@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
@@ -1,45 +1,25 @@
1
- $ bun build:types && bun build:bundle
2
- $ tsc --noEmit
3
- $ tsdown
4
- ℹ tsdown v0.20.3 powered by rolldown v1.0.0-rc.3
5
- ℹ config file: /home/runner/work/contractspec/contractspec/packages/examples/openbanking-powens/tsdown.config.js
6
- ℹ entry: src/example.ts, src/index.ts, src/docs/index.ts, src/docs/openbanking-powens.docblock.ts, src/handlers/oauth-callback.ts, src/handlers/webhook-handler.ts
7
- ℹ target: esnext
8
- ℹ tsconfig: tsconfig.json
9
- ℹ Build start
10
- ℹ dist/handlers/webhook-handler.js 3.32 kB │ gzip: 1.23 kB
11
- ℹ dist/handlers/oauth-callback.js 2.42 kB │ gzip: 1.02 kB
12
- ℹ dist/docs/openbanking-powens.docblock.js 1.57 kB │ gzip: 0.76 kB
13
- ℹ dist/example.js 1.03 kB │ gzip: 0.54 kB
14
- ℹ dist/index.js 0.28 kB │ gzip: 0.15 kB
15
- ℹ dist/docs/index.js 0.04 kB │ gzip: 0.06 kB
16
- ℹ dist/handlers/webhook-handler.js.map 6.40 kB │ gzip: 2.17 kB
17
- ℹ dist/handlers/oauth-callback.js.map 4.79 kB │ gzip: 1.80 kB
18
- ℹ dist/docs/openbanking-powens.docblock.js.map 2.07 kB │ gzip: 0.94 kB
19
- ℹ dist/example.js.map 1.50 kB │ gzip: 0.74 kB
20
- ℹ dist/handlers/webhook-handler.d.ts.map 0.17 kB │ gzip: 0.15 kB
21
- ℹ dist/handlers/oauth-callback.d.ts.map 0.17 kB │ gzip: 0.15 kB
22
- ℹ dist/example.d.ts.map 0.13 kB │ gzip: 0.13 kB
23
- ℹ dist/example.d.ts 0.25 kB │ gzip: 0.17 kB
24
- ℹ dist/index.d.ts 0.25 kB │ gzip: 0.13 kB
25
- ℹ dist/handlers/oauth-callback.d.ts 0.22 kB │ gzip: 0.17 kB
26
- ℹ dist/handlers/webhook-handler.d.ts 0.21 kB │ gzip: 0.16 kB
27
- ℹ dist/docs/index.d.ts 0.01 kB │ gzip: 0.03 kB
28
- ℹ dist/docs/openbanking-powens.docblock.d.ts 0.01 kB │ gzip: 0.03 kB
29
- ℹ 19 files, total: 24.84 kB
30
- src/handlers/webhook-handler.ts (7:44) [UNRESOLVED_IMPORT] Warning: Could not resolve 'crypto' in src/handlers/webhook-handler.ts
31
- ╭─[ src/handlers/webhook-handler.ts:7:45 ]
32
- │
33
- 7 │ import { createHmac, timingSafeEqual } from 'crypto';
34
-  │ ────┬───
35
-  │ ╰───── Module not found, treating it as an external dependency
36
-  │
37
-  │ Help: The "main" field here was ignored. Main fields must be configured explicitly when using the "neutral" platform.
38
- ───╯
1
+ $ contractspec-bun-build prebuild
2
+ $ bun run prebuild && bun run build:bundle && bun run build:types
3
+ $ contractspec-bun-build prebuild
4
+ $ contractspec-bun-build transpile
5
+ [contractspec-bun-build] transpile target=bun root=src entries=6
6
+ Bundled 6 modules in 11ms
39
7
 
40
- [PLUGIN_TIMINGS] Warning: Your build spent significant time in plugins. Here is a breakdown:
41
- - tsdown:external (62%)
42
- - rolldown-plugin-dts:generate (37%)
43
- See https://rolldown.rs/options/checks#plugintimings for more details.
8
+ docs/index.js 1.57 KB (entry point)
9
+ ./index.js 8.1 KB (entry point)
10
+ docs/openbanking-powens.docblock.js 1.57 KB (entry point)
11
+ ./example.js 1.0 KB (entry point)
12
+ handlers/oauth-callback.js 2.26 KB (entry point)
13
+ handlers/webhook-handler.js 3.22 KB (entry point)
44
14
 
