diff --git a/apps/server/src/orchestration/Layers/ProviderRuntimeIngestion.ts b/apps/server/src/orchestration/Layers/ProviderRuntimeIngestion.ts index 59787e0b54..88f91105b6 100644 --- a/apps/server/src/orchestration/Layers/ProviderRuntimeIngestion.ts +++ b/apps/server/src/orchestration/Layers/ProviderRuntimeIngestion.ts @@ -344,6 +344,26 @@ function runtimeEventToActivities( ]; } + case "tool.denied": { + return [ + { + id: event.eventId, + createdAt: event.createdAt, + tone: "error", + kind: "tool.denied", + summary: `Tool denied: ${event.payload.toolName}`, + payload: { + toolName: event.payload.toolName, + ...(event.payload.toolUseId ? { toolUseId: event.payload.toolUseId } : {}), + ...(event.payload.reason ? { detail: truncateDetail(event.payload.reason) } : {}), + ...(event.payload.agentId ? { agentId: event.payload.agentId } : {}), + }, + turnId: toTurnId(event.turnId) ?? null, + ...maybeSequence, + }, + ]; + } + case "runtime.warning": { return [ { diff --git a/apps/server/src/provider/Layers/ClaudeAdapter.ts b/apps/server/src/provider/Layers/ClaudeAdapter.ts index ff9bbfe023..f33526e5fd 100644 --- a/apps/server/src/provider/Layers/ClaudeAdapter.ts +++ b/apps/server/src/provider/Layers/ClaudeAdapter.ts @@ -2267,6 +2267,27 @@ export const makeClaudeAdapter = Effect.fn("makeClaudeAdapter")(function* ( }, }); return; + case "thinking_tokens": + return; + case "permission_denied": + yield* offerRuntimeEvent({ + ...base, + type: "tool.denied", + payload: { + toolName: message.tool_name, + ...(message.tool_use_id ? { toolUseId: message.tool_use_id } : {}), + ...(message.decision_reason ? { reason: message.decision_reason } : {}), + ...(message.agent_id ? { agentId: message.agent_id } : {}), + }, + }); + return; + case "mirror_error": + yield* emitRuntimeError( + context, + `Claude workspace mirror error: ${message.error}`, + message, + ); + return; default: yield* emitRuntimeWarning( context, diff --git a/packages/contracts/src/providerRuntime.ts b/packages/contracts/src/providerRuntime.ts index 5032dc4eb4..eb2563eff0 100644 --- a/packages/contracts/src/providerRuntime.ts +++ b/packages/contracts/src/providerRuntime.ts @@ -241,6 +241,7 @@ const ModelReroutedType = Schema.Literal("model.rerouted"); const ConfigWarningType = Schema.Literal("config.warning"); const DeprecationNoticeType = Schema.Literal("deprecation.notice"); const FilesPersistedType = Schema.Literal("files.persisted"); +const ToolDeniedType = Schema.Literal("tool.denied"); const RuntimeWarningType = Schema.Literal("runtime.warning"); const RuntimeErrorType = Schema.Literal("runtime.error"); @@ -589,6 +590,14 @@ const FilesPersistedPayload = Schema.Struct({ }); export type FilesPersistedPayload = typeof FilesPersistedPayload.Type; +const ToolDeniedPayload = Schema.Struct({ + toolName: TrimmedNonEmptyStringSchema, + toolUseId: Schema.optional(TrimmedNonEmptyStringSchema), + reason: Schema.optional(TrimmedNonEmptyStringSchema), + agentId: Schema.optional(TrimmedNonEmptyStringSchema), +}); +export type ToolDeniedPayload = typeof ToolDeniedPayload.Type; + const RuntimeWarningPayload = Schema.Struct({ message: TrimmedNonEmptyStringSchema, detail: Schema.optional(Schema.Unknown), @@ -934,6 +943,13 @@ const ProviderRuntimeFilesPersistedEvent = Schema.Struct({ }); export type ProviderRuntimeFilesPersistedEvent = typeof ProviderRuntimeFilesPersistedEvent.Type; +const ProviderRuntimeToolDeniedEvent = Schema.Struct({ + ...ProviderRuntimeEventBase.fields, + type: ToolDeniedType, + payload: ToolDeniedPayload, +}); +export type ProviderRuntimeToolDeniedEvent = typeof ProviderRuntimeToolDeniedEvent.Type; + const ProviderRuntimeWarningEvent = Schema.Struct({ ...ProviderRuntimeEventBase.fields, type: RuntimeWarningType, @@ -994,6 +1010,7 @@ export const ProviderRuntimeEventV2 = Schema.Union([ ProviderRuntimeConfigWarningEvent, ProviderRuntimeDeprecationNoticeEvent, ProviderRuntimeFilesPersistedEvent, + ProviderRuntimeToolDeniedEvent, ProviderRuntimeWarningEvent, ProviderRuntimeErrorEvent, ]);