ReadonlyserviceStable, human-readable name for the service. Must be set explicitly on each subclass
because this.constructor.name gets mangled by minification in production builds,
which breaks tracing/observability span names.
ProtectedrunProtectedspanOptional hook for subclasses to attach extra non-PII span attributes derived from params.
The returned attributes appear on the service.${serviceName} span (and, for jobs,
on job.enqueue.* and job.run.* spans too).
Safe ID-like keys on params (e.g. patientId, templateIds, limit, cursor) are
already auto-extracted via toSpanAttributes("service.input", params) — you don't need
to enumerate them here. Use this hook for derived/computed attributes (counts, flags,
computed names) or for fields you've explicitly verified safe but that aren't in the
global allowlist. Hook output overrides auto-extracted attributes on key collision.
Safe by default: returns {} when not overridden. Only declare keys you've confirmed
are non-PII. Never include emails, names, dob, free-text, etc.
ProtectedspanOptional hook for subclasses to attach extra non-PII span attributes derived from the
successful service result. Only called when run resolves successfully; on error, the
span is marked via markSpanError instead.
Safe by default: returns {} when not overridden. Only declare keys you've confirmed
are non-PII (e.g. counts, status flags, computed summaries). Never include emails,
names, dob, free-text, etc.
All the work the AssemblyAI webhook triggers once auth and payload parsing have succeeded: session lookup, status transitions, transcript fetch, note generation, and save. Any recoverable failure is logged and surfaced in
outcome; the webhook route still returns 200 so AssemblyAI doesn't retry-storm.TODO(DEV-1874): after saveGeneratedNote, trigger a patient-summary update via a v2 repo-backed service. Previously this fired off to the legacy v1
update-patient-summarySupabase edge function as a stopgap; that was removed in favor of making the port in DEV-1874 explicit work. Until that lands, audio-generated notes do NOT refresh the patient summary. https://linear.app/circlehealthai/issue/DEV-1874