45
- ✔ Build complete in 20958ms
15
+ [contractspec-bun-build] transpile target=node root=src entries=6
16
+ Bundled 6 modules in 7ms
17
+
18
+ docs/index.js 1.55 KB (entry point)
19
+ ./index.js 8.1 KB (entry point)
20
+ docs/openbanking-powens.docblock.js 1.55 KB (entry point)
21
+ ./example.js 1.0 KB (entry point)
22
+ handlers/oauth-callback.js 2.26 KB (entry point)
23
+ handlers/webhook-handler.js 3.21 KB (entry point)
24
+
25
+ $ contractspec-bun-build types
@@ -0,0 +1 @@
1
+ $ contractspec-bun-build prebuild
package/CHANGELOG.md CHANGED
@@ -1,5 +1,18 @@
1
1
  # @contractspec/example.openbanking-powens
2
2
 
3
+ ## 1.58.0
4
+
5
+ ### Minor Changes
6
+
7
+ - d1f0fd0: chore: Migrate non-app package builds from tsdown to shared Bun tooling, add `@contractspec/tool.bun`, and standardize `prebuild`/`build`/`typecheck` with platform-aware exports and `tsc` declaration emission into `dist`.
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [d1f0fd0]
12
+ - Updated dependencies [4355a9e]
13
+ - @contractspec/integration.providers-impls@1.58.0
14
+ - @contractspec/lib.contracts@1.58.0
15
+
3
16
  ## 1.57.0
4
17
 
5
18
  ### Minor Changes
@@ -1 +1,2 @@
1
- export { };
1
+ import './openbanking-powens.docblock';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/docs/index.ts"],"names":[],"mappings":"AAAA,OAAO,+BAA+B,CAAC"}
@@ -1 +1,39 @@
1
- import "./openbanking-powens.docblock.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.
16
+
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);
@@ -1 +1,2 @@
1
- export { };
1
+ export {};
2
+ //# sourceMappingURL=openbanking-powens.docblock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openbanking-powens.docblock.d.ts","sourceRoot":"","sources":["../../src/docs/openbanking-powens.docblock.ts"],"names":[],"mappings":""}
@@ -1,30 +1,39 @@
1
+ // @bun
2
+ // src/docs/openbanking-powens.docblock.ts
1
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.
2
16
 
3
- //#region src/docs/openbanking-powens.docblock.ts
4
- registerDocBlocks([{
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: [
12
- "openbanking",
13
- "powens",
14
- "integration",
15
- "example"
16
- ],
17
- body: `## What this example shows\n- OAuth callback handler: exchange auth code, map powens user, enqueue sync workflow.\n- Webhook handler: verify signature, route event → workflow, optionally refresh balances.\n\n## Guardrails\n- Secrets via secret providers/env only.\n- Verify webhook signatures.\n- Keep side effects explicit: enqueue workflows instead of mutating canonical stores inline.`
18
- }, {
19
- id: "docs.examples.openbanking-powens.usage",
20
- title: "Open Banking — Powens — Usage",
21
- summary: "How to integrate the handlers in a fetch-compatible runtime.",
22
- kind: "usage",
23
- visibility: "public",
24
- route: "/docs/examples/openbanking-powens/usage",
25
- tags: ["openbanking", "usage"],
26
- body: `## Usage\n- Wire \`powensOAuthCallbackHandler(req)\` at your OAuth redirect route.\n- Wire \`powensWebhookHandler(req)\` at your webhook route.\n\n## Notes\n- Replace the fake stores with your app-layer persistence.\n- Enqueue ContractSpec workflows for canonical upserts and telemetry.`
27
- }]);
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.
28
33
 
29
- //#endregion
30
- //# sourceMappingURL=openbanking-powens.docblock.js.map
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);
package/dist/example.d.ts CHANGED
@@ -1,7 +1,3 @@
1
- import * as _contractspec_lib_contracts0 from "@contractspec/lib.contracts";
2
-
3
- //#region src/example.d.ts
4
- declare const example: _contractspec_lib_contracts0.ExampleSpec;
5
- //#endregion
6
- export { example as default };
1
+ declare const example: import("@contractspec/lib.contracts").ExampleSpec;
2
+ export default example;
7
3
  //# sourceMappingURL=example.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"example.d.ts","names":[],"sources":["../src/example.ts"],"mappings":";;;cAEM,OAAA,EA2BJ,4BAAA,CA3BW,WAAA"}
