@ajna-inc/workflow 0.6.5 → 0.6.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.npmvc/attestations.jsonld +8 -8
- package/.npmvc/sbom.cdx.json +3 -3
- package/build/WorkflowModule.mjs +5 -0
- package/build/WorkflowModule.mjs.map +1 -1
- package/build/protocol/messages/AdvanceMessage.d.mts +2 -2
- package/build/protocol/messages/CompleteMessage.d.mts +2 -2
- package/build/protocol/messages/DiscoverMessage.d.mts +2 -2
- package/build/protocol/messages/PauseMessage.d.mts +2 -2
- package/build/protocol/messages/PauseMessage.d.mts.map +1 -1
- package/build/protocol/messages/ResumeMessage.d.mts +2 -2
- package/build/protocol/messages/StartMessage.d.mts +2 -2
- package/build/protocol/messages/WorkflowsMessage.d.mts +2 -2
- package/build/protocol/messages/WorkflowsMessage.d.mts.map +1 -1
- package/package.json +3 -3
|
@@ -2,40 +2,40 @@
|
|
|
2
2
|
"schema": "https://npmvc.com/schemas/attestation-bundle/v1",
|
|
3
3
|
"package": {
|
|
4
4
|
"name": "@ajna-inc/workflow",
|
|
5
|
-
"version": "0.6.
|
|
5
|
+
"version": "0.6.6"
|
|
6
6
|
},
|
|
7
|
-
"bundledAt": "2026-05-
|
|
7
|
+
"bundledAt": "2026-05-01T14:07:18.770Z",
|
|
8
8
|
"envelopes": [
|
|
9
9
|
{
|
|
10
10
|
"payloadType": "application/vc+json",
|
|
11
|
-
"payload": "
|
|
11
|
+
"payload": "eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvbnMvY3JlZGVudGlhbHMvdjIiLCJodHRwczovL25wbXZjLmNvbS9zY2hlbWFzL3N1cHBseWNoYWluL3YxIl0sImNyZWRlbnRpYWxTdWJqZWN0Ijp7ImJ1aWxkQ29tbWFuZCI6InRzZG93biAtLWNvbmZpZy1sb2FkZXIgdW5jb25maWciLCJidWlsZGVyIjp7ImlkIjoiZGlkOmtleTp6Nk1raEo1WUJTZEJMSEhKYmppNDVraUpuUmRMVURQdVRWaTdkUDg0TWpTdUV1Y28iLCJraW5kIjoibG9jYWwifSwiaWQiOiJwa2c6bnBtL0Bham5hLWluYy93b3JrZmxvd0AwLjYuNiIsInJlcHJvZHVjaWJsZSI6ZmFsc2UsInNsc2FMZXZlbCI6Miwic291cmNlUmVwbyI6eyJjb21taXQiOiI0N2E5ZTU2NGE3MGI2M2NiYmI4MzkwOTNjZDBiODAxNDY1Y2I1NzM0IiwidHlwZSI6ImdpdCIsInVybCI6InVua25vd24ifSwidGFyYmFsbCI6eyJkaWdlc3QiOnt9LCJuYW1lIjoiQGFqbmEtaW5jL3dvcmtmbG93IiwidmVyc2lvbiI6IjAuNi42In0sInRvb2xjaGFpbiI6eyJub2RlIjoiMjAuMTkuNSIsIm5wbSI6IjEwLjIyLjAifX0sImlkIjoidXJuOnV1aWQ6ZWNhMzZhMDItODI3Yi00ZDBlLTgwYjQtNzdmYzQzMDY3M2UyIiwiaXNzdWVyIjoiZGlkOmtleTp6Nk1raEo1WUJTZEJMSEhKYmppNDVraUpuUmRMVURQdVRWaTdkUDg0TWpTdUV1Y28iLCJ0eXBlIjpbIlZlcmlmaWFibGVDcmVkZW50aWFsIiwiUHJvdmVuYW5jZUNyZWRlbnRpYWwiXSwidmFsaWRGcm9tIjoiMjAyNi0wNS0wMVQxNDowNzoxOC41MDhaIn0=",
|
|
12
12
|
"signatures": [
|
|
13
13
|
{
|
|
14
14
|
"keyid": "did:key:z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco#z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco",
|
|
15
15
|
"alg": "Ed25519",
|
|
16
|
-
"sig": "
|
|
16
|
+
"sig": "3wvTR2gJ4M85HyVGE6ymWFPZHbk9o06FyyIbFymuVapZOuwmmyu5vsKcM5aW3p7uA7oLVWkBGyhhGHbbBtp6Aw=="
|
|
17
17
|
}
|
|
18
18
|
]
|
|
19
19
|
},
|
|
20
20
|
{
|
|
21
21
|
"payloadType": "application/vc+json",
|
|
22
|
-
"payload": "
|
|
22
|
+
"payload": "eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvbnMvY3JlZGVudGlhbHMvdjIiLCJodHRwczovL25wbXZjLmNvbS9zY2hlbWFzL3N1cHBseWNoYWluL3YxIl0sImNyZWRlbnRpYWxTdWJqZWN0Ijp7ImRlY2xhcmVkU2NyaXB0cyI6WyJidWlsZCIsInByZXB1Ymxpc2hPbmx5IiwiY2xlYW4iLCJwcmVwYWNrIl0sImlkIjoicGtnOm5wbS9AYWpuYS1pbmMvd29ya2Zsb3dAMC42LjYiLCJwb3N0SW5zdGFsbFBvbGljeSI6ImZvcmJpZGRlbiIsInRhcmJhbGwiOnsiZGlnZXN0Ijp7fSwibmFtZSI6IkBham5hLWluYy93b3JrZmxvdyIsInZlcnNpb24iOiIwLjYuNiJ9LCJ3aGl0ZWxpc3RlZFNjcmlwdHMiOltdfSwiaWQiOiJ1cm46dXVpZDplOTIxZDRlNy01NGJmLTRmMzAtYTAzNS02NmI5N2E4ZDA4NDgiLCJpc3N1ZXIiOiJkaWQ6a2V5Ono2TWtoSjVZQlNkQkxISEpiamk0NWtpSm5SZExVRFB1VFZpN2RQODRNalN1RXVjbyIsInR5cGUiOlsiVmVyaWZpYWJsZUNyZWRlbnRpYWwiLCJMaWZlY3ljbGVQb2xpY3lDcmVkZW50aWFsIl0sInZhbGlkRnJvbSI6IjIwMjYtMDUtMDFUMTQ6MDc6MTguNTI2WiJ9",
|
|
23
23
|
"signatures": [
|
|
24
24
|
{
|
|
25
25
|
"keyid": "did:key:z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco#z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco",
|
|
26
26
|
"alg": "Ed25519",
|
|
27
|
-
"sig": "
|
|
27
|
+
"sig": "OJbZ+UvYKA9rhQ0OBke50ubIRebc9z7rlxwAjj6FFy7+vs0xKdZ/ZcPRuWsIqYF1Cl6i5y6xvdYx25x+zneMBw=="
|
|
28
28
|
}
|
|
29
29
|
]
|
|
30
30
|
},
|
|
31
31
|
{
|
|
32
32
|
"payloadType": "application/vc+json",
|
|
33
|
-
"payload": "
|
|
33
|
+
"payload": "eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvbnMvY3JlZGVudGlhbHMvdjIiLCJodHRwczovL25wbXZjLmNvbS9zY2hlbWFzL3N1cHBseWNoYWluL3YxIl0sImNyZWRlbnRpYWxTdWJqZWN0Ijp7ImZvcm1hdCI6ImN5Y2xvbmVkeC0xLjYiLCJpZCI6InBrZzpucG0vQGFqbmEtaW5jL3dvcmtmbG93QDAuNi42Iiwic2JvbURpZ2VzdCI6eyJhbGciOiJzaGEyNTYiLCJoZXgiOiI2ZTgzYzQxYzI3NjgzZWFhNjk1ZDJjZjc4YWRmZjgzYmI2MDFlOWVjMDE3YWI4OGY3MDUxMDg3OWY2Y2ZkN2I1In0sInNib21VcmwiOiIuLy5ucG12Yy9zYm9tLmNkeC5qc29uIiwidGFyYmFsbCI6eyJkaWdlc3QiOnt9LCJuYW1lIjoiQGFqbmEtaW5jL3dvcmtmbG93IiwidmVyc2lvbiI6IjAuNi42In19LCJpZCI6InVybjp1dWlkOjVlNGFhN2NmLTAxMjktNDllYy04OGZjLWE5OTMzY2IwOTJkOSIsImlzc3VlciI6ImRpZDprZXk6ejZNa2hKNVlCU2RCTEhISmJqaTQ1a2lKblJkTFVEUHVUVmk3ZFA4NE1qU3VFdWNvIiwidHlwZSI6WyJWZXJpZmlhYmxlQ3JlZGVudGlhbCIsIlNib21DcmVkZW50aWFsIl0sInZhbGlkRnJvbSI6IjIwMjYtMDUtMDFUMTQ6MDc6MTguNzY5WiJ9",
|
|
34
34
|
"signatures": [
|
|
35
35
|
{
|
|
36
36
|
"keyid": "did:key:z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco#z6MkhJ5YBSdBLHHJbji45kiJnRdLUDPuTVi7dP84MjSuEuco",
|
|
37
37
|
"alg": "Ed25519",
|
|
38
|
-
"sig": "
|
|
38
|
+
"sig": "Fkji9JFkhpLdvwl9pgrvbpslssQMZWyugSfkCHKUSntzIhXA0wir13OD/gRTfrPWI3+WzkRK6NSOwIactUC4CA=="
|
|
39
39
|
}
|
|
40
40
|
]
|
|
41
41
|
}
|
package/.npmvc/sbom.cdx.json
CHANGED
|
@@ -3,12 +3,12 @@
|
|
|
3
3
|
"specVersion": "1.6",
|
|
4
4
|
"version": 1,
|
|
5
5
|
"metadata": {
|
|
6
|
-
"timestamp": "2026-05-
|
|
6
|
+
"timestamp": "2026-05-01T14:07:18.764Z",
|
|
7
7
|
"component": {
|
|
8
8
|
"type": "application",
|
|
9
9
|
"name": "@ajna-inc/workflow",
|
|
10
|
-
"version": "0.6.
|
|
11
|
-
"purl": "pkg:npm/%40ajna-inc/workflow@0.6.
|
|
10
|
+
"version": "0.6.6",
|
|
11
|
+
"purl": "pkg:npm/%40ajna-inc/workflow@0.6.6"
|
|
12
12
|
},
|
|
13
13
|
"tools": [
|
|
14
14
|
{
|
package/build/WorkflowModule.mjs
CHANGED
|
@@ -123,8 +123,13 @@ var WorkflowModule = class {
|
|
|
123
123
|
}
|
|
124
124
|
try {
|
|
125
125
|
if (rec.state === DidCommCredentialState.ProposalReceived) await service.autoAdvanceByConnection(scoped.context, connId, "proposal_received");
|
|
126
|
+
else if (rec.state === DidCommCredentialState.ProposalSent) await service.autoAdvanceByConnection(scoped.context, connId, "proposal_sent");
|
|
126
127
|
else if (rec.state === DidCommCredentialState.OfferReceived) await service.autoAdvanceByConnection(scoped.context, connId, "offer_received");
|
|
128
|
+
else if (rec.state === DidCommCredentialState.OfferSent) await service.autoAdvanceByConnection(scoped.context, connId, "offer_sent");
|
|
127
129
|
else if (rec.state === DidCommCredentialState.RequestReceived) await service.autoAdvanceByConnection(scoped.context, connId, "request_received");
|
|
130
|
+
else if (rec.state === DidCommCredentialState.RequestSent) await service.autoAdvanceByConnection(scoped.context, connId, "request_sent");
|
|
131
|
+
else if (rec.state === DidCommCredentialState.CredentialIssued) await service.autoAdvanceByConnection(scoped.context, connId, "credential_issued");
|
|
132
|
+
else if (rec.state === DidCommCredentialState.CredentialReceived) await service.autoAdvanceByConnection(scoped.context, connId, "credential_received");
|
|
128
133
|
else if (rec.state === DidCommCredentialState.Done) await service.autoAdvanceByConnection(scoped.context, connId, "issued_ack");
|
|
129
134
|
} finally {
|
|
130
135
|
await scoped.release();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WorkflowModule.mjs","names":["createPaymentsV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)","PaymentsEventTypes: Partial<Record<PaymentEvtKeys, string>> | undefined","createPoeV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)","PoeEventTypes: Partial<Record<PoeEvtKeys, string>> | undefined","PoeState: { [key: string]: string } | undefined","workflowEvent: string | undefined","g: any","metadata: EventMetadata"],"sources":["../src/WorkflowModule.ts"],"sourcesContent":["import type { WorkflowModuleConfigOptions } from './WorkflowModuleConfig'\nimport type { AgentContext, DependencyManager, Module, AgentContextProvider, EventMetadata } from '@credo-ts/core'\nimport type { DidCommCredentialStateChangedEvent, DidCommProofStateChangedEvent } from '@credo-ts/didcomm'\n\nimport { AgentConfig, EventEmitter, InjectionSymbols } from '@credo-ts/core'\n\nimport { DidCommCredentialEventTypes, DidCommProofEventTypes, DidCommProtocol } from '@credo-ts/didcomm'\n\nimport { DidCommCredentialState, DidCommProofState } from '@credo-ts/didcomm'\n\nimport { DidCommFeatureRegistry, DidCommMessageHandlerRegistry, DidCommMessageSender, DidCommOutboundMessageContext, ReturnRouteTypes } from '@credo-ts/didcomm'\n\nimport { WorkflowModuleConfig } from './WorkflowModuleConfig'\nimport { CommandQueueService } from './queue/CommandQueue'\nimport { PersistentCommandQueue } from './queue/PersistentCommandQueue'\nimport { WorkflowApi } from './api/WorkflowApi'\nimport { WorkflowCommandRepository } from './repository/WorkflowCommandRepository'\nimport { AdvanceHandler } from './protocol/handlers/AdvanceHandler'\nimport { CancelHandler } from './protocol/handlers/CancelHandler'\nimport { CompleteHandler } from './protocol/handlers/CompleteHandler'\nimport { DiscoverHandler } from './protocol/handlers/DiscoverHandler'\nimport { FetchTemplateHandler } from './protocol/handlers/FetchTemplateHandler'\nimport { TemplateHandler } from './protocol/handlers/TemplateHandler'\nimport { PauseHandler } from './protocol/handlers/PauseHandler'\nimport { ProblemReportHandler } from './protocol/handlers/ProblemReportHandler'\nimport { PublishTemplateHandler } from './protocol/handlers/PublishTemplateHandler'\nimport { ResumeHandler } from './protocol/handlers/ResumeHandler'\nimport { StartHandler } from './protocol/handlers/StartHandler'\nimport { StatusHandler } from './protocol/handlers/StatusHandler'\nimport { WorkflowInstanceRepository } from './repository/WorkflowInstanceRepository'\nimport { WorkflowTemplateRepository } from './repository/WorkflowTemplateRepository'\nimport { WorkflowService } from './services/WorkflowService'\nimport { DidCommConnectionService } from '@credo-ts/didcomm'\n\nexport const WORKFLOW_PROTOCOL_URI = 'https://didcomm.org/workflow/1.0'\nexport const WORKFLOW_ROLES = ['processor', 'coordinator'] as const\n\nexport class WorkflowModule implements Module {\n public readonly api = WorkflowApi\n public readonly config: WorkflowModuleConfig\n\n public constructor(options?: WorkflowModuleConfigOptions) {\n this.config = new WorkflowModuleConfig(options)\n }\n\n public register(dependencyManager: DependencyManager) {\n dependencyManager.resolve(AgentConfig).logger.info('Registering WorkflowModule')\n dependencyManager.registerInstance(WorkflowModuleConfig, this.config)\n\n dependencyManager.registerSingleton(WorkflowTemplateRepository)\n dependencyManager.registerSingleton(WorkflowInstanceRepository)\n dependencyManager.registerSingleton(WorkflowCommandRepository)\n dependencyManager.registerSingleton(WorkflowService)\n // IMPORTANT: Do not register WorkflowApi as a singleton here.\n // The DependencyManager will register `module.api` (WorkflowApi) as context-scoped\n // via `registerModules`, ensuring a fresh API instance per AgentContext (tenant-safe).\n\n dependencyManager.registerSingleton(PublishTemplateHandler)\n dependencyManager.registerSingleton(StartHandler)\n dependencyManager.registerSingleton(AdvanceHandler)\n dependencyManager.registerSingleton(StatusHandler)\n dependencyManager.registerSingleton(ProblemReportHandler)\n dependencyManager.registerSingleton(PauseHandler)\n dependencyManager.registerSingleton(ResumeHandler)\n dependencyManager.registerSingleton(CancelHandler)\n dependencyManager.registerSingleton(CompleteHandler)\n dependencyManager.registerSingleton(DiscoverHandler)\n dependencyManager.registerSingleton(FetchTemplateHandler)\n dependencyManager.registerSingleton(TemplateHandler)\n }\n\n public async initialize(agentContext: AgentContext): Promise<void> {\n const dm = agentContext.dependencyManager\n const logger = dm.resolve(AgentConfig).logger\n const features = dm.resolve(DidCommFeatureRegistry)\n const handlers = dm.resolve(DidCommMessageHandlerRegistry)\n logger.info('Initializing WorkflowModule - registering workflow/1.0 protocol')\n try {\n features.register(new DidCommProtocol({ id: WORKFLOW_PROTOCOL_URI, roles: [...WORKFLOW_ROLES] }))\n } catch (_e) {\n void 0\n }\n handlers.registerMessageHandler(dm.resolve(PublishTemplateHandler))\n handlers.registerMessageHandler(dm.resolve(StartHandler))\n handlers.registerMessageHandler(dm.resolve(AdvanceHandler))\n handlers.registerMessageHandler(dm.resolve(StatusHandler))\n handlers.registerMessageHandler(dm.resolve(ProblemReportHandler))\n handlers.registerMessageHandler(dm.resolve(PauseHandler))\n handlers.registerMessageHandler(dm.resolve(ResumeHandler))\n handlers.registerMessageHandler(dm.resolve(CancelHandler))\n handlers.registerMessageHandler(dm.resolve(CompleteHandler))\n // discovery/fetch extension\n handlers.registerMessageHandler(dm.resolve(DiscoverHandler))\n handlers.registerMessageHandler(dm.resolve(FetchTemplateHandler))\n handlers.registerMessageHandler(dm.resolve(TemplateHandler))\n // Inbound mapping: credentials/proofs → workflow events\n const events = dm.resolve(EventEmitter)\n const service = dm.resolve(WorkflowService)\n const contextProvider = dm.resolve<AgentContextProvider>(InjectionSymbols.AgentContextProvider)\n const rootContextId = agentContext.contextCorrelationId\n\n const resolveEventContext = async (\n metadata: EventMetadata | undefined\n ): Promise<{ context: AgentContext; release: () => Promise<void> } | null> => {\n const correlationId = metadata?.contextCorrelationId\n if (!correlationId || correlationId === rootContextId) {\n return { context: agentContext, release: async () => {} }\n }\n\n try {\n const scopedContext = await contextProvider.getAgentContextForContextCorrelationId(correlationId)\n return {\n context: scopedContext,\n release: async () => {\n try {\n await contextProvider.endSessionForAgentContext(scopedContext)\n } catch (error) {\n logger.debug('WorkflowModule - failed to end tenant session after event', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n }\n },\n }\n } catch (error) {\n logger.warn('WorkflowModule - unable to resolve context for event', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n return null\n }\n }\n\n events.on<DidCommCredentialStateChangedEvent>(DidCommCredentialEventTypes.DidCommCredentialStateChanged, async (e) => {\n const rec = e.payload.credentialExchangeRecord\n const connId = rec.connectionId\n logger.info(`[WorkflowModule] Credential state changed: ${rec.state}, connectionId=${connId}, contextCorrelationId=${e.metadata?.contextCorrelationId}`)\n if (!connId) { logger.warn('[WorkflowModule] No connectionId on credential record, skipping auto-advance'); return }\n const scoped = await resolveEventContext(e.metadata)\n if (!scoped) { logger.warn('[WorkflowModule] Failed to resolve event context, skipping auto-advance'); return }\n try {\n if (rec.state === DidCommCredentialState.ProposalReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'proposal_received')\n } else if (rec.state === DidCommCredentialState.OfferReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'offer_received')\n } else if (rec.state === DidCommCredentialState.RequestReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'request_received')\n } else if (rec.state === DidCommCredentialState.Done) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'issued_ack')\n }\n } finally {\n await scoped.release()\n }\n })\n events.on<DidCommProofStateChangedEvent>(DidCommProofEventTypes.ProofStateChanged, async (e) => {\n const rec = e.payload.proofRecord\n const connId = rec.connectionId\n if (!connId) return\n const scoped = await resolveEventContext(e.metadata)\n if (!scoped) return\n try {\n if (rec.state === DidCommProofState.PresentationReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'presentation_received')\n } else if (rec.state === DidCommProofState.Done) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'verified_ack')\n }\n } finally {\n await scoped.release()\n }\n })\n\n // Optional: register payments v1 actions when payments module is available\n try {\n let createPaymentsV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments'))\n } catch {\n /* optional dependency */\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n // Try @ajna-inc/payments (static require for React Native compatibility)\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@ajna-inc/payments'))\n } catch {\n /* optional dependency */\n }\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@ajna-inc/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (createPaymentsV1Actions) {\n const actions = createPaymentsV1Actions()\n try {\n // Prefer explicit API if available\n const svcAny = service as unknown as {\n registerActions?: (actions: unknown[]) => void\n actions?: { register: (h: unknown) => void }\n }\n if (typeof svcAny.registerActions === 'function') {\n svcAny.registerActions(actions)\n } else if (svcAny.actions && typeof svcAny.actions.register === 'function') {\n for (const a of actions) svcAny.actions.register(a)\n } else {\n throw new Error('no action registry available')\n }\n logger.info('WorkflowModule - registered PaymentsV1 actions')\n } catch (_e) {\n // swallow\n }\n }\n } catch {\n /* optional dependency */\n }\n\n // Optional: map payments events → workflow events (guarded if payments not installed)\n if (this.config.enablePaymentsEventMapping)\n try {\n type PaymentEvtKeys =\n | 'IntroResponded'\n | 'HandshakeAccepted'\n | 'ComplianceRequired'\n | 'ComplianceSatisfied'\n | 'ComplianceRejected'\n | 'SettlementUpdated'\n let PaymentsEventTypes: Partial<Record<PaymentEvtKeys, string>> | undefined\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments'))\n } catch {\n /* optional dependency */\n }\n if (!PaymentsEventTypes) {\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments/events/PaymentEvents'))\n } catch {\n /* optional dependency */\n }\n }\n if (!PaymentsEventTypes) {\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments/events/PaymentEvents'))\n } catch {\n /* optional dependency */\n }\n }\n if (!PaymentsEventTypes) throw new Error('payments not available')\n\n const adv = async (threadId: string, event: string, metadata?: EventMetadata) => {\n const scoped = await resolveEventContext(metadata)\n if (!scoped) return\n try {\n await service.advance(scoped.context, {\n instance_id: threadId,\n event,\n idempotency_key: `auto:payments:${event}:${threadId}`,\n })\n } catch (e) {\n logger.debug(`[Workflow] payments event advance error: ${(e as Error).message}`)\n } finally {\n await scoped.release()\n }\n }\n type PaymentListener = (e: {\n payload?: { threadId?: string; status?: string }\n metadata?: EventMetadata\n }) => void\n const on = (evt: string, cb: PaymentListener) =>\n (events as unknown as { on?: (evt: string, cb: PaymentListener) => void }).on?.(evt, cb)\n if (PaymentsEventTypes.IntroResponded)\n on(PaymentsEventTypes.IntroResponded, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.methods_received', e?.metadata)\n })\n if (PaymentsEventTypes.HandshakeAccepted)\n on(PaymentsEventTypes.HandshakeAccepted, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.handshake_accepted', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceRequired)\n on(PaymentsEventTypes.ComplianceRequired, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_required', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceSatisfied)\n on(PaymentsEventTypes.ComplianceSatisfied, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_satisfied', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceRejected)\n on(PaymentsEventTypes.ComplianceRejected, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_rejected', e?.metadata)\n })\n if (PaymentsEventTypes.SettlementUpdated)\n on(PaymentsEventTypes.SettlementUpdated, async (e) => {\n const p = e?.payload\n const th = p?.threadId\n const status = p?.status\n if (!status) return\n const map: Record<string, string> = {\n received: 'payments.receipt_received',\n pending: 'payments.settlement_pending',\n settled: 'payments.settled',\n failed: 'payments.failed',\n }\n const ev = map[status]\n if (ev && th) await adv(th, ev, e?.metadata)\n })\n logger.info('WorkflowModule - registered Payments event listeners')\n } catch {\n /* optional dependency */\n }\n\n // Optional: register POE v1 actions when POE module is available\n try {\n let createPoeV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)\n try {\n ;({ createPoeV1Actions } = require('@ajna-inc/poe'))\n } catch {\n /* optional dependency */\n }\n if (!createPoeV1Actions) {\n try {\n ;({ createPoeV1Actions } = require('@ajna-inc/poe/workflow/PoeV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (createPoeV1Actions) {\n const actions = createPoeV1Actions()\n try {\n const svcAny = service as unknown as {\n registerActions?: (actions: unknown[]) => void\n actions?: { register: (h: unknown) => void }\n }\n if (typeof svcAny.registerActions === 'function') {\n svcAny.registerActions(actions)\n } else if (svcAny.actions && typeof svcAny.actions.register === 'function') {\n for (const a of actions) svcAny.actions.register(a)\n } else {\n throw new Error('no action registry available')\n }\n logger.info('WorkflowModule - registered PoeV1 actions')\n } catch (_e) {\n // swallow\n }\n }\n } catch {\n /* optional dependency */\n }\n\n // Optional: map POE events → workflow events (guarded if POE not installed)\n if (this.config.enablePoeEventMapping)\n try {\n type PoeEvtKeys = 'PoeStateChanged'\n let PoeEventTypes: Partial<Record<PoeEvtKeys, string>> | undefined\n let PoeState: { [key: string]: string } | undefined\n try {\n ;({ PoeEventTypes, PoeState } = require('@ajna-inc/poe'))\n } catch {\n /* optional dependency */\n }\n if (!PoeEventTypes || !PoeState) throw new Error('poe not available')\n\n type PoeListener = (e: {\n payload?: {\n poeRecord?: {\n id?: string\n connectionId?: string\n sessionId?: string\n state?: string\n programId?: string\n verificationResult?: { verified?: boolean; errors?: string[] }\n finalProof?: { result?: unknown }\n }\n previousState?: string\n }\n metadata?: EventMetadata\n }) => void\n const on = (evt: string, cb: PoeListener) =>\n (events as unknown as { on?: (evt: string, cb: PoeListener) => void }).on?.(evt, cb)\n\n if (PoeEventTypes.PoeStateChanged)\n on(PoeEventTypes.PoeStateChanged, async (e) => {\n const poeRecord = e?.payload?.poeRecord\n const connectionId = poeRecord?.connectionId\n if (!connectionId) return\n\n const scoped = await resolveEventContext(e?.metadata)\n if (!scoped) return\n try {\n let workflowEvent: string | undefined\n\n switch (poeRecord.state) {\n case PoeState?.RequestReceived:\n workflowEvent = 'poe.request_received'\n break\n case PoeState?.SubmitReceived:\n workflowEvent = poeRecord.verificationResult?.verified\n ? 'poe.verified'\n : 'poe.verification_failed'\n break\n case PoeState?.ProposalReceived:\n workflowEvent = 'poe.proposal_received'\n break\n case PoeState?.Accepted:\n workflowEvent = 'poe.accepted'\n break\n case PoeState?.Declined:\n workflowEvent = 'poe.declined'\n break\n case PoeState?.Complete:\n workflowEvent = 'poe.completed'\n break\n case PoeState?.Problem:\n workflowEvent = 'poe.problem'\n break\n case PoeState?.ChallengeReceived:\n workflowEvent = 'poe.challenge_received'\n break\n }\n\n if (workflowEvent) {\n await service.autoAdvanceByConnection(\n scoped.context,\n connectionId,\n workflowEvent\n )\n }\n } catch (err) {\n logger.debug(`[Workflow] POE event advance error: ${(err as Error).message}`)\n } finally {\n await scoped.release()\n }\n })\n logger.info('WorkflowModule - registered POE event listeners')\n } catch {\n /* optional dependency */\n }\n\n // Initialize persistent command queue (always enabled, no Redis needed)\n logger.info('WorkflowModule - initializing persistent command queue')\n const commandRepo = dm.resolve(WorkflowCommandRepository)\n const queue = new PersistentCommandQueue(commandRepo, contextProvider, agentContext, {\n pollIntervalMs: this.config.asyncQueue?.pollIntervalMs,\n concurrency: this.config.asyncQueue?.concurrency,\n processingTimeoutMs: this.config.asyncQueue?.processingTimeoutMs,\n staleCheckIntervalMs: this.config.asyncQueue?.staleCheckIntervalMs,\n cleanupIntervalMs: this.config.asyncQueue?.cleanupIntervalMs,\n commandRetentionMs: this.config.asyncQueue?.commandRetentionMs,\n failedRetentionMs: this.config.asyncQueue?.failedRetentionMs,\n maxAttempts: this.config.asyncQueue?.maxAttempts,\n })\n\n // Test-time helper: register queue instance globally for best-effort shutdown in afterAll\n try {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const g: any = globalThis as unknown\n g.__WF_QUEUES = g.__WF_QUEUES || new Set()\n g.__WF_QUEUES.add(queue)\n } catch {\n /* noop */\n }\n\n // In tests or minimal environments, dependencyManager may not expose registerInstance\n try {\n const anyDm = dm as unknown as { registerInstance?: (ctor: unknown, instance: unknown) => void }\n anyDm.registerInstance?.(CommandQueueService, queue)\n } catch {\n // no-op if DI container doesn't support instance registration in this context\n }\n\n // Start worker: processes commands and sends follow-up status messages\n await queue.startWorker(async (job) => {\n // Context resolution handled inside PersistentCommandQueue\n // Worker receives job with already-resolved context\n\n // This worker callback is called from PersistentCommandQueue.processCommand\n // which already resolves the context, so we need to get it here\n const metadata: EventMetadata = { contextCorrelationId: job.contextCorrelationId }\n const scoped = await (async () => {\n const correlationId = metadata.contextCorrelationId\n if (!correlationId || correlationId === rootContextId) {\n return { context: agentContext, release: async () => {} }\n }\n try {\n const scopedContext = await contextProvider.getAgentContextForContextCorrelationId(correlationId)\n return {\n context: scopedContext,\n release: async () => {\n try {\n await contextProvider.endSessionForAgentContext(scopedContext)\n } catch (error) {\n logger.debug('WorkflowModule - failed to end tenant session after queue job', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n }\n },\n }\n } catch (error) {\n logger.debug('WorkflowModule - unable to resolve context for queue job', {\n error: (error as Error).message,\n })\n return null\n }\n })()\n if (!scoped) return\n try {\n const ctx = scoped.context\n try {\n logger.info('[WorkflowWorker] handling job', {\n cmd: (job as { cmd?: string }).cmd,\n thid: (job as { thid?: string }).thid,\n connectionId: (job as { connectionId?: string }).connectionId,\n contextCorrelationId: (job as { contextCorrelationId?: string }).contextCorrelationId,\n })\n } catch {}\n switch (job.cmd) {\n case 'start': {\n // Ensure template exists before starting. If missing, attempt auto-discover and defer.\n try {\n const templateRepo = dm.resolve(WorkflowTemplateRepository)\n const p = (job.payload || {}) as unknown as {\n template_id?: string\n template_version?: string\n template_hash?: string\n allow_discover?: boolean\n }\n const templateRec = p.template_id\n ? await templateRepo.findByTemplateIdAndVersion(ctx, p.template_id, p.template_version)\n : null\n if (!templateRec) {\n const allowDiscover = p.allow_discover ?? true\n if (allowDiscover && this.config.enableAutoDiscoverOnStart && job.connectionId) {\n try {\n const sender = dm.resolve(DidCommMessageSender)\n const connectionSvc = dm.resolve(DidCommConnectionService)\n const connection = await connectionSvc.getById(ctx, job.connectionId)\n const { FetchTemplateMessage } = require('./protocol/messages/FetchTemplateMessage')\n const fetch = new FetchTemplateMessage({\n thid: job.thid,\n body: {\n template_id: p.template_id,\n template_version: p.template_version,\n prefer_hash: p.template_hash,\n },\n })\n try {\n fetch.setReturnRouting(ReturnRouteTypes.thread, job.thid)\n } catch {}\n const outbound = new DidCommOutboundMessageContext(fetch, { agentContext: ctx, connection })\n await sender.sendMessage(outbound)\n try {\n logger.info('[WorkflowWorker] fetch-template sent from worker', {\n thid: job.thid,\n template_id: p.template_id,\n template_version: p.template_version,\n })\n } catch {}\n } catch (e) {\n logger.debug('WorkflowModule - fetch-template send failed in worker', {\n error: (e as Error).message,\n })\n }\n }\n // Defer start by signaling invalid_template so queue will retry later\n const err = new Error('template not found for start') as Error & { code?: string }\n err.code = 'invalid_template'\n throw err\n }\n } catch (precheckErr) {\n // Rethrow to queue-level handler for unified deferral behavior\n throw precheckErr\n }\n await service.start(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] start completed', { thid: job.thid }) } catch {}\n break\n }\n case 'advance':\n await service.advance(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] advance completed', { thid: job.thid }) } catch {}\n break\n case 'pause':\n await service.pause(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] pause completed', { thid: job.thid }) } catch {}\n break\n case 'resume':\n await service.resume(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] resume completed', { thid: job.thid }) } catch {}\n break\n case 'cancel':\n await service.cancel(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] cancel completed', { thid: job.thid }) } catch {}\n break\n case 'complete':\n await service.complete(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] complete completed', { thid: job.thid }) } catch {}\n break\n }\n\n // Note: Per Workflow 1.0 spec §11.6 and §3.4, status is provided on-demand (pull-based).\n // The spec defines status as a request/response pattern where Coordinators explicitly\n // request status via StatusRequestMessage, and Processors respond with StatusMessage.\n //\n // Unsolicited push notifications are not part of the base protocol and cause issues:\n // - Tenant context mismatches in multi-tenant deployments\n // - Receivers interpret unsolicited StatusMessage as a request (same @type)\n // - HTTP transport timeouts (fire-and-forget over request/response transport)\n //\n // For real-time UI updates, use the existing WebSocket event system which emits\n // WorkflowInstanceStateChanged events to connected clients.\n } finally {\n await scoped.release()\n }\n })\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"WorkflowModule.mjs","names":["createPaymentsV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)","PaymentsEventTypes: Partial<Record<PaymentEvtKeys, string>> | undefined","createPoeV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)","PoeEventTypes: Partial<Record<PoeEvtKeys, string>> | undefined","PoeState: { [key: string]: string } | undefined","workflowEvent: string | undefined","g: any","metadata: EventMetadata"],"sources":["../src/WorkflowModule.ts"],"sourcesContent":["import type { WorkflowModuleConfigOptions } from './WorkflowModuleConfig'\nimport type { AgentContext, DependencyManager, Module, AgentContextProvider, EventMetadata } from '@credo-ts/core'\nimport type { DidCommCredentialStateChangedEvent, DidCommProofStateChangedEvent } from '@credo-ts/didcomm'\n\nimport { AgentConfig, EventEmitter, InjectionSymbols } from '@credo-ts/core'\n\nimport { DidCommCredentialEventTypes, DidCommProofEventTypes, DidCommProtocol } from '@credo-ts/didcomm'\n\nimport { DidCommCredentialState, DidCommProofState } from '@credo-ts/didcomm'\n\nimport { DidCommFeatureRegistry, DidCommMessageHandlerRegistry, DidCommMessageSender, DidCommOutboundMessageContext, ReturnRouteTypes } from '@credo-ts/didcomm'\n\nimport { WorkflowModuleConfig } from './WorkflowModuleConfig'\nimport { CommandQueueService } from './queue/CommandQueue'\nimport { PersistentCommandQueue } from './queue/PersistentCommandQueue'\nimport { WorkflowApi } from './api/WorkflowApi'\nimport { WorkflowCommandRepository } from './repository/WorkflowCommandRepository'\nimport { AdvanceHandler } from './protocol/handlers/AdvanceHandler'\nimport { CancelHandler } from './protocol/handlers/CancelHandler'\nimport { CompleteHandler } from './protocol/handlers/CompleteHandler'\nimport { DiscoverHandler } from './protocol/handlers/DiscoverHandler'\nimport { FetchTemplateHandler } from './protocol/handlers/FetchTemplateHandler'\nimport { TemplateHandler } from './protocol/handlers/TemplateHandler'\nimport { PauseHandler } from './protocol/handlers/PauseHandler'\nimport { ProblemReportHandler } from './protocol/handlers/ProblemReportHandler'\nimport { PublishTemplateHandler } from './protocol/handlers/PublishTemplateHandler'\nimport { ResumeHandler } from './protocol/handlers/ResumeHandler'\nimport { StartHandler } from './protocol/handlers/StartHandler'\nimport { StatusHandler } from './protocol/handlers/StatusHandler'\nimport { WorkflowInstanceRepository } from './repository/WorkflowInstanceRepository'\nimport { WorkflowTemplateRepository } from './repository/WorkflowTemplateRepository'\nimport { WorkflowService } from './services/WorkflowService'\nimport { DidCommConnectionService } from '@credo-ts/didcomm'\n\nexport const WORKFLOW_PROTOCOL_URI = 'https://didcomm.org/workflow/1.0'\nexport const WORKFLOW_ROLES = ['processor', 'coordinator'] as const\n\nexport class WorkflowModule implements Module {\n public readonly api = WorkflowApi\n public readonly config: WorkflowModuleConfig\n\n public constructor(options?: WorkflowModuleConfigOptions) {\n this.config = new WorkflowModuleConfig(options)\n }\n\n public register(dependencyManager: DependencyManager) {\n dependencyManager.resolve(AgentConfig).logger.info('Registering WorkflowModule')\n dependencyManager.registerInstance(WorkflowModuleConfig, this.config)\n\n dependencyManager.registerSingleton(WorkflowTemplateRepository)\n dependencyManager.registerSingleton(WorkflowInstanceRepository)\n dependencyManager.registerSingleton(WorkflowCommandRepository)\n dependencyManager.registerSingleton(WorkflowService)\n // IMPORTANT: Do not register WorkflowApi as a singleton here.\n // The DependencyManager will register `module.api` (WorkflowApi) as context-scoped\n // via `registerModules`, ensuring a fresh API instance per AgentContext (tenant-safe).\n\n dependencyManager.registerSingleton(PublishTemplateHandler)\n dependencyManager.registerSingleton(StartHandler)\n dependencyManager.registerSingleton(AdvanceHandler)\n dependencyManager.registerSingleton(StatusHandler)\n dependencyManager.registerSingleton(ProblemReportHandler)\n dependencyManager.registerSingleton(PauseHandler)\n dependencyManager.registerSingleton(ResumeHandler)\n dependencyManager.registerSingleton(CancelHandler)\n dependencyManager.registerSingleton(CompleteHandler)\n dependencyManager.registerSingleton(DiscoverHandler)\n dependencyManager.registerSingleton(FetchTemplateHandler)\n dependencyManager.registerSingleton(TemplateHandler)\n }\n\n public async initialize(agentContext: AgentContext): Promise<void> {\n const dm = agentContext.dependencyManager\n const logger = dm.resolve(AgentConfig).logger\n const features = dm.resolve(DidCommFeatureRegistry)\n const handlers = dm.resolve(DidCommMessageHandlerRegistry)\n logger.info('Initializing WorkflowModule - registering workflow/1.0 protocol')\n try {\n features.register(new DidCommProtocol({ id: WORKFLOW_PROTOCOL_URI, roles: [...WORKFLOW_ROLES] }))\n } catch (_e) {\n void 0\n }\n handlers.registerMessageHandler(dm.resolve(PublishTemplateHandler))\n handlers.registerMessageHandler(dm.resolve(StartHandler))\n handlers.registerMessageHandler(dm.resolve(AdvanceHandler))\n handlers.registerMessageHandler(dm.resolve(StatusHandler))\n handlers.registerMessageHandler(dm.resolve(ProblemReportHandler))\n handlers.registerMessageHandler(dm.resolve(PauseHandler))\n handlers.registerMessageHandler(dm.resolve(ResumeHandler))\n handlers.registerMessageHandler(dm.resolve(CancelHandler))\n handlers.registerMessageHandler(dm.resolve(CompleteHandler))\n // discovery/fetch extension\n handlers.registerMessageHandler(dm.resolve(DiscoverHandler))\n handlers.registerMessageHandler(dm.resolve(FetchTemplateHandler))\n handlers.registerMessageHandler(dm.resolve(TemplateHandler))\n // Inbound mapping: credentials/proofs → workflow events\n const events = dm.resolve(EventEmitter)\n const service = dm.resolve(WorkflowService)\n const contextProvider = dm.resolve<AgentContextProvider>(InjectionSymbols.AgentContextProvider)\n const rootContextId = agentContext.contextCorrelationId\n\n const resolveEventContext = async (\n metadata: EventMetadata | undefined\n ): Promise<{ context: AgentContext; release: () => Promise<void> } | null> => {\n const correlationId = metadata?.contextCorrelationId\n if (!correlationId || correlationId === rootContextId) {\n return { context: agentContext, release: async () => {} }\n }\n\n try {\n const scopedContext = await contextProvider.getAgentContextForContextCorrelationId(correlationId)\n return {\n context: scopedContext,\n release: async () => {\n try {\n await contextProvider.endSessionForAgentContext(scopedContext)\n } catch (error) {\n logger.debug('WorkflowModule - failed to end tenant session after event', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n }\n },\n }\n } catch (error) {\n logger.warn('WorkflowModule - unable to resolve context for event', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n return null\n }\n }\n\n events.on<DidCommCredentialStateChangedEvent>(DidCommCredentialEventTypes.DidCommCredentialStateChanged, async (e) => {\n const rec = e.payload.credentialExchangeRecord\n const connId = rec.connectionId\n logger.info(`[WorkflowModule] Credential state changed: ${rec.state}, connectionId=${connId}, contextCorrelationId=${e.metadata?.contextCorrelationId}`)\n if (!connId) { logger.warn('[WorkflowModule] No connectionId on credential record, skipping auto-advance'); return }\n const scoped = await resolveEventContext(e.metadata)\n if (!scoped) { logger.warn('[WorkflowModule] Failed to resolve event context, skipping auto-advance'); return }\n try {\n // Map both sent and received states so the workflow advances\n // regardless of whether this agent is the issuer or holder\n if (rec.state === DidCommCredentialState.ProposalReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'proposal_received')\n } else if (rec.state === DidCommCredentialState.ProposalSent) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'proposal_sent')\n } else if (rec.state === DidCommCredentialState.OfferReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'offer_received')\n } else if (rec.state === DidCommCredentialState.OfferSent) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'offer_sent')\n } else if (rec.state === DidCommCredentialState.RequestReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'request_received')\n } else if (rec.state === DidCommCredentialState.RequestSent) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'request_sent')\n } else if (rec.state === DidCommCredentialState.CredentialIssued) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'credential_issued')\n } else if (rec.state === DidCommCredentialState.CredentialReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'credential_received')\n } else if (rec.state === DidCommCredentialState.Done) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'issued_ack')\n }\n } finally {\n await scoped.release()\n }\n })\n events.on<DidCommProofStateChangedEvent>(DidCommProofEventTypes.ProofStateChanged, async (e) => {\n const rec = e.payload.proofRecord\n const connId = rec.connectionId\n if (!connId) return\n const scoped = await resolveEventContext(e.metadata)\n if (!scoped) return\n try {\n if (rec.state === DidCommProofState.PresentationReceived) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'presentation_received')\n } else if (rec.state === DidCommProofState.Done) {\n await service.autoAdvanceByConnection(scoped.context, connId, 'verified_ack')\n }\n } finally {\n await scoped.release()\n }\n })\n\n // Optional: register payments v1 actions when payments module is available\n try {\n let createPaymentsV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments'))\n } catch {\n /* optional dependency */\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@credo-ts/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n // Try @ajna-inc/payments (static require for React Native compatibility)\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@ajna-inc/payments'))\n } catch {\n /* optional dependency */\n }\n }\n if (!createPaymentsV1Actions) {\n try {\n ;({ createPaymentsV1Actions } = require('@ajna-inc/payments/workflow/PaymentsV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (createPaymentsV1Actions) {\n const actions = createPaymentsV1Actions()\n try {\n // Prefer explicit API if available\n const svcAny = service as unknown as {\n registerActions?: (actions: unknown[]) => void\n actions?: { register: (h: unknown) => void }\n }\n if (typeof svcAny.registerActions === 'function') {\n svcAny.registerActions(actions)\n } else if (svcAny.actions && typeof svcAny.actions.register === 'function') {\n for (const a of actions) svcAny.actions.register(a)\n } else {\n throw new Error('no action registry available')\n }\n logger.info('WorkflowModule - registered PaymentsV1 actions')\n } catch (_e) {\n // swallow\n }\n }\n } catch {\n /* optional dependency */\n }\n\n // Optional: map payments events → workflow events (guarded if payments not installed)\n if (this.config.enablePaymentsEventMapping)\n try {\n type PaymentEvtKeys =\n | 'IntroResponded'\n | 'HandshakeAccepted'\n | 'ComplianceRequired'\n | 'ComplianceSatisfied'\n | 'ComplianceRejected'\n | 'SettlementUpdated'\n let PaymentsEventTypes: Partial<Record<PaymentEvtKeys, string>> | undefined\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments'))\n } catch {\n /* optional dependency */\n }\n if (!PaymentsEventTypes) {\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments/events/PaymentEvents'))\n } catch {\n /* optional dependency */\n }\n }\n if (!PaymentsEventTypes) {\n try {\n ;({ PaymentsEventTypes } = require('@credo-ts/payments/events/PaymentEvents'))\n } catch {\n /* optional dependency */\n }\n }\n if (!PaymentsEventTypes) throw new Error('payments not available')\n\n const adv = async (threadId: string, event: string, metadata?: EventMetadata) => {\n const scoped = await resolveEventContext(metadata)\n if (!scoped) return\n try {\n await service.advance(scoped.context, {\n instance_id: threadId,\n event,\n idempotency_key: `auto:payments:${event}:${threadId}`,\n })\n } catch (e) {\n logger.debug(`[Workflow] payments event advance error: ${(e as Error).message}`)\n } finally {\n await scoped.release()\n }\n }\n type PaymentListener = (e: {\n payload?: { threadId?: string; status?: string }\n metadata?: EventMetadata\n }) => void\n const on = (evt: string, cb: PaymentListener) =>\n (events as unknown as { on?: (evt: string, cb: PaymentListener) => void }).on?.(evt, cb)\n if (PaymentsEventTypes.IntroResponded)\n on(PaymentsEventTypes.IntroResponded, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.methods_received', e?.metadata)\n })\n if (PaymentsEventTypes.HandshakeAccepted)\n on(PaymentsEventTypes.HandshakeAccepted, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.handshake_accepted', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceRequired)\n on(PaymentsEventTypes.ComplianceRequired, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_required', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceSatisfied)\n on(PaymentsEventTypes.ComplianceSatisfied, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_satisfied', e?.metadata)\n })\n if (PaymentsEventTypes.ComplianceRejected)\n on(PaymentsEventTypes.ComplianceRejected, async (e) => {\n const th = e?.payload?.threadId\n if (th) await adv(th, 'payments.compliance_rejected', e?.metadata)\n })\n if (PaymentsEventTypes.SettlementUpdated)\n on(PaymentsEventTypes.SettlementUpdated, async (e) => {\n const p = e?.payload\n const th = p?.threadId\n const status = p?.status\n if (!status) return\n const map: Record<string, string> = {\n received: 'payments.receipt_received',\n pending: 'payments.settlement_pending',\n settled: 'payments.settled',\n failed: 'payments.failed',\n }\n const ev = map[status]\n if (ev && th) await adv(th, ev, e?.metadata)\n })\n logger.info('WorkflowModule - registered Payments event listeners')\n } catch {\n /* optional dependency */\n }\n\n // Optional: register POE v1 actions when POE module is available\n try {\n let createPoeV1Actions:\n | undefined\n | (() => Array<{ typeUri: string; execute: (...args: unknown[]) => Promise<unknown> }>)\n try {\n ;({ createPoeV1Actions } = require('@ajna-inc/poe'))\n } catch {\n /* optional dependency */\n }\n if (!createPoeV1Actions) {\n try {\n ;({ createPoeV1Actions } = require('@ajna-inc/poe/workflow/PoeV1Actions'))\n } catch {\n /* optional dependency */\n }\n }\n if (createPoeV1Actions) {\n const actions = createPoeV1Actions()\n try {\n const svcAny = service as unknown as {\n registerActions?: (actions: unknown[]) => void\n actions?: { register: (h: unknown) => void }\n }\n if (typeof svcAny.registerActions === 'function') {\n svcAny.registerActions(actions)\n } else if (svcAny.actions && typeof svcAny.actions.register === 'function') {\n for (const a of actions) svcAny.actions.register(a)\n } else {\n throw new Error('no action registry available')\n }\n logger.info('WorkflowModule - registered PoeV1 actions')\n } catch (_e) {\n // swallow\n }\n }\n } catch {\n /* optional dependency */\n }\n\n // Optional: map POE events → workflow events (guarded if POE not installed)\n if (this.config.enablePoeEventMapping)\n try {\n type PoeEvtKeys = 'PoeStateChanged'\n let PoeEventTypes: Partial<Record<PoeEvtKeys, string>> | undefined\n let PoeState: { [key: string]: string } | undefined\n try {\n ;({ PoeEventTypes, PoeState } = require('@ajna-inc/poe'))\n } catch {\n /* optional dependency */\n }\n if (!PoeEventTypes || !PoeState) throw new Error('poe not available')\n\n type PoeListener = (e: {\n payload?: {\n poeRecord?: {\n id?: string\n connectionId?: string\n sessionId?: string\n state?: string\n programId?: string\n verificationResult?: { verified?: boolean; errors?: string[] }\n finalProof?: { result?: unknown }\n }\n previousState?: string\n }\n metadata?: EventMetadata\n }) => void\n const on = (evt: string, cb: PoeListener) =>\n (events as unknown as { on?: (evt: string, cb: PoeListener) => void }).on?.(evt, cb)\n\n if (PoeEventTypes.PoeStateChanged)\n on(PoeEventTypes.PoeStateChanged, async (e) => {\n const poeRecord = e?.payload?.poeRecord\n const connectionId = poeRecord?.connectionId\n if (!connectionId) return\n\n const scoped = await resolveEventContext(e?.metadata)\n if (!scoped) return\n try {\n let workflowEvent: string | undefined\n\n switch (poeRecord.state) {\n case PoeState?.RequestReceived:\n workflowEvent = 'poe.request_received'\n break\n case PoeState?.SubmitReceived:\n workflowEvent = poeRecord.verificationResult?.verified\n ? 'poe.verified'\n : 'poe.verification_failed'\n break\n case PoeState?.ProposalReceived:\n workflowEvent = 'poe.proposal_received'\n break\n case PoeState?.Accepted:\n workflowEvent = 'poe.accepted'\n break\n case PoeState?.Declined:\n workflowEvent = 'poe.declined'\n break\n case PoeState?.Complete:\n workflowEvent = 'poe.completed'\n break\n case PoeState?.Problem:\n workflowEvent = 'poe.problem'\n break\n case PoeState?.ChallengeReceived:\n workflowEvent = 'poe.challenge_received'\n break\n }\n\n if (workflowEvent) {\n await service.autoAdvanceByConnection(\n scoped.context,\n connectionId,\n workflowEvent\n )\n }\n } catch (err) {\n logger.debug(`[Workflow] POE event advance error: ${(err as Error).message}`)\n } finally {\n await scoped.release()\n }\n })\n logger.info('WorkflowModule - registered POE event listeners')\n } catch {\n /* optional dependency */\n }\n\n // Initialize persistent command queue (always enabled, no Redis needed)\n logger.info('WorkflowModule - initializing persistent command queue')\n const commandRepo = dm.resolve(WorkflowCommandRepository)\n const queue = new PersistentCommandQueue(commandRepo, contextProvider, agentContext, {\n pollIntervalMs: this.config.asyncQueue?.pollIntervalMs,\n concurrency: this.config.asyncQueue?.concurrency,\n processingTimeoutMs: this.config.asyncQueue?.processingTimeoutMs,\n staleCheckIntervalMs: this.config.asyncQueue?.staleCheckIntervalMs,\n cleanupIntervalMs: this.config.asyncQueue?.cleanupIntervalMs,\n commandRetentionMs: this.config.asyncQueue?.commandRetentionMs,\n failedRetentionMs: this.config.asyncQueue?.failedRetentionMs,\n maxAttempts: this.config.asyncQueue?.maxAttempts,\n })\n\n // Test-time helper: register queue instance globally for best-effort shutdown in afterAll\n try {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const g: any = globalThis as unknown\n g.__WF_QUEUES = g.__WF_QUEUES || new Set()\n g.__WF_QUEUES.add(queue)\n } catch {\n /* noop */\n }\n\n // In tests or minimal environments, dependencyManager may not expose registerInstance\n try {\n const anyDm = dm as unknown as { registerInstance?: (ctor: unknown, instance: unknown) => void }\n anyDm.registerInstance?.(CommandQueueService, queue)\n } catch {\n // no-op if DI container doesn't support instance registration in this context\n }\n\n // Start worker: processes commands and sends follow-up status messages\n await queue.startWorker(async (job) => {\n // Context resolution handled inside PersistentCommandQueue\n // Worker receives job with already-resolved context\n\n // This worker callback is called from PersistentCommandQueue.processCommand\n // which already resolves the context, so we need to get it here\n const metadata: EventMetadata = { contextCorrelationId: job.contextCorrelationId }\n const scoped = await (async () => {\n const correlationId = metadata.contextCorrelationId\n if (!correlationId || correlationId === rootContextId) {\n return { context: agentContext, release: async () => {} }\n }\n try {\n const scopedContext = await contextProvider.getAgentContextForContextCorrelationId(correlationId)\n return {\n context: scopedContext,\n release: async () => {\n try {\n await contextProvider.endSessionForAgentContext(scopedContext)\n } catch (error) {\n logger.debug('WorkflowModule - failed to end tenant session after queue job', {\n contextCorrelationId: correlationId,\n error: (error as Error).message,\n })\n }\n },\n }\n } catch (error) {\n logger.debug('WorkflowModule - unable to resolve context for queue job', {\n error: (error as Error).message,\n })\n return null\n }\n })()\n if (!scoped) return\n try {\n const ctx = scoped.context\n try {\n logger.info('[WorkflowWorker] handling job', {\n cmd: (job as { cmd?: string }).cmd,\n thid: (job as { thid?: string }).thid,\n connectionId: (job as { connectionId?: string }).connectionId,\n contextCorrelationId: (job as { contextCorrelationId?: string }).contextCorrelationId,\n })\n } catch {}\n switch (job.cmd) {\n case 'start': {\n // Ensure template exists before starting. If missing, attempt auto-discover and defer.\n try {\n const templateRepo = dm.resolve(WorkflowTemplateRepository)\n const p = (job.payload || {}) as unknown as {\n template_id?: string\n template_version?: string\n template_hash?: string\n allow_discover?: boolean\n }\n const templateRec = p.template_id\n ? await templateRepo.findByTemplateIdAndVersion(ctx, p.template_id, p.template_version)\n : null\n if (!templateRec) {\n const allowDiscover = p.allow_discover ?? true\n if (allowDiscover && this.config.enableAutoDiscoverOnStart && job.connectionId) {\n try {\n const sender = dm.resolve(DidCommMessageSender)\n const connectionSvc = dm.resolve(DidCommConnectionService)\n const connection = await connectionSvc.getById(ctx, job.connectionId)\n const { FetchTemplateMessage } = require('./protocol/messages/FetchTemplateMessage')\n const fetch = new FetchTemplateMessage({\n thid: job.thid,\n body: {\n template_id: p.template_id,\n template_version: p.template_version,\n prefer_hash: p.template_hash,\n },\n })\n try {\n fetch.setReturnRouting(ReturnRouteTypes.thread, job.thid)\n } catch {}\n const outbound = new DidCommOutboundMessageContext(fetch, { agentContext: ctx, connection })\n await sender.sendMessage(outbound)\n try {\n logger.info('[WorkflowWorker] fetch-template sent from worker', {\n thid: job.thid,\n template_id: p.template_id,\n template_version: p.template_version,\n })\n } catch {}\n } catch (e) {\n logger.debug('WorkflowModule - fetch-template send failed in worker', {\n error: (e as Error).message,\n })\n }\n }\n // Defer start by signaling invalid_template so queue will retry later\n const err = new Error('template not found for start') as Error & { code?: string }\n err.code = 'invalid_template'\n throw err\n }\n } catch (precheckErr) {\n // Rethrow to queue-level handler for unified deferral behavior\n throw precheckErr\n }\n await service.start(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] start completed', { thid: job.thid }) } catch {}\n break\n }\n case 'advance':\n await service.advance(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] advance completed', { thid: job.thid }) } catch {}\n break\n case 'pause':\n await service.pause(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] pause completed', { thid: job.thid }) } catch {}\n break\n case 'resume':\n await service.resume(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] resume completed', { thid: job.thid }) } catch {}\n break\n case 'cancel':\n await service.cancel(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] cancel completed', { thid: job.thid }) } catch {}\n break\n case 'complete':\n await service.complete(ctx, job.payload as never)\n try { logger.info('[WorkflowWorker] complete completed', { thid: job.thid }) } catch {}\n break\n }\n\n // Note: Per Workflow 1.0 spec §11.6 and §3.4, status is provided on-demand (pull-based).\n // The spec defines status as a request/response pattern where Coordinators explicitly\n // request status via StatusRequestMessage, and Processors respond with StatusMessage.\n //\n // Unsolicited push notifications are not part of the base protocol and cause issues:\n // - Tenant context mismatches in multi-tenant deployments\n // - Receivers interpret unsolicited StatusMessage as a request (same @type)\n // - HTTP transport timeouts (fire-and-forget over request/response transport)\n //\n // For real-time UI updates, use the existing WebSocket event system which emits\n // WorkflowInstanceStateChanged events to connected clients.\n } finally {\n await scoped.release()\n }\n })\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm1 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/AdvanceMessage.d.ts
|
|
5
5
|
declare class AdvanceMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm1.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
instance_id: string;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm6 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/CompleteMessage.d.ts
|
|
5
5
|
declare class CompleteMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm6.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
instance_id: string;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm7 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/DiscoverMessage.d.ts
|
|
5
5
|
declare class DiscoverMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm7.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
filters?: {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm10 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/PauseMessage.d.ts
|
|
5
5
|
declare class PauseMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm10.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
instance_id: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PauseMessage.d.mts","names":[],"sources":["../../../src/protocol/messages/PauseMessage.ts"],"sourcesContent":[],"mappings":";;;;cAEa,YAAA,SAAqB,cAAA;wBAAR,
|
|
1
|
+
{"version":3,"file":"PauseMessage.d.mts","names":[],"sources":["../../../src/protocol/messages/PauseMessage.ts"],"sourcesContent":[],"mappings":";;;;cAEa,YAAA,SAAqB,cAAA;wBAAR,mBAAA,CACG;;EADhB,IAAA,EAAA;IAAa,WAAA,EACG,MAAA;IAOuB,MAAA,CAAA,EAAA,MAAA;EARlB,CAAA;EAAc,WAAA,CAAA,QAAA,EAAA;;UAQI"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm9 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/ResumeMessage.d.ts
|
|
5
5
|
declare class ResumeMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm9.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
instance_id: string;
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Participants } from "../../model/types.mjs";
|
|
2
|
-
import * as
|
|
2
|
+
import * as _credo_ts_didcomm0 from "@credo-ts/didcomm";
|
|
3
3
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
4
4
|
|
|
5
5
|
//#region src/protocol/messages/StartMessage.d.ts
|
|
6
6
|
declare class StartMessage extends DidCommMessage {
|
|
7
|
-
static readonly type:
|
|
7
|
+
static readonly type: _credo_ts_didcomm0.ParsedMessageType;
|
|
8
8
|
type: string;
|
|
9
9
|
body: {
|
|
10
10
|
template_id: string;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as _credo_ts_didcomm8 from "@credo-ts/didcomm";
|
|
2
2
|
import { DidCommMessage } from "@credo-ts/didcomm";
|
|
3
3
|
|
|
4
4
|
//#region src/protocol/messages/WorkflowsMessage.d.ts
|
|
5
5
|
declare class WorkflowsMessage extends DidCommMessage {
|
|
6
|
-
static readonly type:
|
|
6
|
+
static readonly type: _credo_ts_didcomm8.ParsedMessageType;
|
|
7
7
|
type: string;
|
|
8
8
|
body: {
|
|
9
9
|
workflows: Array<{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WorkflowsMessage.d.mts","names":[],"sources":["../../../src/protocol/messages/WorkflowsMessage.ts"],"sourcesContent":[],"mappings":";;;;cAEa,gBAAA,SAAyB,cAAA;wBAAR,
|
|
1
|
+
{"version":3,"file":"WorkflowsMessage.d.mts","names":[],"sources":["../../../src/protocol/messages/WorkflowsMessage.ts"],"sourcesContent":[],"mappings":";;;;cAEa,gBAAA,SAAyB,cAAA;wBAAR,kBAAA,CACD;;EADhB,IAAA,EAAA;IAAiB,SAAA,EAOf,KANc,CAAA;MAMd,WAAA,EAAA,MAAA;MAIqC,QAAA,EAAA,MAAA,EAAA;MAXd,KAAA,CAAA,EAAA,MAAA;MAAc,IAAA,CAAA,EAAA,MAAA;;;;;;;;;UAWA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ajna-inc/workflow",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.6",
|
|
4
4
|
"files": [
|
|
5
5
|
"build",
|
|
6
6
|
".npmvc"
|
|
@@ -26,8 +26,8 @@
|
|
|
26
26
|
"jmespath": "^0.16.0",
|
|
27
27
|
"rxjs": "^7.8.2",
|
|
28
28
|
"semver": "^7.6.3",
|
|
29
|
-
"@credo-ts/
|
|
30
|
-
"@credo-ts/
|
|
29
|
+
"@credo-ts/didcomm": "0.6.1",
|
|
30
|
+
"@credo-ts/core": "0.6.1"
|
|
31
31
|
},
|
|
32
32
|
"devDependencies": {
|
|
33
33
|
"@types/jmespath": "^0.15.2",
|