@contractspec/example.openbanking-powens 1.57.0 → 1.58.0

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.
Files changed (35) hide show
  1. package/.turbo/turbo-build.log +23 -43
  2. package/.turbo/turbo-prebuild.log +1 -0
  3. package/CHANGELOG.md +13 -0
  4. package/dist/docs/index.d.ts +2 -1
  5. package/dist/docs/index.d.ts.map +1 -0
  6. package/dist/docs/index.js +39 -1
  7. package/dist/docs/openbanking-powens.docblock.d.ts +2 -1
  8. package/dist/docs/openbanking-powens.docblock.d.ts.map +1 -0
  9. package/dist/docs/openbanking-powens.docblock.js +36 -27
  10. package/dist/example.d.ts +2 -6
  11. package/dist/example.d.ts.map +1 -1
  12. package/dist/example.js +32 -44
  13. package/dist/handlers/oauth-callback.d.ts +1 -4
  14. package/dist/handlers/oauth-callback.d.ts.map +1 -1
  15. package/dist/handlers/oauth-callback.js +56 -55
  16. package/dist/handlers/webhook-handler.d.ts +1 -4
  17. package/dist/handlers/webhook-handler.d.ts.map +1 -1
  18. package/dist/handlers/webhook-handler.js +83 -75
  19. package/dist/index.d.ts +5 -4
  20. package/dist/index.d.ts.map +1 -0
  21. package/dist/index.js +228 -5
  22. package/dist/node/docs/index.js +38 -0
  23. package/dist/node/docs/openbanking-powens.docblock.js +38 -0
  24. package/dist/node/example.js +33 -0
  25. package/dist/node/handlers/oauth-callback.js +64 -0
  26. package/dist/node/handlers/webhook-handler.js +95 -0
  27. package/dist/node/index.js +228 -0
  28. package/package.json +62 -26
  29. package/tsdown.config.js +1 -2
  30. package/.turbo/turbo-build$colon$bundle.log +0 -44
  31. package/dist/docs/openbanking-powens.docblock.js.map +0 -1
  32. package/dist/example.js.map +0 -1
  33. package/dist/handlers/oauth-callback.js.map +0 -1
  34. package/dist/handlers/webhook-handler.js.map +0 -1
  35. package/tsconfig.tsbuildinfo +0 -1