1
+ {"version":3,"file":"example.d.ts","sourceRoot":"","sources":["../src/example.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,OAAO,mDA2BX,CAAC;AAEH,eAAe,OAAO,CAAC"}
package/dist/example.js CHANGED
@@ -1,46 +1,34 @@
1
+ // @bun
2
+ // src/example.ts
1
3
  import { defineExample } from "@contractspec/lib.contracts";
2
-
3
- //#region src/example.ts
4
- const example = defineExample({
5
- meta: {
6
- key: "openbanking-powens",
7
- version: "1.0.0",
8
- title: "Open Banking — Powens",
9
- description: "OAuth callback + webhook handler patterns for Powens open banking integration (provider + workflow orchestration).",
10
- kind: "integration",
11
- visibility: "public",
12
- stability: "experimental",
13
- owners: ["@platform.core"],
14
- tags: [
15
- "openbanking",
16
- "powens",
17
- "oauth",
18
- "webhooks",
19
- "integrations"
20
- ]
21
- },
22
- docs: {
23
- rootDocId: "docs.examples.openbanking-powens",
24
- usageDocId: "docs.examples.openbanking-powens.usage"
25
- },
26
- entrypoints: {
27
- packageName: "@contractspec/example.openbanking-powens",
28
- docs: "./docs"
29
- },
30
- surfaces: {
31
- templates: true,
32
- sandbox: {
33
- enabled: true,
34
- modes: ["markdown", "specs"]
35
- },
36
- studio: {
37
- enabled: true,
38
- installable: true
39
- },
40
- mcp: { enabled: true }
41
- }
4
+ var example = defineExample({
5
+ meta: {
6
+ key: "openbanking-powens",
7
+ version: "1.0.0",
8
+ title: "Open Banking \u2014 Powens",
9
+ description: "OAuth callback + webhook handler patterns for Powens open banking integration (provider + workflow orchestration).",
10
+ kind: "integration",
11
+ visibility: "public",
12
+ stability: "experimental",
13
+ owners: ["@platform.core"],
14
+ tags: ["openbanking", "powens", "oauth", "webhooks", "integrations"]
15
+ },
16
+ docs: {
17
+ rootDocId: "docs.examples.openbanking-powens",
18
+ usageDocId: "docs.examples.openbanking-powens.usage"
19
+ },
20
+ entrypoints: {
21
+ packageName: "@contractspec/example.openbanking-powens",
22
+ docs: "./docs"
23
+ },
24
+ surfaces: {
25
+ templates: true,
26
+ sandbox: { enabled: true, modes: ["markdown", "specs"] },
27
+ studio: { enabled: true, installable: true },
28
+ mcp: { enabled: true }
29
+ }
42
30
  });
43
-
44
- //#endregion
45
- export { example as default };
46
- //# sourceMappingURL=example.js.map
31
+ var example_default = example;
32
+ export {
33
+ example_default as default
34
+ };
@@ -1,5 +1,2 @@
1
- //#region src/handlers/oauth-callback.d.ts
2
- declare function powensOAuthCallbackHandler(req: Request): Promise<Response>;
3
- //#endregion
4
- export { powensOAuthCallbackHandler };
1
+ export declare function powensOAuthCallbackHandler(req: Request): Promise<Response>;
5
2
  //# sourceMappingURL=oauth-callback.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"oauth-callback.d.ts","names":[],"sources":["../../src/handlers/oauth-callback.ts"],"mappings":";iBASsB,0BAAA,CAA2B,GAAA,EAAK,OAAA,GAAO,OAAA,CAAA,QAAA"}
1
+ {"version":3,"file":"oauth-callback.d.ts","sourceRoot":"","sources":["../../src/handlers/oauth-callback.ts"],"names":[],"mappings":"AASA,wBAAsB,0BAA0B,CAAC,GAAG,EAAE,OAAO,qBAiD5D"}
@@ -1,64 +1,65 @@
1
+ // @bun
2
+ // src/handlers/oauth-callback.ts
1
3
  import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
2
-
3
- //#region src/handlers/oauth-callback.ts
4
- /**
5
- * Example OAuth callback handler for Powens (open banking).
6
- *
7
- * This example stays framework-neutral: it operates on the standard `Request`
8
- * type so it can be used in Next.js, Elysia, or any fetch-compatible runtime.
9
- */
10
4
  async function powensOAuthCallbackHandler(req) {
11
- const url = new URL(req.url);
12
- const code = url.searchParams.get("code");
13
- const state = url.searchParams.get("state");
14
- const userUuid = url.searchParams.get("user_uuid");
15
- if (!code || !state || !userUuid) return new Response("Missing Powens OAuth params", { status: 400 });
16
- const connection = await getConnectionByState(state);
17
- if (!connection) return new Response("Unknown Powens OAuth state", { status: 404 });
18
- const secrets = await getPowensSecretsForConnection(connection.meta.id);
19
- const preview = await new PowensOpenBankingProvider({
20
- clientId: secrets.clientId,
21
- clientSecret: secrets.clientSecret,
22
- apiKey: secrets.apiKey,
23
- environment: connection.config.environment,
24
- baseUrl: connection.config.baseUrl
25
- }).listAccounts({
26
- tenantId: connection.meta.tenantId,
27
- connectionId: connection.meta.id,
28
- userId: userUuid
29
- });
30
- await connection.storePowensUser({
31
- tenantUserId: connection.meta.tenantUserId,
32
- powensUserUuid: userUuid,
33
- authCode: code
34
- });
35
- await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
36
- tenantId: connection.meta.tenantId,
37
- userUuid,
38
- connectionId: connection.meta.id,
39
- previewAccounts: preview.accounts
40
- });
41
- const redirectBase = process.env.APP_DASHBOARD_URL ?? "";
42
- return Response.redirect(`${redirectBase}/banking/linked?tenant=${connection.meta.tenantId}`, 302);
5
+ const url = new URL(req.url);
6
+ const code = url.searchParams.get("code");
7
+ const state = url.searchParams.get("state");
8
+ const userUuid = url.searchParams.get("user_uuid");
9
+ if (!code || !state || !userUuid) {
10
+ return new Response("Missing Powens OAuth params", { status: 400 });
11
+ }
12
+ const connection = await getConnectionByState(state);
13
+ if (!connection) {
14
+ return new Response("Unknown Powens OAuth state", { status: 404 });
15
+ }
16
+ const secrets = await getPowensSecretsForConnection(connection.meta.id);
17
+ const provider = new PowensOpenBankingProvider({
18
+ clientId: secrets.clientId,
19
+ clientSecret: secrets.clientSecret,
20
+ apiKey: secrets.apiKey,
21
+ environment: connection.config.environment,
22
+ baseUrl: connection.config.baseUrl
23
+ });
24
+ const preview = await provider.listAccounts({
25
+ tenantId: connection.meta.tenantId,
26
+ connectionId: connection.meta.id,
27
+ userId: userUuid
28
+ });
29
+ await connection.storePowensUser({
30
+ tenantUserId: connection.meta.tenantUserId,
31
+ powensUserUuid: userUuid,
32
+ authCode: code
33
+ });
34
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
35
+ tenantId: connection.meta.tenantId,
36
+ userUuid,
37
+ connectionId: connection.meta.id,
38
+ previewAccounts: preview.accounts
39
+ });
40
+ const redirectBase = process.env.APP_DASHBOARD_URL ?? "";
41
+ return Response.redirect(`${redirectBase}/banking/linked?tenant=${connection.meta.tenantId}`, 302);
43
42
  }
