@contractspec/module.examples 1.45.0 → 1.45.2
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/dist/index.js +1 -2
- package/dist/registry.d.ts +2 -2
- package/dist/registry.js +2 -3
- package/dist/registry.js.map +1 -1
- package/package.json +38 -37
- package/dist/libs/contracts/dist/_virtual/rolldown_runtime.js +0 -6
- package/dist/libs/contracts/dist/_virtual/rolldown_runtime.js.map +0 -1
- package/dist/libs/contracts/dist/app-config/spec.js +0 -1
- package/dist/libs/contracts/dist/capabilities/capabilities.js +0 -1
- package/dist/libs/contracts/dist/capabilities/index.js +0 -2
- package/dist/libs/contracts/dist/capabilities/openbanking.js +0 -89
- package/dist/libs/contracts/dist/capabilities/openbanking.js.map +0 -1
- package/dist/libs/contracts/dist/client/index.js +0 -5
- package/dist/libs/contracts/dist/client/react/feature-render.js +0 -3
- package/dist/libs/contracts/dist/client/react/form-render.js +0 -6
- package/dist/libs/contracts/dist/client/react/index.js +0 -4
- package/dist/libs/contracts/dist/contract-registry/index.js +0 -1
- package/dist/libs/contracts/dist/contract-registry/schemas.js +0 -61
- package/dist/libs/contracts/dist/contract-registry/schemas.js.map +0 -1
- package/dist/libs/contracts/dist/data-views/index.js +0 -1
- package/dist/libs/contracts/dist/data-views/registry.js +0 -1
- package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +0 -17
- package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/index.js +0 -27
- package/dist/libs/contracts/dist/docs/meta.docs.js +0 -30
- package/dist/libs/contracts/dist/docs/meta.docs.js.map +0 -1
- package/dist/libs/contracts/dist/docs/presentations.js +0 -57
- package/dist/libs/contracts/dist/docs/presentations.js.map +0 -1
- package/dist/libs/contracts/dist/docs/registry.js +0 -45
- package/dist/libs/contracts/dist/docs/registry.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +0 -81
- package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +0 -58
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-import.docblock.js +0 -65
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-import.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +0 -17
- package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +0 -358
- package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +0 -38
- package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +0 -17
- package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +0 -21
- package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +0 -49
- package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +0 -80
- package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +0 -85
- package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +0 -46
- package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +0 -68
- package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +0 -41
- package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +0 -70
- package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +0 -48
- package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +0 -63
- package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +0 -156
- package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +0 -21
- package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +0 -102
- package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/docs/tech-contracts.docs.js +0 -97
- package/dist/libs/contracts/dist/docs/tech-contracts.docs.js.map +0 -1
- package/dist/libs/contracts/dist/events.js +0 -2
- package/dist/libs/contracts/dist/examples/index.js +0 -3
- package/dist/libs/contracts/dist/examples/registry.js +0 -145
- package/dist/libs/contracts/dist/examples/registry.js.map +0 -1
- package/dist/libs/contracts/dist/examples/schema.js +0 -102
- package/dist/libs/contracts/dist/examples/schema.js.map +0 -1
- package/dist/libs/contracts/dist/examples/validation.js +0 -1
- package/dist/libs/contracts/dist/experiments/evaluator.js +0 -1
- package/dist/libs/contracts/dist/experiments/spec.js +0 -1
- package/dist/libs/contracts/dist/features/index.js +0 -1
- package/dist/libs/contracts/dist/features/registry.js +0 -7
- package/dist/libs/contracts/dist/features/registry.js.map +0 -1
- package/dist/libs/contracts/dist/forms/forms.js +0 -2
- package/dist/libs/contracts/dist/forms/index.js +0 -1
- package/dist/libs/contracts/dist/index.js +0 -109
- package/dist/libs/contracts/dist/index.js.map +0 -1
- package/dist/libs/contracts/dist/install.js +0 -2
- package/dist/libs/contracts/dist/integrations/index.js +0 -19
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +0 -230
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +0 -161
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +0 -3
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +0 -212
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/openbanking/models.js +0 -243
- package/dist/libs/contracts/dist/integrations/openbanking/models.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +0 -14
- package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/operations.js +0 -384
- package/dist/libs/contracts/dist/integrations/operations.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +0 -52
- package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +0 -75
- package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/gmail.js +0 -87
- package/dist/libs/contracts/dist/integrations/providers/gmail.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +0 -66
- package/dist/libs/contracts/dist/integrations/providers/google-calendar.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/index.js +0 -11
- package/dist/libs/contracts/dist/integrations/providers/mistral.js +0 -68
- package/dist/libs/contracts/dist/integrations/providers/mistral.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/postmark.js +0 -68
- package/dist/libs/contracts/dist/integrations/providers/postmark.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/powens.js +0 -116
- package/dist/libs/contracts/dist/integrations/providers/powens.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/qdrant.js +0 -73
- package/dist/libs/contracts/dist/integrations/providers/qdrant.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/registry.js +0 -11
- package/dist/libs/contracts/dist/integrations/providers/stripe.js +0 -83
- package/dist/libs/contracts/dist/integrations/providers/stripe.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +0 -61
- package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js.map +0 -1
- package/dist/libs/contracts/dist/integrations/spec.js +0 -1
- package/dist/libs/contracts/dist/jsonschema.js +0 -1
- package/dist/libs/contracts/dist/knowledge/index.js +0 -8
- package/dist/libs/contracts/dist/knowledge/operations.js +0 -313
- package/dist/libs/contracts/dist/knowledge/operations.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +0 -34
- package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +0 -34
- package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +0 -38
- package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/index.js +0 -6
- package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +0 -34
- package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +0 -37
- package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +0 -34
- package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js.map +0 -1
- package/dist/libs/contracts/dist/knowledge/spec.js +0 -1
- package/dist/libs/contracts/dist/llm/exporters.js +0 -21
- package/dist/libs/contracts/dist/llm/exporters.js.map +0 -1
- package/dist/libs/contracts/dist/llm/index.js +0 -2
- package/dist/libs/contracts/dist/llm/prompts.js +0 -1
- package/dist/libs/contracts/dist/migrations.js +0 -1
- package/dist/libs/contracts/dist/model-registry.js +0 -1
- package/dist/libs/contracts/dist/onboarding-base.js +0 -198
- package/dist/libs/contracts/dist/onboarding-base.js.map +0 -1
- package/dist/libs/contracts/dist/openapi.js +0 -2
- package/dist/libs/contracts/dist/operations/index.js +0 -2
- package/dist/libs/contracts/dist/operations/operation.js +0 -35
- package/dist/libs/contracts/dist/operations/operation.js.map +0 -1
- package/dist/libs/contracts/dist/operations/registry.js +0 -2
- package/dist/libs/contracts/dist/ownership.js +0 -22
- package/dist/libs/contracts/dist/ownership.js.map +0 -1
- package/dist/libs/contracts/dist/policy/engine.js +0 -1
- package/dist/libs/contracts/dist/policy/index.js +0 -2
- package/dist/libs/contracts/dist/policy/registry.js +0 -1
- package/dist/libs/contracts/dist/presentations/index.js +0 -2
- package/dist/libs/contracts/dist/presentations/registry.js +0 -1
- package/dist/libs/contracts/dist/presentations/transform-engine.js +0 -13
- package/dist/libs/contracts/dist/presentations/transform-engine.js.map +0 -1
- package/dist/libs/contracts/dist/prompt.js +0 -1
- package/dist/libs/contracts/dist/promptRegistry.js +0 -2
- package/dist/libs/contracts/dist/regenerator/index.js +0 -1
- package/dist/libs/contracts/dist/regenerator/service.js +0 -5
- package/dist/libs/contracts/dist/regenerator/service.js.map +0 -1
- package/dist/libs/contracts/dist/registry-utils.js +0 -71
- package/dist/libs/contracts/dist/registry-utils.js.map +0 -1
- package/dist/libs/contracts/dist/registry.js +0 -8
- package/dist/libs/contracts/dist/registry.js.map +0 -1
- package/dist/libs/contracts/dist/resources.js +0 -1
- package/dist/libs/contracts/dist/schema-to-markdown.js +0 -1
- package/dist/libs/contracts/dist/server/contracts-adapter-input.js +0 -1
- package/dist/libs/contracts/dist/server/graphql-pothos.js +0 -8
- package/dist/libs/contracts/dist/server/index.js +0 -8
- package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +0 -4
- package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +0 -2
- package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +0 -1
- package/dist/libs/contracts/dist/server/mcp/registerResources.js +0 -2
- package/dist/libs/contracts/dist/server/mcp/registerTools.js +0 -1
- package/dist/libs/contracts/dist/server/provider-mcp.js +0 -1
- package/dist/libs/contracts/dist/server/rest-elysia.js +0 -1
- package/dist/libs/contracts/dist/server/rest-express.js +0 -1
- package/dist/libs/contracts/dist/server/rest-generic.js +0 -1
- package/dist/libs/contracts/dist/server/rest-next-app.js +0 -1
- package/dist/libs/contracts/dist/server/rest-next-pages.js +0 -1
- package/dist/libs/contracts/dist/telemetry/index.js +0 -2
- package/dist/libs/contracts/dist/telemetry/spec.js +0 -2
- package/dist/libs/contracts/dist/telemetry/tracker.js +0 -1
- package/dist/libs/contracts/dist/tests/index.js +0 -2
- package/dist/libs/contracts/dist/tests/runner.js +0 -2
- package/dist/libs/contracts/dist/tests/spec.js +0 -1
- package/dist/libs/contracts/dist/themes.js +0 -1
- package/dist/libs/contracts/dist/workflow/index.js +0 -2
- package/dist/libs/contracts/dist/workflow/overview.docblock.js +0 -21
- package/dist/libs/contracts/dist/workflow/overview.docblock.js.map +0 -1
- package/dist/libs/contracts/dist/workflow/runner.js +0 -1
- package/dist/libs/contracts/dist/workflow/spec.js +0 -1
- package/dist/libs/contracts/dist/workspace-config/contractsrc-schema.js +0 -263
- package/dist/libs/contracts/dist/workspace-config/contractsrc-schema.js.map +0 -1
- package/dist/libs/contracts/dist/workspace-config/index.js +0 -1
- package/dist/libs/contracts/dist/workspace-config/workspace-config.docblock.js +0 -45
- package/dist/libs/contracts/dist/workspace-config/workspace-config.docblock.js.map +0 -1
- package/dist/libs/schema/dist/EnumType.js +0 -2
- package/dist/libs/schema/dist/FieldType.js +0 -50
- package/dist/libs/schema/dist/FieldType.js.map +0 -1
- package/dist/libs/schema/dist/GraphQLSchemaType.js +0 -1
- package/dist/libs/schema/dist/JsonSchemaType.js +0 -1
- package/dist/libs/schema/dist/ScalarTypeEnum.js +0 -237
- package/dist/libs/schema/dist/ScalarTypeEnum.js.map +0 -1
- package/dist/libs/schema/dist/SchemaModel.js +0 -35
- package/dist/libs/schema/dist/SchemaModel.js.map +0 -1
- package/dist/libs/schema/dist/ZodSchemaType.js +0 -1
- package/dist/libs/schema/dist/entity/defineEntity.js +0 -1
- package/dist/libs/schema/dist/entity/index.js +0 -2
- package/dist/libs/schema/dist/entity/types.js +0 -1
- package/dist/libs/schema/dist/index.js +0 -9
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
import { ScalarTypeEnum } from "../../../../../schema/dist/ScalarTypeEnum.js";
|
|
2
|
-
import { SchemaModel } from "../../../../../schema/dist/SchemaModel.js";
|
|
3
|
-
import "../../../../../schema/dist/index.js";
|
|
4
|
-
import { defineCommand, defineQuery } from "../../../operations/operation.js";
|
|
5
|
-
import "../../../operations/index.js";
|
|
6
|
-
import { AccountBalanceRecord } from "../models.js";
|
|
7
|
-
import { OPENBANKING_TELEMETRY_EVENTS } from "../telemetry.js";
|
|
8
|
-
|
|
9
|
-
//#region ../../libs/contracts/dist/integrations/openbanking/contracts/balances.js
|
|
10
|
-
const OpenBankingGetBalancesInput = new SchemaModel({
|
|
11
|
-
name: "OpenBankingGetBalancesInput",
|
|
12
|
-
description: "Parameters for retrieving bank account balances from the canonical ledger.",
|
|
13
|
-
fields: {
|
|
14
|
-
tenantId: {
|
|
15
|
-
type: ScalarTypeEnum.ID(),
|
|
16
|
-
isOptional: false
|
|
17
|
-
},
|
|
18
|
-
accountId: {
|
|
19
|
-
type: ScalarTypeEnum.ID(),
|
|
20
|
-
isOptional: false
|
|
21
|
-
},
|
|
22
|
-
balanceTypes: {
|
|
23
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
24
|
-
isArray: true,
|
|
25
|
-
isOptional: true
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
const OpenBankingGetBalancesOutput = new SchemaModel({
|
|
30
|
-
name: "OpenBankingGetBalancesOutput",
|
|
31
|
-
description: "Canonical balances for a bank account.",
|
|
32
|
-
fields: {
|
|
33
|
-
balances: {
|
|
34
|
-
type: AccountBalanceRecord,
|
|
35
|
-
isOptional: false,
|
|
36
|
-
isArray: true
|
|
37
|
-
},
|
|
38
|
-
asOf: {
|
|
39
|
-
type: ScalarTypeEnum.DateTime(),
|
|
40
|
-
isOptional: true
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
const OpenBankingRefreshBalancesInput = new SchemaModel({
|
|
45
|
-
name: "OpenBankingRefreshBalancesInput",
|
|
46
|
-
description: "Command payload to refresh balances for a bank account via the open banking provider.",
|
|
47
|
-
fields: {
|
|
48
|
-
tenantId: {
|
|
49
|
-
type: ScalarTypeEnum.ID(),
|
|
50
|
-
isOptional: false
|
|
51
|
-
},
|
|
52
|
-
accountId: {
|
|
53
|
-
type: ScalarTypeEnum.ID(),
|
|
54
|
-
isOptional: false
|
|
55
|
-
},
|
|
56
|
-
connectionId: {
|
|
57
|
-
type: ScalarTypeEnum.ID(),
|
|
58
|
-
isOptional: true
|
|
59
|
-
},
|
|
60
|
-
balanceTypes: {
|
|
61
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
62
|
-
isArray: true,
|
|
63
|
-
isOptional: true
|
|
64
|
-
},
|
|
65
|
-
forceRefresh: {
|
|
66
|
-
type: ScalarTypeEnum.Boolean(),
|
|
67
|
-
isOptional: true
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
const OpenBankingRefreshBalancesOutput = new SchemaModel({
|
|
72
|
-
name: "OpenBankingRefreshBalancesOutput",
|
|
73
|
-
description: "Result of a balance refresh against the open banking provider.",
|
|
74
|
-
fields: {
|
|
75
|
-
balances: {
|
|
76
|
-
type: AccountBalanceRecord,
|
|
77
|
-
isOptional: false,
|
|
78
|
-
isArray: true
|
|
79
|
-
},
|
|
80
|
-
refreshedAt: {
|
|
81
|
-
type: ScalarTypeEnum.DateTime(),
|
|
82
|
-
isOptional: false
|
|
83
|
-
},
|
|
84
|
-
errors: {
|
|
85
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
86
|
-
isArray: true,
|
|
87
|
-
isOptional: true
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
const OpenBankingGetBalances = defineQuery({
|
|
92
|
-
meta: {
|
|
93
|
-
key: "openbanking.balances.get",
|
|
94
|
-
version: "1.0.0",
|
|
95
|
-
description: "Retrieve the latest cached balances for a bank account.",
|
|
96
|
-
goal: "Expose current and available balances required by dashboards and analytics.",
|
|
97
|
-
context: "Used by Pocket Family Office UI surfaces and automation steps that require balance totals prior to generating summaries.",
|
|
98
|
-
owners: ["@platform.finance"],
|
|
99
|
-
tags: [
|
|
100
|
-
"open-banking",
|
|
101
|
-
"powens",
|
|
102
|
-
"balances"
|
|
103
|
-
],
|
|
104
|
-
stability: "experimental"
|
|
105
|
-
},
|
|
106
|
-
io: {
|
|
107
|
-
input: OpenBankingGetBalancesInput,
|
|
108
|
-
output: OpenBankingGetBalancesOutput
|
|
109
|
-
},
|
|
110
|
-
policy: { auth: "user" }
|
|
111
|
-
});
|
|
112
|
-
const OpenBankingRefreshBalances = defineCommand({
|
|
113
|
-
meta: {
|
|
114
|
-
key: "openbanking.balances.refresh",
|
|
115
|
-
version: "1.0.0",
|
|
116
|
-
description: "Refresh balances for a bank account via the configured open banking provider.",
|
|
117
|
-
goal: "Ensure canonical balance records reflect the latest values from Powens.",
|
|
118
|
-
context: "Triggered by scheduled workflows before generating summaries or forecasting cashflow.",
|
|
119
|
-
owners: ["@platform.finance"],
|
|
120
|
-
tags: [
|
|
121
|
-
"open-banking",
|
|
122
|
-
"powens",
|
|
123
|
-
"balances"
|
|
124
|
-
],
|
|
125
|
-
stability: "experimental"
|
|
126
|
-
},
|
|
127
|
-
io: {
|
|
128
|
-
input: OpenBankingRefreshBalancesInput,
|
|
129
|
-
output: OpenBankingRefreshBalancesOutput
|
|
130
|
-
},
|
|
131
|
-
policy: { auth: "admin" },
|
|
132
|
-
telemetry: {
|
|
133
|
-
success: {
|
|
134
|
-
event: { key: OPENBANKING_TELEMETRY_EVENTS.balancesRefreshed },
|
|
135
|
-
properties: ({ input, output }) => {
|
|
136
|
-
const payload = input;
|
|
137
|
-
const result = output;
|
|
138
|
-
return {
|
|
139
|
-
tenantId: payload?.tenantId,
|
|
140
|
-
accountId: payload?.accountId,
|
|
141
|
-
refreshedAt: result?.refreshedAt,
|
|
142
|
-
balanceCount: Array.isArray(result?.balances) ? result?.balances.length : void 0
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
},
|
|
146
|
-
failure: {
|
|
147
|
-
event: { key: OPENBANKING_TELEMETRY_EVENTS.balancesRefreshFailed },
|
|
148
|
-
properties: ({ input, error }) => {
|
|
149
|
-
const payload = input;
|
|
150
|
-
return {
|
|
151
|
-
tenantId: payload?.tenantId,
|
|
152
|
-
accountId: payload?.accountId,
|
|
153
|
-
error: error instanceof Error ? error.message : String(error ?? "unknown")
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
//#endregion
|
|
161
|
-
//# sourceMappingURL=balances.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"balances.js","names":[],"sources":["../../../../../../../../../libs/contracts/dist/integrations/openbanking/contracts/balances.js"],"sourcesContent":["import { defineCommand, defineQuery } from \"../../../operations/operation.js\";\nimport \"../../../operations/index.js\";\nimport { AccountBalanceRecord } from \"../models.js\";\nimport { OPENBANKING_TELEMETRY_EVENTS } from \"../telemetry.js\";\nimport { ScalarTypeEnum, SchemaModel } from \"@contractspec/lib.schema\";\n\n//#region src/integrations/openbanking/contracts/balances.ts\nconst OpenBankingGetBalancesInput = new SchemaModel({\n\tname: \"OpenBankingGetBalancesInput\",\n\tdescription: \"Parameters for retrieving bank account balances from the canonical ledger.\",\n\tfields: {\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tbalanceTypes: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisArray: true,\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingGetBalancesOutput = new SchemaModel({\n\tname: \"OpenBankingGetBalancesOutput\",\n\tdescription: \"Canonical balances for a bank account.\",\n\tfields: {\n\t\tbalances: {\n\t\t\ttype: AccountBalanceRecord,\n\t\t\tisOptional: false,\n\t\t\tisArray: true\n\t\t},\n\t\tasOf: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingRefreshBalancesInput = new SchemaModel({\n\tname: \"OpenBankingRefreshBalancesInput\",\n\tdescription: \"Command payload to refresh balances for a bank account via the open banking provider.\",\n\tfields: {\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tconnectionId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: true\n\t\t},\n\t\tbalanceTypes: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisArray: true,\n\t\t\tisOptional: true\n\t\t},\n\t\tforceRefresh: {\n\t\t\ttype: ScalarTypeEnum.Boolean(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingRefreshBalancesOutput = new SchemaModel({\n\tname: \"OpenBankingRefreshBalancesOutput\",\n\tdescription: \"Result of a balance refresh against the open banking provider.\",\n\tfields: {\n\t\tbalances: {\n\t\t\ttype: AccountBalanceRecord,\n\t\t\tisOptional: false,\n\t\t\tisArray: true\n\t\t},\n\t\trefreshedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\terrors: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisArray: true,\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingGetBalances = defineQuery({\n\tmeta: {\n\t\tkey: \"openbanking.balances.get\",\n\t\tversion: \"1.0.0\",\n\t\tdescription: \"Retrieve the latest cached balances for a bank account.\",\n\t\tgoal: \"Expose current and available balances required by dashboards and analytics.\",\n\t\tcontext: \"Used by Pocket Family Office UI surfaces and automation steps that require balance totals prior to generating summaries.\",\n\t\towners: [\"@platform.finance\"],\n\t\ttags: [\n\t\t\t\"open-banking\",\n\t\t\t\"powens\",\n\t\t\t\"balances\"\n\t\t],\n\t\tstability: \"experimental\"\n\t},\n\tio: {\n\t\tinput: OpenBankingGetBalancesInput,\n\t\toutput: OpenBankingGetBalancesOutput\n\t},\n\tpolicy: { auth: \"user\" }\n});\nconst OpenBankingRefreshBalances = defineCommand({\n\tmeta: {\n\t\tkey: \"openbanking.balances.refresh\",\n\t\tversion: \"1.0.0\",\n\t\tdescription: \"Refresh balances for a bank account via the configured open banking provider.\",\n\t\tgoal: \"Ensure canonical balance records reflect the latest values from Powens.\",\n\t\tcontext: \"Triggered by scheduled workflows before generating summaries or forecasting cashflow.\",\n\t\towners: [\"@platform.finance\"],\n\t\ttags: [\n\t\t\t\"open-banking\",\n\t\t\t\"powens\",\n\t\t\t\"balances\"\n\t\t],\n\t\tstability: \"experimental\"\n\t},\n\tio: {\n\t\tinput: OpenBankingRefreshBalancesInput,\n\t\toutput: OpenBankingRefreshBalancesOutput\n\t},\n\tpolicy: { auth: \"admin\" },\n\ttelemetry: {\n\t\tsuccess: {\n\t\t\tevent: { key: OPENBANKING_TELEMETRY_EVENTS.balancesRefreshed },\n\t\t\tproperties: ({ input, output }) => {\n\t\t\t\tconst payload = input;\n\t\t\t\tconst result = output;\n\t\t\t\treturn {\n\t\t\t\t\ttenantId: payload?.tenantId,\n\t\t\t\t\taccountId: payload?.accountId,\n\t\t\t\t\trefreshedAt: result?.refreshedAt,\n\t\t\t\t\tbalanceCount: Array.isArray(result?.balances) ? result?.balances.length : void 0\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\tfailure: {\n\t\t\tevent: { key: OPENBANKING_TELEMETRY_EVENTS.balancesRefreshFailed },\n\t\t\tproperties: ({ input, error }) => {\n\t\t\t\tconst payload = input;\n\t\t\t\treturn {\n\t\t\t\t\ttenantId: payload?.tenantId,\n\t\t\t\t\taccountId: payload?.accountId,\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error ?? \"unknown\")\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n});\nconst openBankingBalanceContracts = {\n\tOpenBankingGetBalances,\n\tOpenBankingRefreshBalances\n};\nfunction registerOpenBankingBalanceContracts(registry) {\n\treturn registry.register(OpenBankingGetBalances).register(OpenBankingRefreshBalances);\n}\n\n//#endregion\nexport { OpenBankingGetBalances, OpenBankingRefreshBalances, openBankingBalanceContracts, registerOpenBankingBalanceContracts };"],"mappings":";;;;;;;;;AAOA,MAAM,8BAA8B,IAAI,YAAY;CACnD,MAAM;CACN,aAAa;CACb,QAAQ;EACP,UAAU;GACT,MAAM,eAAe,IAAI;GACzB,YAAY;GACZ;EACD,WAAW;GACV,MAAM,eAAe,IAAI;GACzB,YAAY;GACZ;EACD,cAAc;GACb,MAAM,eAAe,iBAAiB;GACtC,SAAS;GACT,YAAY;GACZ;EACD;CACD,CAAC;AACF,MAAM,+BAA+B,IAAI,YAAY;CACpD,MAAM;CACN,aAAa;CACb,QAAQ;EACP,UAAU;GACT,MAAM;GACN,YAAY;GACZ,SAAS;GACT;EACD,MAAM;GACL,MAAM,eAAe,UAAU;GAC/B,YAAY;GACZ;EACD;CACD,CAAC;AACF,MAAM,kCAAkC,IAAI,YAAY;CACvD,MAAM;CACN,aAAa;CACb,QAAQ;EACP,UAAU;GACT,MAAM,eAAe,IAAI;GACzB,YAAY;GACZ;EACD,WAAW;GACV,MAAM,eAAe,IAAI;GACzB,YAAY;GACZ;EACD,cAAc;GACb,MAAM,eAAe,IAAI;GACzB,YAAY;GACZ;EACD,cAAc;GACb,MAAM,eAAe,iBAAiB;GACtC,SAAS;GACT,YAAY;GACZ;EACD,cAAc;GACb,MAAM,eAAe,SAAS;GAC9B,YAAY;GACZ;EACD;CACD,CAAC;AACF,MAAM,mCAAmC,IAAI,YAAY;CACxD,MAAM;CACN,aAAa;CACb,QAAQ;EACP,UAAU;GACT,MAAM;GACN,YAAY;GACZ,SAAS;GACT;EACD,aAAa;GACZ,MAAM,eAAe,UAAU;GAC/B,YAAY;GACZ;EACD,QAAQ;GACP,MAAM,eAAe,iBAAiB;GACtC,SAAS;GACT,YAAY;GACZ;EACD;CACD,CAAC;AACF,MAAM,yBAAyB,YAAY;CAC1C,MAAM;EACL,KAAK;EACL,SAAS;EACT,aAAa;EACb,MAAM;EACN,SAAS;EACT,QAAQ,CAAC,oBAAoB;EAC7B,MAAM;GACL;GACA;GACA;GACA;EACD,WAAW;EACX;CACD,IAAI;EACH,OAAO;EACP,QAAQ;EACR;CACD,QAAQ,EAAE,MAAM,QAAQ;CACxB,CAAC;AACF,MAAM,6BAA6B,cAAc;CAChD,MAAM;EACL,KAAK;EACL,SAAS;EACT,aAAa;EACb,MAAM;EACN,SAAS;EACT,QAAQ,CAAC,oBAAoB;EAC7B,MAAM;GACL;GACA;GACA;GACA;EACD,WAAW;EACX;CACD,IAAI;EACH,OAAO;EACP,QAAQ;EACR;CACD,QAAQ,EAAE,MAAM,SAAS;CACzB,WAAW;EACV,SAAS;GACR,OAAO,EAAE,KAAK,6BAA6B,mBAAmB;GAC9D,aAAa,EAAE,OAAO,aAAa;IAClC,MAAM,UAAU;IAChB,MAAM,SAAS;AACf,WAAO;KACN,UAAU,SAAS;KACnB,WAAW,SAAS;KACpB,aAAa,QAAQ;KACrB,cAAc,MAAM,QAAQ,QAAQ,SAAS,GAAG,QAAQ,SAAS,SAAS,KAAK;KAC/E;;GAEF;EACD,SAAS;GACR,OAAO,EAAE,KAAK,6BAA6B,uBAAuB;GAClE,aAAa,EAAE,OAAO,YAAY;IACjC,MAAM,UAAU;AAChB,WAAO;KACN,UAAU,SAAS;KACnB,WAAW,SAAS;KACpB,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,SAAS,UAAU;KAC1E;;GAEF;EACD;CACD,CAAC"}
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
import { ScalarTypeEnum } from "../../../../../schema/dist/ScalarTypeEnum.js";
|
|
2
|
-
import { SchemaModel } from "../../../../../schema/dist/SchemaModel.js";
|
|
3
|
-
import "../../../../../schema/dist/index.js";
|
|
4
|
-
import { defineCommand, defineQuery } from "../../../operations/operation.js";
|
|
5
|
-
import "../../../operations/index.js";
|
|
6
|
-
import { BankTransactionRecord } from "../models.js";
|
|
7
|
-
import { OPENBANKING_TELEMETRY_EVENTS } from "../telemetry.js";
|
|
8
|
-
|
|
9
|
-
//#region ../../libs/contracts/dist/integrations/openbanking/contracts/transactions.js
|
|
10
|
-
const OpenBankingListTransactionsInput = new SchemaModel({
|
|
11
|
-
name: "OpenBankingListTransactionsInput",
|
|
12
|
-
description: "Parameters for listing bank transactions from the canonical ledger.",
|
|
13
|
-
fields: {
|
|
14
|
-
tenantId: {
|
|
15
|
-
type: ScalarTypeEnum.ID(),
|
|
16
|
-
isOptional: false
|
|
17
|
-
},
|
|
18
|
-
accountId: {
|
|
19
|
-
type: ScalarTypeEnum.ID(),
|
|
20
|
-
isOptional: false
|
|
21
|
-
},
|
|
22
|
-
from: {
|
|
23
|
-
type: ScalarTypeEnum.DateTime(),
|
|
24
|
-
isOptional: true
|
|
25
|
-
},
|
|
26
|
-
to: {
|
|
27
|
-
type: ScalarTypeEnum.DateTime(),
|
|
28
|
-
isOptional: true
|
|
29
|
-
},
|
|
30
|
-
cursor: {
|
|
31
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
32
|
-
isOptional: true
|
|
33
|
-
},
|
|
34
|
-
pageSize: {
|
|
35
|
-
type: ScalarTypeEnum.Int_unsecure(),
|
|
36
|
-
isOptional: true
|
|
37
|
-
},
|
|
38
|
-
direction: {
|
|
39
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
40
|
-
isOptional: true
|
|
41
|
-
},
|
|
42
|
-
minimumAmount: {
|
|
43
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
44
|
-
isOptional: true
|
|
45
|
-
},
|
|
46
|
-
maximumAmount: {
|
|
47
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
48
|
-
isOptional: true
|
|
49
|
-
},
|
|
50
|
-
category: {
|
|
51
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
52
|
-
isOptional: true
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
const OpenBankingListTransactionsOutput = new SchemaModel({
|
|
57
|
-
name: "OpenBankingListTransactionsOutput",
|
|
58
|
-
description: "Paginated list of transactions for a bank account.",
|
|
59
|
-
fields: {
|
|
60
|
-
transactions: {
|
|
61
|
-
type: BankTransactionRecord,
|
|
62
|
-
isOptional: false,
|
|
63
|
-
isArray: true
|
|
64
|
-
},
|
|
65
|
-
nextCursor: {
|
|
66
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
67
|
-
isOptional: true
|
|
68
|
-
},
|
|
69
|
-
hasMore: {
|
|
70
|
-
type: ScalarTypeEnum.Boolean(),
|
|
71
|
-
isOptional: true
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
const OpenBankingSyncTransactionsInput = new SchemaModel({
|
|
76
|
-
name: "OpenBankingSyncTransactionsInput",
|
|
77
|
-
description: "Command payload to synchronise transactions from the open banking provider into the canonical ledger.",
|
|
78
|
-
fields: {
|
|
79
|
-
tenantId: {
|
|
80
|
-
type: ScalarTypeEnum.ID(),
|
|
81
|
-
isOptional: false
|
|
82
|
-
},
|
|
83
|
-
accountId: {
|
|
84
|
-
type: ScalarTypeEnum.ID(),
|
|
85
|
-
isOptional: false
|
|
86
|
-
},
|
|
87
|
-
from: {
|
|
88
|
-
type: ScalarTypeEnum.DateTime(),
|
|
89
|
-
isOptional: true
|
|
90
|
-
},
|
|
91
|
-
to: {
|
|
92
|
-
type: ScalarTypeEnum.DateTime(),
|
|
93
|
-
isOptional: true
|
|
94
|
-
},
|
|
95
|
-
connectionId: {
|
|
96
|
-
type: ScalarTypeEnum.ID(),
|
|
97
|
-
isOptional: true
|
|
98
|
-
},
|
|
99
|
-
includePending: {
|
|
100
|
-
type: ScalarTypeEnum.Boolean(),
|
|
101
|
-
isOptional: true
|
|
102
|
-
},
|
|
103
|
-
backfillDays: {
|
|
104
|
-
type: ScalarTypeEnum.Int_unsecure(),
|
|
105
|
-
isOptional: true
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
const OpenBankingSyncTransactionsOutput = new SchemaModel({
|
|
110
|
-
name: "OpenBankingSyncTransactionsOutput",
|
|
111
|
-
description: "Result of a transaction synchronisation run.",
|
|
112
|
-
fields: {
|
|
113
|
-
synced: {
|
|
114
|
-
type: ScalarTypeEnum.Int_unsecure(),
|
|
115
|
-
isOptional: false
|
|
116
|
-
},
|
|
117
|
-
failed: {
|
|
118
|
-
type: ScalarTypeEnum.Int_unsecure(),
|
|
119
|
-
isOptional: false
|
|
120
|
-
},
|
|
121
|
-
earliestSyncedAt: {
|
|
122
|
-
type: ScalarTypeEnum.DateTime(),
|
|
123
|
-
isOptional: true
|
|
124
|
-
},
|
|
125
|
-
latestSyncedAt: {
|
|
126
|
-
type: ScalarTypeEnum.DateTime(),
|
|
127
|
-
isOptional: true
|
|
128
|
-
},
|
|
129
|
-
nextSinceToken: {
|
|
130
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
131
|
-
isOptional: true
|
|
132
|
-
},
|
|
133
|
-
errors: {
|
|
134
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
135
|
-
isArray: true,
|
|
136
|
-
isOptional: true
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
});
|
|
140
|
-
const OpenBankingListTransactions = defineQuery({
|
|
141
|
-
meta: {
|
|
142
|
-
key: "openbanking.transactions.list",
|
|
143
|
-
version: "1.0.0",
|
|
144
|
-
description: "List bank transactions that have been normalised into the canonical ledger.",
|
|
145
|
-
goal: "Allow downstream analytics and UI surfaces to page through canonical bank transactions.",
|
|
146
|
-
context: "Used by Pocket Family Office dashboards, reconciliation workflows, and analytics data views.",
|
|
147
|
-
owners: ["@platform.finance"],
|
|
148
|
-
tags: [
|
|
149
|
-
"open-banking",
|
|
150
|
-
"powens",
|
|
151
|
-
"transactions"
|
|
152
|
-
],
|
|
153
|
-
stability: "experimental"
|
|
154
|
-
},
|
|
155
|
-
io: {
|
|
156
|
-
input: OpenBankingListTransactionsInput,
|
|
157
|
-
output: OpenBankingListTransactionsOutput
|
|
158
|
-
},
|
|
159
|
-
policy: { auth: "user" }
|
|
160
|
-
});
|
|
161
|
-
const OpenBankingSyncTransactions = defineCommand({
|
|
162
|
-
meta: {
|
|
163
|
-
key: "openbanking.transactions.sync",
|
|
164
|
-
version: "1.0.0",
|
|
165
|
-
description: "Synchronise transactions for a bank account by calling the configured open banking provider.",
|
|
166
|
-
goal: "Ensure the canonical transaction ledger stays aligned with the external provider.",
|
|
167
|
-
context: "Triggered by scheduled workflows or on-demand actions when activity is expected on an account.",
|
|
168
|
-
owners: ["@platform.finance"],
|
|
169
|
-
tags: [
|
|
170
|
-
"open-banking",
|
|
171
|
-
"powens",
|
|
172
|
-
"transactions"
|
|
173
|
-
],
|
|
174
|
-
stability: "experimental"
|
|
175
|
-
},
|
|
176
|
-
io: {
|
|
177
|
-
input: OpenBankingSyncTransactionsInput,
|
|
178
|
-
output: OpenBankingSyncTransactionsOutput
|
|
179
|
-
},
|
|
180
|
-
policy: { auth: "admin" },
|
|
181
|
-
telemetry: {
|
|
182
|
-
success: {
|
|
183
|
-
event: { key: OPENBANKING_TELEMETRY_EVENTS.transactionsSynced },
|
|
184
|
-
properties: ({ input, output }) => {
|
|
185
|
-
const payload = input;
|
|
186
|
-
const result = output;
|
|
187
|
-
return {
|
|
188
|
-
tenantId: payload?.tenantId,
|
|
189
|
-
accountId: payload?.accountId,
|
|
190
|
-
synced: result?.synced,
|
|
191
|
-
failed: result?.failed,
|
|
192
|
-
earliestSyncedAt: result?.earliestSyncedAt,
|
|
193
|
-
latestSyncedAt: result?.latestSyncedAt
|
|
194
|
-
};
|
|
195
|
-
}
|
|
196
|
-
},
|
|
197
|
-
failure: {
|
|
198
|
-
event: { key: OPENBANKING_TELEMETRY_EVENTS.transactionsSyncFailed },
|
|
199
|
-
properties: ({ input, error }) => {
|
|
200
|
-
const payload = input;
|
|
201
|
-
return {
|
|
202
|
-
tenantId: payload?.tenantId,
|
|
203
|
-
accountId: payload?.accountId,
|
|
204
|
-
error: error instanceof Error ? error.message : String(error ?? "unknown")
|
|
205
|
-
};
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
});
|
|
210
|
-
|
|
211
|
-
//#endregion
|
|
212
|
-
//# sourceMappingURL=transactions.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transactions.js","names":[],"sources":["../../../../../../../../../libs/contracts/dist/integrations/openbanking/contracts/transactions.js"],"sourcesContent":["import { defineCommand, defineQuery } from \"../../../operations/operation.js\";\nimport \"../../../operations/index.js\";\nimport { BankTransactionRecord } from \"../models.js\";\nimport { OPENBANKING_TELEMETRY_EVENTS } from \"../telemetry.js\";\nimport { ScalarTypeEnum, SchemaModel } from \"@contractspec/lib.schema\";\n\n//#region src/integrations/openbanking/contracts/transactions.ts\nconst OpenBankingListTransactionsInput = new SchemaModel({\n\tname: \"OpenBankingListTransactionsInput\",\n\tdescription: \"Parameters for listing bank transactions from the canonical ledger.\",\n\tfields: {\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tfrom: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tto: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcursor: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tpageSize: {\n\t\t\ttype: ScalarTypeEnum.Int_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tdirection: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tminimumAmount: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tmaximumAmount: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcategory: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingListTransactionsOutput = new SchemaModel({\n\tname: \"OpenBankingListTransactionsOutput\",\n\tdescription: \"Paginated list of transactions for a bank account.\",\n\tfields: {\n\t\ttransactions: {\n\t\t\ttype: BankTransactionRecord,\n\t\t\tisOptional: false,\n\t\t\tisArray: true\n\t\t},\n\t\tnextCursor: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\thasMore: {\n\t\t\ttype: ScalarTypeEnum.Boolean(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingSyncTransactionsInput = new SchemaModel({\n\tname: \"OpenBankingSyncTransactionsInput\",\n\tdescription: \"Command payload to synchronise transactions from the open banking provider into the canonical ledger.\",\n\tfields: {\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tfrom: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tto: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tconnectionId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: true\n\t\t},\n\t\tincludePending: {\n\t\t\ttype: ScalarTypeEnum.Boolean(),\n\t\t\tisOptional: true\n\t\t},\n\t\tbackfillDays: {\n\t\t\ttype: ScalarTypeEnum.Int_unsecure(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingSyncTransactionsOutput = new SchemaModel({\n\tname: \"OpenBankingSyncTransactionsOutput\",\n\tdescription: \"Result of a transaction synchronisation run.\",\n\tfields: {\n\t\tsynced: {\n\t\t\ttype: ScalarTypeEnum.Int_unsecure(),\n\t\t\tisOptional: false\n\t\t},\n\t\tfailed: {\n\t\t\ttype: ScalarTypeEnum.Int_unsecure(),\n\t\t\tisOptional: false\n\t\t},\n\t\tearliestSyncedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tlatestSyncedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tnextSinceToken: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\terrors: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisArray: true,\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst OpenBankingListTransactions = defineQuery({\n\tmeta: {\n\t\tkey: \"openbanking.transactions.list\",\n\t\tversion: \"1.0.0\",\n\t\tdescription: \"List bank transactions that have been normalised into the canonical ledger.\",\n\t\tgoal: \"Allow downstream analytics and UI surfaces to page through canonical bank transactions.\",\n\t\tcontext: \"Used by Pocket Family Office dashboards, reconciliation workflows, and analytics data views.\",\n\t\towners: [\"@platform.finance\"],\n\t\ttags: [\n\t\t\t\"open-banking\",\n\t\t\t\"powens\",\n\t\t\t\"transactions\"\n\t\t],\n\t\tstability: \"experimental\"\n\t},\n\tio: {\n\t\tinput: OpenBankingListTransactionsInput,\n\t\toutput: OpenBankingListTransactionsOutput\n\t},\n\tpolicy: { auth: \"user\" }\n});\nconst OpenBankingSyncTransactions = defineCommand({\n\tmeta: {\n\t\tkey: \"openbanking.transactions.sync\",\n\t\tversion: \"1.0.0\",\n\t\tdescription: \"Synchronise transactions for a bank account by calling the configured open banking provider.\",\n\t\tgoal: \"Ensure the canonical transaction ledger stays aligned with the external provider.\",\n\t\tcontext: \"Triggered by scheduled workflows or on-demand actions when activity is expected on an account.\",\n\t\towners: [\"@platform.finance\"],\n\t\ttags: [\n\t\t\t\"open-banking\",\n\t\t\t\"powens\",\n\t\t\t\"transactions\"\n\t\t],\n\t\tstability: \"experimental\"\n\t},\n\tio: {\n\t\tinput: OpenBankingSyncTransactionsInput,\n\t\toutput: OpenBankingSyncTransactionsOutput\n\t},\n\tpolicy: { auth: \"admin\" },\n\ttelemetry: {\n\t\tsuccess: {\n\t\t\tevent: { key: OPENBANKING_TELEMETRY_EVENTS.transactionsSynced },\n\t\t\tproperties: ({ input, output }) => {\n\t\t\t\tconst payload = input;\n\t\t\t\tconst result = output;\n\t\t\t\treturn {\n\t\t\t\t\ttenantId: payload?.tenantId,\n\t\t\t\t\taccountId: payload?.accountId,\n\t\t\t\t\tsynced: result?.synced,\n\t\t\t\t\tfailed: result?.failed,\n\t\t\t\t\tearliestSyncedAt: result?.earliestSyncedAt,\n\t\t\t\t\tlatestSyncedAt: result?.latestSyncedAt\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\tfailure: {\n\t\t\tevent: { key: OPENBANKING_TELEMETRY_EVENTS.transactionsSyncFailed },\n\t\t\tproperties: ({ input, error }) => {\n\t\t\t\tconst payload = input;\n\t\t\t\treturn {\n\t\t\t\t\ttenantId: payload?.tenantId,\n\t\t\t\t\taccountId: payload?.accountId,\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error ?? \"unknown\")\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n});\nconst openBankingTransactionContracts = {\n\tOpenBankingListTransactions,\n\tOpenBankingSyncTransactions\n};\nfunction registerOpenBankingTransactionContracts(registry) {\n\treturn registry.register(OpenBankingListTransactions).register(OpenBankingSyncTransactions);\n}\n\n//#endregion\nexport { OpenBankingListTransactions, OpenBankingSyncTransactions, openBankingTransactionContracts, registerOpenBankingTransactionContracts };"],"mappings":"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"}
|
|
@@ -1,243 +0,0 @@
|
|
|
1
|
-
import { ScalarTypeEnum } from "../../../../schema/dist/ScalarTypeEnum.js";
|
|
2
|
-
import { SchemaModel } from "../../../../schema/dist/SchemaModel.js";
|
|
3
|
-
import "../../../../schema/dist/index.js";
|
|
4
|
-
|
|
5
|
-
//#region ../../libs/contracts/dist/integrations/openbanking/models.js
|
|
6
|
-
const BankAccountRecord = new SchemaModel({
|
|
7
|
-
name: "BankAccountRecord",
|
|
8
|
-
description: "Canonical representation of a bank account synced from an open banking provider.",
|
|
9
|
-
fields: {
|
|
10
|
-
id: {
|
|
11
|
-
type: ScalarTypeEnum.ID(),
|
|
12
|
-
isOptional: false
|
|
13
|
-
},
|
|
14
|
-
tenantId: {
|
|
15
|
-
type: ScalarTypeEnum.ID(),
|
|
16
|
-
isOptional: false
|
|
17
|
-
},
|
|
18
|
-
userId: {
|
|
19
|
-
type: ScalarTypeEnum.ID(),
|
|
20
|
-
isOptional: false
|
|
21
|
-
},
|
|
22
|
-
connectionId: {
|
|
23
|
-
type: ScalarTypeEnum.ID(),
|
|
24
|
-
isOptional: false
|
|
25
|
-
},
|
|
26
|
-
externalId: {
|
|
27
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
28
|
-
isOptional: false
|
|
29
|
-
},
|
|
30
|
-
institutionId: {
|
|
31
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
32
|
-
isOptional: false
|
|
33
|
-
},
|
|
34
|
-
institutionName: {
|
|
35
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
36
|
-
isOptional: false
|
|
37
|
-
},
|
|
38
|
-
institutionLogoUrl: {
|
|
39
|
-
type: ScalarTypeEnum.URL(),
|
|
40
|
-
isOptional: true
|
|
41
|
-
},
|
|
42
|
-
iban: {
|
|
43
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
44
|
-
isOptional: true
|
|
45
|
-
},
|
|
46
|
-
bic: {
|
|
47
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
48
|
-
isOptional: true
|
|
49
|
-
},
|
|
50
|
-
accountType: {
|
|
51
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
52
|
-
isOptional: false
|
|
53
|
-
},
|
|
54
|
-
currency: {
|
|
55
|
-
type: ScalarTypeEnum.Currency(),
|
|
56
|
-
isOptional: false
|
|
57
|
-
},
|
|
58
|
-
displayName: {
|
|
59
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
60
|
-
isOptional: false
|
|
61
|
-
},
|
|
62
|
-
accountNumberMasked: {
|
|
63
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
64
|
-
isOptional: true
|
|
65
|
-
},
|
|
66
|
-
productCode: {
|
|
67
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
68
|
-
isOptional: true
|
|
69
|
-
},
|
|
70
|
-
balance: {
|
|
71
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
72
|
-
isOptional: true
|
|
73
|
-
},
|
|
74
|
-
availableBalance: {
|
|
75
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
76
|
-
isOptional: true
|
|
77
|
-
},
|
|
78
|
-
lastSyncedAt: {
|
|
79
|
-
type: ScalarTypeEnum.DateTime(),
|
|
80
|
-
isOptional: false
|
|
81
|
-
},
|
|
82
|
-
createdAt: {
|
|
83
|
-
type: ScalarTypeEnum.DateTime(),
|
|
84
|
-
isOptional: false
|
|
85
|
-
},
|
|
86
|
-
updatedAt: {
|
|
87
|
-
type: ScalarTypeEnum.DateTime(),
|
|
88
|
-
isOptional: false
|
|
89
|
-
},
|
|
90
|
-
metadata: {
|
|
91
|
-
type: ScalarTypeEnum.JSONObject(),
|
|
92
|
-
isOptional: true
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
const BankTransactionRecord = new SchemaModel({
|
|
97
|
-
name: "BankTransactionRecord",
|
|
98
|
-
description: "Canonical transaction entry mapped from Powens into the open banking ledger.",
|
|
99
|
-
fields: {
|
|
100
|
-
id: {
|
|
101
|
-
type: ScalarTypeEnum.ID(),
|
|
102
|
-
isOptional: false
|
|
103
|
-
},
|
|
104
|
-
accountId: {
|
|
105
|
-
type: ScalarTypeEnum.ID(),
|
|
106
|
-
isOptional: false
|
|
107
|
-
},
|
|
108
|
-
tenantId: {
|
|
109
|
-
type: ScalarTypeEnum.ID(),
|
|
110
|
-
isOptional: false
|
|
111
|
-
},
|
|
112
|
-
connectionId: {
|
|
113
|
-
type: ScalarTypeEnum.ID(),
|
|
114
|
-
isOptional: false
|
|
115
|
-
},
|
|
116
|
-
externalId: {
|
|
117
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
118
|
-
isOptional: false
|
|
119
|
-
},
|
|
120
|
-
amount: {
|
|
121
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
122
|
-
isOptional: false
|
|
123
|
-
},
|
|
124
|
-
currency: {
|
|
125
|
-
type: ScalarTypeEnum.Currency(),
|
|
126
|
-
isOptional: false
|
|
127
|
-
},
|
|
128
|
-
date: {
|
|
129
|
-
type: ScalarTypeEnum.DateTime(),
|
|
130
|
-
isOptional: false
|
|
131
|
-
},
|
|
132
|
-
bookingDate: {
|
|
133
|
-
type: ScalarTypeEnum.DateTime(),
|
|
134
|
-
isOptional: true
|
|
135
|
-
},
|
|
136
|
-
valueDate: {
|
|
137
|
-
type: ScalarTypeEnum.DateTime(),
|
|
138
|
-
isOptional: true
|
|
139
|
-
},
|
|
140
|
-
description: {
|
|
141
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
142
|
-
isOptional: true
|
|
143
|
-
},
|
|
144
|
-
counterpartyName: {
|
|
145
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
146
|
-
isOptional: true
|
|
147
|
-
},
|
|
148
|
-
counterpartyAccount: {
|
|
149
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
150
|
-
isOptional: true
|
|
151
|
-
},
|
|
152
|
-
merchantCategoryCode: {
|
|
153
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
154
|
-
isOptional: true
|
|
155
|
-
},
|
|
156
|
-
rawCategory: {
|
|
157
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
158
|
-
isOptional: true
|
|
159
|
-
},
|
|
160
|
-
standardizedCategory: {
|
|
161
|
-
type: ScalarTypeEnum.String_unsecure(),
|
|
162
|
-
isOptional: true
|
|
163
|
-
},
|
|
164
|
-
transactionType: {
|
|
165
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
166
|
-
isOptional: false
|
|
167
|
-
},
|
|
168
|
-
status: {
|
|
169
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
170
|
-
isOptional: false
|
|
171
|
-
},
|
|
172
|
-
runningBalance: {
|
|
173
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
174
|
-
isOptional: true
|
|
175
|
-
},
|
|
176
|
-
metadata: {
|
|
177
|
-
type: ScalarTypeEnum.JSONObject(),
|
|
178
|
-
isOptional: true
|
|
179
|
-
},
|
|
180
|
-
createdAt: {
|
|
181
|
-
type: ScalarTypeEnum.DateTime(),
|
|
182
|
-
isOptional: false
|
|
183
|
-
},
|
|
184
|
-
updatedAt: {
|
|
185
|
-
type: ScalarTypeEnum.DateTime(),
|
|
186
|
-
isOptional: false
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
});
|
|
190
|
-
const AccountBalanceRecord = new SchemaModel({
|
|
191
|
-
name: "AccountBalanceRecord",
|
|
192
|
-
description: "Canonical balance snapshot computed from Powens balance payloads.",
|
|
193
|
-
fields: {
|
|
194
|
-
id: {
|
|
195
|
-
type: ScalarTypeEnum.ID(),
|
|
196
|
-
isOptional: false
|
|
197
|
-
},
|
|
198
|
-
accountId: {
|
|
199
|
-
type: ScalarTypeEnum.ID(),
|
|
200
|
-
isOptional: false
|
|
201
|
-
},
|
|
202
|
-
tenantId: {
|
|
203
|
-
type: ScalarTypeEnum.ID(),
|
|
204
|
-
isOptional: false
|
|
205
|
-
},
|
|
206
|
-
connectionId: {
|
|
207
|
-
type: ScalarTypeEnum.ID(),
|
|
208
|
-
isOptional: false
|
|
209
|
-
},
|
|
210
|
-
balanceType: {
|
|
211
|
-
type: ScalarTypeEnum.NonEmptyString(),
|
|
212
|
-
isOptional: false
|
|
213
|
-
},
|
|
214
|
-
currentBalance: {
|
|
215
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
216
|
-
isOptional: false
|
|
217
|
-
},
|
|
218
|
-
availableBalance: {
|
|
219
|
-
type: ScalarTypeEnum.Float_unsecure(),
|
|
220
|
-
isOptional: true
|
|
221
|
-
},
|
|
222
|
-
currency: {
|
|
223
|
-
type: ScalarTypeEnum.Currency(),
|
|
224
|
-
isOptional: false
|
|
225
|
-
},
|
|
226
|
-
lastUpdatedAt: {
|
|
227
|
-
type: ScalarTypeEnum.DateTime(),
|
|
228
|
-
isOptional: false
|
|
229
|
-
},
|
|
230
|
-
createdAt: {
|
|
231
|
-
type: ScalarTypeEnum.DateTime(),
|
|
232
|
-
isOptional: false
|
|
233
|
-
},
|
|
234
|
-
metadata: {
|
|
235
|
-
type: ScalarTypeEnum.JSONObject(),
|
|
236
|
-
isOptional: true
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
//#endregion
|
|
242
|
-
export { AccountBalanceRecord, BankAccountRecord, BankTransactionRecord };
|
|
243
|
-
//# sourceMappingURL=models.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","names":[],"sources":["../../../../../../../../libs/contracts/dist/integrations/openbanking/models.js"],"sourcesContent":["import { ScalarTypeEnum, SchemaModel } from \"@contractspec/lib.schema\";\n\n//#region src/integrations/openbanking/models.ts\nconst BankAccountRecord = new SchemaModel({\n\tname: \"BankAccountRecord\",\n\tdescription: \"Canonical representation of a bank account synced from an open banking provider.\",\n\tfields: {\n\t\tid: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tuserId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tconnectionId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\texternalId: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tinstitutionId: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tinstitutionName: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tinstitutionLogoUrl: {\n\t\t\ttype: ScalarTypeEnum.URL(),\n\t\t\tisOptional: true\n\t\t},\n\t\tiban: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tbic: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\taccountType: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tcurrency: {\n\t\t\ttype: ScalarTypeEnum.Currency(),\n\t\t\tisOptional: false\n\t\t},\n\t\tdisplayName: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountNumberMasked: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tproductCode: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tbalance: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tavailableBalance: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tlastSyncedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tcreatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tupdatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tmetadata: {\n\t\t\ttype: ScalarTypeEnum.JSONObject(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\nconst BankTransactionRecord = new SchemaModel({\n\tname: \"BankTransactionRecord\",\n\tdescription: \"Canonical transaction entry mapped from Powens into the open banking ledger.\",\n\tfields: {\n\t\tid: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tconnectionId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\texternalId: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tamount: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: false\n\t\t},\n\t\tcurrency: {\n\t\t\ttype: ScalarTypeEnum.Currency(),\n\t\t\tisOptional: false\n\t\t},\n\t\tdate: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tbookingDate: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tvalueDate: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: true\n\t\t},\n\t\tdescription: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcounterpartyName: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcounterpartyAccount: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tmerchantCategoryCode: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\trawCategory: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tstandardizedCategory: {\n\t\t\ttype: ScalarTypeEnum.String_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\ttransactionType: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tstatus: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\trunningBalance: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tmetadata: {\n\t\t\ttype: ScalarTypeEnum.JSONObject(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcreatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tupdatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t}\n\t}\n});\nconst AccountBalanceRecord = new SchemaModel({\n\tname: \"AccountBalanceRecord\",\n\tdescription: \"Canonical balance snapshot computed from Powens balance payloads.\",\n\tfields: {\n\t\tid: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\taccountId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\ttenantId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tconnectionId: {\n\t\t\ttype: ScalarTypeEnum.ID(),\n\t\t\tisOptional: false\n\t\t},\n\t\tbalanceType: {\n\t\t\ttype: ScalarTypeEnum.NonEmptyString(),\n\t\t\tisOptional: false\n\t\t},\n\t\tcurrentBalance: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: false\n\t\t},\n\t\tavailableBalance: {\n\t\t\ttype: ScalarTypeEnum.Float_unsecure(),\n\t\t\tisOptional: true\n\t\t},\n\t\tcurrency: {\n\t\t\ttype: ScalarTypeEnum.Currency(),\n\t\t\tisOptional: false\n\t\t},\n\t\tlastUpdatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tcreatedAt: {\n\t\t\ttype: ScalarTypeEnum.DateTime(),\n\t\t\tisOptional: false\n\t\t},\n\t\tmetadata: {\n\t\t\ttype: ScalarTypeEnum.JSONObject(),\n\t\t\tisOptional: true\n\t\t}\n\t}\n});\n\n//#endregion\nexport { AccountBalanceRecord, BankAccountRecord, BankTransactionRecord };"],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
//#region ../../libs/contracts/dist/integrations/openbanking/telemetry.js
|
|
2
|
-
const OPENBANKING_TELEMETRY_EVENTS = {
|
|
3
|
-
accountsSynced: "openbanking.accounts.synced",
|
|
4
|
-
accountsSyncFailed: "openbanking.accounts.sync_failed",
|
|
5
|
-
transactionsSynced: "openbanking.transactions.synced",
|
|
6
|
-
transactionsSyncFailed: "openbanking.transactions.sync_failed",
|
|
7
|
-
balancesRefreshed: "openbanking.balances.refreshed",
|
|
8
|
-
balancesRefreshFailed: "openbanking.balances.refresh_failed",
|
|
9
|
-
overviewGenerated: "openbanking.overview.generated"
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
//#endregion
|
|
13
|
-
export { OPENBANKING_TELEMETRY_EVENTS };
|
|
14
|
-
//# sourceMappingURL=telemetry.js.map
|