package/dist/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- import example from "./example.js";
2
- import { powensOAuthCallbackHandler } from "./handlers/oauth-callback.js";
3
- import { powensWebhookHandler } from "./handlers/webhook-handler.js";
4
- export { example, powensOAuthCallbackHandler, powensWebhookHandler };
1
+ export * from './handlers/oauth-callback';
2
+ export * from './handlers/webhook-handler';
3
+ export { default as example } from './example';
4
+ import './docs';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,QAAQ,CAAC"}
package/dist/index.js CHANGED
@@ -1,6 +1,229 @@
1
- import example from "./example.js";
2
- import { powensOAuthCallbackHandler } from "./handlers/oauth-callback.js";
3
- import { powensWebhookHandler } from "./handlers/webhook-handler.js";
4
- import "./docs/index.js";
1
+ // @bun
2
+ // src/docs/openbanking-powens.docblock.ts
3
+ import { registerDocBlocks } from "@contractspec/lib.contracts/docs";
4
+ var blocks = [
5
+ {
6
+ id: "docs.examples.openbanking-powens",
7
+ title: "Open Banking \u2014 Powens (example)",
8
+ summary: "Framework-neutral OAuth callback + webhook handler patterns for Powens, orchestrating canonical sync workflows.",
9
+ kind: "reference",
10
+ visibility: "public",
11
+ route: "/docs/examples/openbanking-powens",
12
+ tags: ["openbanking", "powens", "integration", "example"],
13
+ body: `## What this example shows
14
+ - OAuth callback handler: exchange auth code, map powens user, enqueue sync workflow.
15
+ - Webhook handler: verify signature, route event \u2192 workflow, optionally refresh balances.
5
16
 
6
- export { example, powensOAuthCallbackHandler, powensWebhookHandler };
17
+ ## Guardrails
18
+ - Secrets via secret providers/env only.
19
+ - Verify webhook signatures.
20
+ - Keep side effects explicit: enqueue workflows instead of mutating canonical stores inline.`
21
+ },
22
+ {
23
+ id: "docs.examples.openbanking-powens.usage",
24
+ title: "Open Banking \u2014 Powens \u2014 Usage",
25
+ summary: "How to integrate the handlers in a fetch-compatible runtime.",
26
+ kind: "usage",
27
+ visibility: "public",
28
+ route: "/docs/examples/openbanking-powens/usage",
29
+ tags: ["openbanking", "usage"],
30
+ body: `## Usage
31
+ - Wire \`powensOAuthCallbackHandler(req)\` at your OAuth redirect route.
32
+ - Wire \`powensWebhookHandler(req)\` at your webhook route.
33
+
34
+ ## Notes
35
+ - Replace the fake stores with your app-layer persistence.
36
+ - Enqueue ContractSpec workflows for canonical upserts and telemetry.`
37
+ }
38
+ ];
39
+ registerDocBlocks(blocks);
40
+ // src/example.ts
41
+ import { defineExample } from "@contractspec/lib.contracts";
42
+ var example = defineExample({
43
+ meta: {
44
+ key: "openbanking-powens",
45
+ version: "1.0.0",
46
+ title: "Open Banking \u2014 Powens",
47
+ description: "OAuth callback + webhook handler patterns for Powens open banking integration (provider + workflow orchestration).",
48
+ kind: "integration",
49
+ visibility: "public",
50
+ stability: "experimental",
51
+ owners: ["@platform.core"],
52
+ tags: ["openbanking", "powens", "oauth", "webhooks", "integrations"]
53
+ },
54
+ docs: {
55
+ rootDocId: "docs.examples.openbanking-powens",
56
+ usageDocId: "docs.examples.openbanking-powens.usage"
57
+ },
58
+ entrypoints: {
59
+ packageName: "@contractspec/example.openbanking-powens",
60
+ docs: "./docs"
61
+ },
62
+ surfaces: {
63
+ templates: true,
64
+ sandbox: { enabled: true, modes: ["markdown", "specs"] },
65
+ studio: { enabled: true, installable: true },
66
+ mcp: { enabled: true }
67
+ }
68
+ });
69
+ var example_default = example;
70
+
71
+ // src/handlers/oauth-callback.ts
72
+ import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
73
+ async function powensOAuthCallbackHandler(req) {
74
+ const url = new URL(req.url);
75
+ const code = url.searchParams.get("code");
76
+ const state = url.searchParams.get("state");
77
+ const userUuid = url.searchParams.get("user_uuid");
78
+ if (!code || !state || !userUuid) {
79
+ return new Response("Missing Powens OAuth params", { status: 400 });
80
+ }
81
+ const connection = await getConnectionByState(state);
82
+ if (!connection) {
83
+ return new Response("Unknown Powens OAuth state", { status: 404 });
84
+ }
85
+ const secrets = await getPowensSecretsForConnection(connection.meta.id);
86
+ const provider = new PowensOpenBankingProvider({
87
+ clientId: secrets.clientId,
88
+ clientSecret: secrets.clientSecret,
89
+ apiKey: secrets.apiKey,
90
+ environment: connection.config.environment,
91
+ baseUrl: connection.config.baseUrl
92
+ });
93
+ const preview = await provider.listAccounts({
94
+ tenantId: connection.meta.tenantId,
95
+ connectionId: connection.meta.id,
96
+ userId: userUuid
97
+ });
98
+ await connection.storePowensUser({
99
+ tenantUserId: connection.meta.tenantUserId,
100
+ powensUserUuid: userUuid,
101
+ authCode: code
102
+ });
103
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
104
+ tenantId: connection.meta.tenantId,
105
+ userUuid,
106
+ connectionId: connection.meta.id,
107
+ previewAccounts: preview.accounts
108
+ });
109
+ const redirectBase = process.env.APP_DASHBOARD_URL ?? "";
110
+ return Response.redirect(`${redirectBase}/banking/linked?tenant=${connection.meta.tenantId}`, 302);
111
+ }
112
+ async function getConnectionByState(state) {
113
+ const record = fakeDatabase.connections.find((conn) => conn.state === state);
114
+ return record ?? null;
115
+ }
116
+ async function getPowensSecretsForConnection(connectionId) {
117
+ const secret = fakeSecretStore[connectionId];
118
+ if (!secret)
119
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
120
+ return secret;
121
+ }
122
+ async function enqueueWorkflow(name, input) {
123
+ await fakeWorkflowQueue.enqueue({ name, input });
124
+ }
125
+ var fakeDatabase = {
126
+ connections: []
127
+ };
128
+ var fakeSecretStore = {};
129
+ var fakeWorkflowQueue = {
130
+ enqueue: async (_payload) => {}
131
+ };
132
+
133
+ // src/handlers/webhook-handler.ts
134
+ import { createHmac, timingSafeEqual } from "crypto";
135
+ import { PowensOpenBankingProvider as PowensOpenBankingProvider2 } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
136
+ async function powensWebhookHandler(req) {
137
+ const signature = req.headers.get("x-powens-signature");
138
+ const stateHeader = req.headers.get("x-powens-state");
139
+ const payload = await req.text();
140
+ if (!signature || !stateHeader) {
141
+ return new Response("Missing Powens signature headers", { status: 400 });
142
+ }
143
+ const connection = await getConnectionByState2(stateHeader);
144
+ if (!connection) {
145
+ return new Response("Unknown Powens state header", { status: 404 });
146
+ }
147
+ const secrets = await getPowensSecretsForConnection2(connection.meta.id);
148
+ if (!verifySignature(payload, signature, secrets.webhookSecret)) {
149
+ return new Response("Invalid Powens webhook signature", { status: 401 });
150
+ }
151
+ const event = JSON.parse(payload);
152
+ const provider = new PowensOpenBankingProvider2({
153
+ clientId: secrets.clientId,
154
+ clientSecret: secrets.clientSecret,
155
+ apiKey: secrets.apiKey,
156
+ environment: connection.config.environment,
157
+ baseUrl: connection.config.baseUrl
158
+ });
159
+ switch (event.type) {
160
+ case "connection.updated":
161
+ case "user.sync.completed": {
162
+ await enqueueWorkflow2("pfo.workflow.sync-openbanking-accounts", {
163
+ tenantId: connection.meta.tenantId,
164
+ connectionId: connection.meta.id,
165
+ userUuid: event.user_uuid
166
+ });
167
+ break;
168
+ }
169
+ case "transactions.created":
170
+ case "transactions.updated": {
171
+ await enqueueWorkflow2("pfo.workflow.sync-openbanking-transactions", {
172
+ tenantId: connection.meta.tenantId,
173
+ connectionId: connection.meta.id,
174
+ userUuid: event.user_uuid,
175
+ accountId: event.account_uuid
176
+ });
177
+ break;
178
+ }
179
+ default:
180
+ await logUnmappedEvent(event);
181
+ }
182
+ if (event.account_uuid) {
183
+ await provider.getBalances({
184
+ tenantId: connection.meta.tenantId,
185
+ connectionId: connection.meta.id,
186
+ accountId: event.account_uuid
187
+ });
188
+ }
189
+ return new Response("OK", { status: 200 });
190
+ }
191
+ function verifySignature(payload, signature, secret) {
192
+ const digest = createHmac("sha256", secret).update(payload).digest("hex");
193
+ const a = Buffer.from(digest, "hex");
194
+ const b = Buffer.from(signature, "hex");
195
+ return a.length === b.length && timingSafeEqual(a, b);
196
+ }
197
+ async function getConnectionByState2(state) {
198
+ return fakeDatabase2.connections.find((conn) => conn.state === state) ?? null;
199
+ }
200
+ async function getPowensSecretsForConnection2(connectionId) {
201
+ const secret = fakeSecretStore2[connectionId];
202
+ if (!secret)
203
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
204
+ return secret;
205
+ }
206
+ async function enqueueWorkflow2(name, input) {
207
+ await fakeWorkflowQueue2.enqueue({ name, input });
208
+ }
209
+ async function logUnmappedEvent(_event) {
210
+ await fakeTelemetryLogger.record({
211
+ event: "openbanking.webhook.unmapped",
212
+ payload: "redacted"
213
+ });
214
+ }
215
+ var fakeDatabase2 = {
216
+ connections: []
217
+ };
218
+ var fakeSecretStore2 = {};
219
+ var fakeWorkflowQueue2 = {
220
+ enqueue: async (_payload) => {}
221
+ };
222
+ var fakeTelemetryLogger = {
223
+ record: async (_payload) => {}
224
+ };
225
+ export {
226
+ powensWebhookHandler,
227
+ powensOAuthCallbackHandler,
228
+ example_default as example
229
+ };
@@ -0,0 +1,38 @@
1
+ // src/docs/openbanking-powens.docblock.ts
2
+ import { registerDocBlocks } from "@contractspec/lib.contracts/docs";
3
+ var blocks = [
4
+ {
5
+ id: "docs.examples.openbanking-powens",
6
+ title: "Open Banking — Powens (example)",
7
+ summary: "Framework-neutral OAuth callback + webhook handler patterns for Powens, orchestrating canonical sync workflows.",
8
+ kind: "reference",
9
+ visibility: "public",
10
+ route: "/docs/examples/openbanking-powens",
11
+ tags: ["openbanking", "powens", "integration", "example"],
12
+ body: `## What this example shows
13
+ - OAuth callback handler: exchange auth code, map powens user, enqueue sync workflow.
14
+ - Webhook handler: verify signature, route event → workflow, optionally refresh balances.
15
+
16
+ ## Guardrails
17
+ - Secrets via secret providers/env only.
18
+ - Verify webhook signatures.
19
+ - Keep side effects explicit: enqueue workflows instead of mutating canonical stores inline.`
20
+ },
21
+ {
22
+ id: "docs.examples.openbanking-powens.usage",
23
+ title: "Open Banking — Powens — Usage",
24
+ summary: "How to integrate the handlers in a fetch-compatible runtime.",
25
+ kind: "usage",
26
+ visibility: "public",
27
+ route: "/docs/examples/openbanking-powens/usage",
28
+ tags: ["openbanking", "usage"],
29
+ body: `## Usage
30
+ - Wire \`powensOAuthCallbackHandler(req)\` at your OAuth redirect route.
31
+ - Wire \`powensWebhookHandler(req)\` at your webhook route.
32
+
33
+ ## Notes
34
+ - Replace the fake stores with your app-layer persistence.
35
+ - Enqueue ContractSpec workflows for canonical upserts and telemetry.`
36
+ }
37
+ ];
38
+ registerDocBlocks(blocks);
@@ -0,0 +1,38 @@
1
+ // src/docs/openbanking-powens.docblock.ts
2
+ import { registerDocBlocks } from "@contractspec/lib.contracts/docs";
3
+ var blocks = [
4
+ {
5
+ id: "docs.examples.openbanking-powens",
6
+ title: "Open Banking — Powens (example)",
7
+ summary: "Framework-neutral OAuth callback + webhook handler patterns for Powens, orchestrating canonical sync workflows.",
8
+ kind: "reference",
9
+ visibility: "public",
10
+ route: "/docs/examples/openbanking-powens",
11
+ tags: ["openbanking", "powens", "integration", "example"],
12
+ body: `## What this example shows
13
+ - OAuth callback handler: exchange auth code, map powens user, enqueue sync workflow.
14
+ - Webhook handler: verify signature, route event → workflow, optionally refresh balances.
15
+
16
+ ## Guardrails
17
+ - Secrets via secret providers/env only.
18
+ - Verify webhook signatures.
19
+ - Keep side effects explicit: enqueue workflows instead of mutating canonical stores inline.`
20
+ },
21
+ {
22
+ id: "docs.examples.openbanking-powens.usage",
23
+ title: "Open Banking — Powens — Usage",
24
+ summary: "How to integrate the handlers in a fetch-compatible runtime.",
25
+ kind: "usage",
26
+ visibility: "public",
27
+ route: "/docs/examples/openbanking-powens/usage",
28
+ tags: ["openbanking", "usage"],
29
+ body: `## Usage
30
+ - Wire \`powensOAuthCallbackHandler(req)\` at your OAuth redirect route.
31
+ - Wire \`powensWebhookHandler(req)\` at your webhook route.
32
+
33
+ ## Notes
34
+ - Replace the fake stores with your app-layer persistence.
35
+ - Enqueue ContractSpec workflows for canonical upserts and telemetry.`
36
+ }
37
+ ];
38
+ registerDocBlocks(blocks);
@@ -0,0 +1,33 @@
1
+ // src/example.ts
2
+ import { defineExample } from "@contractspec/lib.contracts";
3
+ var example = defineExample({
4
+ meta: {
5
+ key: "openbanking-powens",
6
+ version: "1.0.0",
7
+ title: "Open Banking — Powens",
8
+ description: "OAuth callback + webhook handler patterns for Powens open banking integration (provider + workflow orchestration).",
9
+ kind: "integration",
10
+ visibility: "public",
11
+ stability: "experimental",
12
+ owners: ["@platform.core"],
13
+ tags: ["openbanking", "powens", "oauth", "webhooks", "integrations"]
14
+ },
15
+ docs: {
16
+ rootDocId: "docs.examples.openbanking-powens",
17
+ usageDocId: "docs.examples.openbanking-powens.usage"
18
+ },
19
+ entrypoints: {
20
+ packageName: "@contractspec/example.openbanking-powens",
21
+ docs: "./docs"
22
+ },
23
+ surfaces: {
24
+ templates: true,
25
+ sandbox: { enabled: true, modes: ["markdown", "specs"] },
26
+ studio: { enabled: true, installable: true },
27
+ mcp: { enabled: true }
28
+ }
29
+ });
30
+ var example_default = example;
31
+ export {
32
+ example_default as default
33
+ };
@@ -0,0 +1,64 @@
1
+ // src/handlers/oauth-callback.ts
2
+ import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
3
+ async function powensOAuthCallbackHandler(req) {
4
+ const url = new URL(req.url);
5
+ const code = url.searchParams.get("code");
6
+ const state = url.searchParams.get("state");
7
+ const userUuid = url.searchParams.get("user_uuid");
8
+ if (!code || !state || !userUuid) {
9
+ return new Response("Missing Powens OAuth params", { status: 400 });
10
+ }
11
+ const connection = await getConnectionByState(state);
12
+ if (!connection) {
13
+ return new Response("Unknown Powens OAuth state", { status: 404 });
14
+ }
15
+ const secrets = await getPowensSecretsForConnection(connection.meta.id);
16
+ const provider = new PowensOpenBankingProvider({
17
+ clientId: secrets.clientId,
18
+ clientSecret: secrets.clientSecret,
19
+ apiKey: secrets.apiKey,
20
+ environment: connection.config.environment,
21
+ baseUrl: connection.config.baseUrl
22
+ });
23
+ const preview = await provider.listAccounts({
24
+ tenantId: connection.meta.tenantId,
25
+ connectionId: connection.meta.id,
26
+ userId: userUuid
27
+ });
28
+ await connection.storePowensUser({
29
+ tenantUserId: connection.meta.tenantUserId,
30
+ powensUserUuid: userUuid,
31
+ authCode: code
32
+ });
33
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
34
+ tenantId: connection.meta.tenantId,
35
+ userUuid,
36
+ connectionId: connection.meta.id,
37
+ previewAccounts: preview.accounts
38
+ });
39
+ const redirectBase = process.env.APP_DASHBOARD_URL ?? "";
40
+ return Response.redirect(`${redirectBase}/banking/linked?tenant=${connection.meta.tenantId}`, 302);
41
+ }
42
+ async function getConnectionByState(state) {
43
+ const record = fakeDatabase.connections.find((conn) => conn.state === state);
44
+ return record ?? null;
45
+ }
46
+ async function getPowensSecretsForConnection(connectionId) {
47
+ const secret = fakeSecretStore[connectionId];
48
+ if (!secret)
49
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
50
+ return secret;
51
+ }
52
+ async function enqueueWorkflow(name, input) {
53
+ await fakeWorkflowQueue.enqueue({ name, input });
54
+ }
55
+ var fakeDatabase = {
56
+ connections: []
57
+ };
58
+ var fakeSecretStore = {};
59
+ var fakeWorkflowQueue = {
60
+ enqueue: async (_payload) => {}
61
+ };
62
+ export {
63
+ powensOAuthCallbackHandler
64
+ };
@@ -0,0 +1,95 @@
1
+ // src/handlers/webhook-handler.ts
2
+ import { createHmac, timingSafeEqual } from "crypto";
3
+ import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
4
+ async function powensWebhookHandler(req) {
5
+ const signature = req.headers.get("x-powens-signature");
6
+ const stateHeader = req.headers.get("x-powens-state");
7
+ const payload = await req.text();
8
+ if (!signature || !stateHeader) {
9
+ return new Response("Missing Powens signature headers", { status: 400 });
10
+ }
11
+ const connection = await getConnectionByState(stateHeader);
12
+ if (!connection) {
13
+ return new Response("Unknown Powens state header", { status: 404 });
14
+ }
15
+ const secrets = await getPowensSecretsForConnection(connection.meta.id);
16
+ if (!verifySignature(payload, signature, secrets.webhookSecret)) {
17
+ return new Response("Invalid Powens webhook signature", { status: 401 });
18
+ }
19
+ const event = JSON.parse(payload);
20
+ const provider = new PowensOpenBankingProvider({
21
+ clientId: secrets.clientId,
22
+ clientSecret: secrets.clientSecret,
23
+ apiKey: secrets.apiKey,
24
+ environment: connection.config.environment,
25
+ baseUrl: connection.config.baseUrl
26
+ });
27
+ switch (event.type) {
28
+ case "connection.updated":
29
+ case "user.sync.completed": {
30
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
31
+ tenantId: connection.meta.tenantId,
32
+ connectionId: connection.meta.id,
33
+ userUuid: event.user_uuid
34
+ });
35
+ break;
36
+ }
37
+ case "transactions.created":
38
+ case "transactions.updated": {
39
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-transactions", {
40
+ tenantId: connection.meta.tenantId,
41
+ connectionId: connection.meta.id,
42
+ userUuid: event.user_uuid,
43
+ accountId: event.account_uuid
44
+ });
45
+ break;
46
+ }
47
+ default:
48
+ await logUnmappedEvent(event);
49
+ }
50
+ if (event.account_uuid) {
51
+ await provider.getBalances({
52
+ tenantId: connection.meta.tenantId,
53
+ connectionId: connection.meta.id,
54
+ accountId: event.account_uuid
55
+ });
56
+ }
57
+ return new Response("OK", { status: 200 });
58
+ }
59
+ function verifySignature(payload, signature, secret) {
60
+ const digest = createHmac("sha256", secret).update(payload).digest("hex");
61
+ const a = Buffer.from(digest, "hex");
62
+ const b = Buffer.from(signature, "hex");
63
+ return a.length === b.length && timingSafeEqual(a, b);
64
+ }
65
+ async function getConnectionByState(state) {
66
+ return fakeDatabase.connections.find((conn) => conn.state === state) ?? null;
67
+ }
68
+ async function getPowensSecretsForConnection(connectionId) {
69
+ const secret = fakeSecretStore[connectionId];
70
+ if (!secret)
71
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
72
+ return secret;
73
+ }
74
+ async function enqueueWorkflow(name, input) {
75
+ await fakeWorkflowQueue.enqueue({ name, input });
76
+ }
77
+ async function logUnmappedEvent(_event) {
78
+ await fakeTelemetryLogger.record({
79
+ event: "openbanking.webhook.unmapped",
80
+ payload: "redacted"
81
+ });
82
+ }
83
+ var fakeDatabase = {
84
+ connections: []
85
+ };
86
+ var fakeSecretStore = {};
87
+ var fakeWorkflowQueue = {
88
+ enqueue: async (_payload) => {}
89
+ };
90
+ var fakeTelemetryLogger = {
91
+ record: async (_payload) => {}
92
+ };
93
+ export {
94
+ powensWebhookHandler
95
+ };