44
43
  async function getConnectionByState(state) {
45
- return fakeDatabase.connections.find((conn) => conn.state === state) ?? null;
44
+ const record = fakeDatabase.connections.find((conn) => conn.state === state);
45
+ return record ?? null;
46
46
  }
47
47
  async function getPowensSecretsForConnection(connectionId) {
48
- const secret = fakeSecretStore[connectionId];
49
- if (!secret) throw new Error(`Missing Powens secrets for ${connectionId}`);
50
- return secret;
48
+ const secret = fakeSecretStore[connectionId];
49
+ if (!secret)
50
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
51
+ return secret;
51
52
  }
52
53
  async function enqueueWorkflow(name, input) {
53
- await fakeWorkflowQueue.enqueue({
54
- name,
55
- input
56
- });
54
+ await fakeWorkflowQueue.enqueue({ name, input });
57
55
  }
58
- const fakeDatabase = { connections: [] };
59
- const fakeSecretStore = {};
60
- const fakeWorkflowQueue = { enqueue: async (_payload) => {} };
61
-
62
- //#endregion
63
- export { powensOAuthCallbackHandler };
64
- //# sourceMappingURL=oauth-callback.js.map
56
+ var fakeDatabase = {
57
+ connections: []
58
+ };
59
+ var fakeSecretStore = {};
60
+ var fakeWorkflowQueue = {
61
+ enqueue: async (_payload) => {}
62
+ };
63
+ export {
64
+ powensOAuthCallbackHandler
65
+ };
@@ -1,5 +1,2 @@
1
- //#region src/handlers/webhook-handler.d.ts
2
- declare function powensWebhookHandler(req: Request): Promise<Response>;
3
- //#endregion
4
- export { powensWebhookHandler };
1
+ export declare function powensWebhookHandler(req: Request): Promise<Response>;
5
2
  //# sourceMappingURL=webhook-handler.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"webhook-handler.d.ts","names":[],"sources":["../../src/handlers/webhook-handler.ts"],"mappings":";iBAUsB,oBAAA,CAAqB,GAAA,EAAK,OAAA,GAAO,OAAA,CAAA,QAAA"}
1
+ {"version":3,"file":"webhook-handler.d.ts","sourceRoot":"","sources":["../../src/handlers/webhook-handler.ts"],"names":[],"mappings":"AAUA,wBAAsB,oBAAoB,CAAC,GAAG,EAAE,OAAO,qBA6DtD"}
@@ -1,88 +1,96 @@
1
- import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
1
+ // @bun
2
+ // src/handlers/webhook-handler.ts
2
3
  import { createHmac, timingSafeEqual } from "crypto";
3
-
4
- //#region src/handlers/webhook-handler.ts
5
- /**
6
- * Example Powens webhook handler (fetch-compatible).
7
- *
8
- * Verifies signature, then enqueues the canonical workflows to keep the ledger
9
- * in sync. Unknown events are ignored (or can be recorded by the app layer).
10
- */
4
+ import { PowensOpenBankingProvider } from "@contractspec/integration.providers-impls/impls/powens-openbanking";
11
5
  async function powensWebhookHandler(req) {
12
- const signature = req.headers.get("x-powens-signature");
13
- const stateHeader = req.headers.get("x-powens-state");
14
- const payload = await req.text();
15
- if (!signature || !stateHeader) return new Response("Missing Powens signature headers", { status: 400 });
16
- const connection = await getConnectionByState(stateHeader);
17
- if (!connection) return new Response("Unknown Powens state header", { status: 404 });
18
- const secrets = await getPowensSecretsForConnection(connection.meta.id);
19
- if (!verifySignature(payload, signature, secrets.webhookSecret)) return new Response("Invalid Powens webhook signature", { status: 401 });
20
- const event = JSON.parse(payload);
21
- const provider = new PowensOpenBankingProvider({
22
- clientId: secrets.clientId,
23
- clientSecret: secrets.clientSecret,
24
- apiKey: secrets.apiKey,
25
- environment: connection.config.environment,
26
- baseUrl: connection.config.baseUrl
27
- });
28
- switch (event.type) {
29
- case "connection.updated":
30
- case "user.sync.completed":
31
- await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
32
- tenantId: connection.meta.tenantId,
33
- connectionId: connection.meta.id,
34
- userUuid: event.user_uuid
35
- });
36
- break;
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
- default: await logUnmappedEvent(event);
47
- }
48
- if (event.account_uuid) await provider.getBalances({
49
- tenantId: connection.meta.tenantId,
50
- connectionId: connection.meta.id,
51
- accountId: event.account_uuid
52
- });
53
- return new Response("OK", { status: 200 });
6
+ const signature = req.headers.get("x-powens-signature");
7
+ const stateHeader = req.headers.get("x-powens-state");
8
+ const payload = await req.text();
9
+ if (!signature || !stateHeader) {
10
+ return new Response("Missing Powens signature headers", { status: 400 });
11
+ }
12
+ const connection = await getConnectionByState(stateHeader);
13
+ if (!connection) {
14
+ return new Response("Unknown Powens state header", { status: 404 });
15
+ }
16
+ const secrets = await getPowensSecretsForConnection(connection.meta.id);
17
+ if (!verifySignature(payload, signature, secrets.webhookSecret)) {
18
+ return new Response("Invalid Powens webhook signature", { status: 401 });
19
+ }
20
+ const event = JSON.parse(payload);
21
+ const provider = new PowensOpenBankingProvider({
22
+ clientId: secrets.clientId,
23
+ clientSecret: secrets.clientSecret,
24
+ apiKey: secrets.apiKey,
25
+ environment: connection.config.environment,
26
+ baseUrl: connection.config.baseUrl
27
+ });
28
+ switch (event.type) {
29
+ case "connection.updated":
30
+ case "user.sync.completed": {
31
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-accounts", {
32
+ tenantId: connection.meta.tenantId,
33
+ connectionId: connection.meta.id,
34
+ userUuid: event.user_uuid
35
+ });
36
+ break;
37
+ }
38
+ case "transactions.created":
39
+ case "transactions.updated": {
40
+ await enqueueWorkflow("pfo.workflow.sync-openbanking-transactions", {
41
+ tenantId: connection.meta.tenantId,
42
+ connectionId: connection.meta.id,
43
+ userUuid: event.user_uuid,
44
+ accountId: event.account_uuid
45
+ });
46
+ break;
47
+ }
48
+ default:
49
+ await logUnmappedEvent(event);
50
+ }
51
+ if (event.account_uuid) {
52
+ await provider.getBalances({
53
+ tenantId: connection.meta.tenantId,
54
+ connectionId: connection.meta.id,
55
+ accountId: event.account_uuid
56
+ });
57
+ }
58
+ return new Response("OK", { status: 200 });
54
59
  }
55
60
  function verifySignature(payload, signature, secret) {
56
- const digest = createHmac("sha256", secret).update(payload).digest("hex");
57
- const a = Buffer.from(digest, "hex");
58
- const b = Buffer.from(signature, "hex");
59
- return a.length === b.length && timingSafeEqual(a, b);
61
+ const digest = createHmac("sha256", secret).update(payload).digest("hex");
62
+ const a = Buffer.from(digest, "hex");
63
+ const b = Buffer.from(signature, "hex");
64
+ return a.length === b.length && timingSafeEqual(a, b);
60
65
  }
61
66
  async function getConnectionByState(state) {
62
- return fakeDatabase.connections.find((conn) => conn.state === state) ?? null;
67
+ return fakeDatabase.connections.find((conn) => conn.state === state) ?? null;
63
68
  }
64
69
  async function getPowensSecretsForConnection(connectionId) {
65
- const secret = fakeSecretStore[connectionId];
66
- if (!secret) throw new Error(`Missing Powens secrets for ${connectionId}`);
67
- return secret;
70
+ const secret = fakeSecretStore[connectionId];
71
+ if (!secret)
72
+ throw new Error(`Missing Powens secrets for ${connectionId}`);
73
+ return secret;
68
74
  }
69
75
  async function enqueueWorkflow(name, input) {
70
- await fakeWorkflowQueue.enqueue({
71
- name,
72
- input
73
- });
76
+ await fakeWorkflowQueue.enqueue({ name, input });
74
77
  }
75
78
  async function logUnmappedEvent(_event) {
76
- await fakeTelemetryLogger.record({
77
- event: "openbanking.webhook.unmapped",
78
- payload: "redacted"
79
- });
79
+ await fakeTelemetryLogger.record({
80
+ event: "openbanking.webhook.unmapped",
81
+ payload: "redacted"
82
+ });
80
83
  }
81
- const fakeDatabase = { connections: [] };
82
- const fakeSecretStore = {};
83
- const fakeWorkflowQueue = { enqueue: async (_payload) => {} };
84
- const fakeTelemetryLogger = { record: async (_payload) => {} };
85
-
86
- //#endregion
87
- export { powensWebhookHandler };
88
- //# sourceMappingURL=webhook-handler.js.map
84
+ var fakeDatabase = {
85
+ connections: []
86
+ };
87
+ var fakeSecretStore = {};
88
+ var fakeWorkflowQueue = {
89
+ enqueue: async (_payload) => {}
90
+ };
91
+ var fakeTelemetryLogger = {
92
+ record: async (_payload) => {}
93
+ };
94
+ export {
95
+ powensWebhookHandler
96
+ };