@lssm/example.analytics-dashboard 0.0.0-canary-20251217063201 → 0.0.0-canary-20251217072406
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/dashboard/dashboard.contracts.d.ts +131 -131
- package/dist/dashboard/dashboard.contracts.js +5 -5
- package/dist/dashboard/dashboard.enum.d.ts +4 -4
- package/dist/dashboard/dashboard.enum.js +4 -4
- package/dist/dashboard/dashboard.schema.d.ts +79 -79
- package/dist/dashboard/dashboard.schema.js +43 -43
- package/dist/docs/analytics-dashboard.docblock.js +2 -2
- package/dist/events.d.ts +40 -40
- package/dist/events.js +25 -25
- package/dist/libs/contracts/dist/capabilities/openbanking.js +53 -49
- package/dist/libs/contracts/dist/client/index.js +1 -1
- package/dist/libs/contracts/dist/client/react/index.js +1 -1
- package/dist/libs/contracts/dist/contract-registry/index.js +1 -1
- package/dist/libs/contracts/dist/contract-registry/schemas.js +52 -49
- package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +11 -86
- package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +11 -360
- package/dist/libs/contracts/dist/docs/index.js +2 -2
- package/dist/libs/contracts/dist/docs/presentations.js +48 -44
- package/dist/libs/contracts/dist/docs/registry.js +27 -25
- package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +11 -393
- package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +11 -78
- package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +11 -150
- package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +11 -96
- package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +10 -10
- package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +15 -15
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +12 -12
- package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +11 -223
- package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +44 -44
- package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +30 -14
- package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +10 -10
- package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +13 -274
- package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +41 -15
- package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +15 -15
- package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +14 -14
- package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +16 -28
- package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +60 -15
- package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +13 -13
- package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +31 -48
- package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +40 -15
- package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +14 -14
- package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +22 -22
- package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +12 -12
- package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +22 -22
- package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +11 -11
- package/dist/libs/contracts/dist/events.js +4 -3
- package/dist/libs/contracts/dist/index.js +14 -14
- package/dist/libs/contracts/dist/integrations/contracts.js +205 -199
- package/dist/libs/contracts/dist/integrations/index.js +5 -5
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +133 -130
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +95 -93
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +3 -3
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +120 -118
- package/dist/libs/contracts/dist/integrations/openbanking/models.js +122 -120
- package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +9 -20
- package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +25 -25
- package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +36 -36
- package/dist/libs/contracts/dist/integrations/providers/gmail.js +40 -40
- package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +31 -31
- package/dist/libs/contracts/dist/integrations/providers/mistral.js +31 -31
- package/dist/libs/contracts/dist/integrations/providers/postmark.js +31 -31
- package/dist/libs/contracts/dist/integrations/providers/powens.js +51 -51
- package/dist/libs/contracts/dist/integrations/providers/qdrant.js +31 -31
- package/dist/libs/contracts/dist/integrations/providers/stripe.js +35 -35
- package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +28 -28
- package/dist/libs/contracts/dist/jsonschema.js +1 -1
- package/dist/libs/contracts/dist/knowledge/contracts.js +170 -163
- package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +17 -17
- package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +17 -17
- package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +19 -19
- package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +17 -17
- package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +17 -17
- package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +17 -17
- package/dist/libs/contracts/dist/llm/exporters.js +13 -12
- package/dist/libs/contracts/dist/onboarding-base.js +116 -99
- package/dist/libs/contracts/dist/ownership.js +18 -33
- package/dist/libs/contracts/dist/presentations.js +1 -1
- package/dist/libs/contracts/dist/presentations.v2.js +6 -2
- package/dist/libs/contracts/dist/regenerator/service.js +5 -0
- package/dist/libs/contracts/dist/registry.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/FieldType.js +24 -14
- package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +180 -166
- package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +20 -9
- package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +1 -1
- package/dist/libs/contracts/dist/spec.js +22 -13
- package/dist/libs/schema/dist/EnumType.js +25 -9
- package/dist/libs/schema/dist/FieldType.js +24 -14
- package/dist/libs/schema/dist/ScalarTypeEnum.js +180 -166
- package/dist/libs/schema/dist/SchemaModel.js +25 -10
- package/dist/libs/schema/dist/index.js +4 -4
- package/dist/query/query.contracts.d.ts +44 -44
- package/dist/query/query.contracts.js +3 -3
- package/dist/query/query.enum.js +2 -2
- package/dist/query/query.schema.js +33 -33
- package/package.json +10 -10
|
@@ -1,222 +1,236 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import * as
|
|
1
|
+
import { FieldType } from "./FieldType.js";
|
|
2
|
+
import * as z$1 from "zod";
|
|
3
3
|
import { Kind } from "graphql";
|
|
4
4
|
|
|
5
5
|
//#region ../../libs/contracts/dist/schema/dist/ScalarTypeEnum.js
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
6
|
+
const localeRegex = /^[A-Za-z]{2}(?:-[A-Za-z0-9]{2,8})*$/;
|
|
7
|
+
const timezoneRegex = /^(?:UTC|[A-Za-z_]+\/[A-Za-z_]+)$/;
|
|
8
|
+
const phoneRegex = /^[+]?\d[\d\s().-]{3,}$/;
|
|
9
|
+
const currencyRegex = /^[A-Z]{3}$/;
|
|
10
|
+
const countryRegex = /^[A-Z]{2}$/;
|
|
11
|
+
const latMin = -90;
|
|
12
|
+
const latMax = 90;
|
|
13
|
+
const lonMin = -180;
|
|
14
|
+
const lonMax = 180;
|
|
15
|
+
/**
|
|
16
|
+
* Factory functions for common scalar FieldTypes with zod/GraphQL/JSON Schema.
|
|
17
|
+
*/
|
|
18
|
+
const ScalarTypeEnum = {
|
|
19
|
+
String_unsecure: () => new FieldType({
|
|
20
|
+
name: "String_unsecure",
|
|
21
|
+
description: "Unvalidated string scalar",
|
|
22
|
+
zod: z$1.string(),
|
|
23
|
+
parseValue: (v) => z$1.string().parse(v),
|
|
24
|
+
serialize: (v) => String(v),
|
|
25
|
+
parseLiteral: (ast) => {
|
|
26
|
+
if (ast.kind !== Kind.STRING) throw new TypeError("Invalid literal");
|
|
27
|
+
return ast.value;
|
|
16
28
|
},
|
|
17
|
-
jsonSchema: { type:
|
|
18
|
-
}),
|
|
19
|
-
Int_unsecure: () => new
|
|
20
|
-
name:
|
|
21
|
-
description:
|
|
22
|
-
zod:
|
|
23
|
-
parseValue: (
|
|
24
|
-
|
|
25
|
-
return
|
|
29
|
+
jsonSchema: { type: "string" }
|
|
30
|
+
}),
|
|
31
|
+
Int_unsecure: () => new FieldType({
|
|
32
|
+
name: "Int_unsecure",
|
|
33
|
+
description: "Unvalidated integer scalar",
|
|
34
|
+
zod: z$1.number().int(),
|
|
35
|
+
parseValue: (v) => {
|
|
36
|
+
const num = typeof v === "number" ? v : Number(v);
|
|
37
|
+
return z$1.number().int().parse(num);
|
|
26
38
|
},
|
|
27
|
-
serialize: (
|
|
28
|
-
parseLiteral: (
|
|
29
|
-
if (
|
|
30
|
-
return Number(
|
|
39
|
+
serialize: (v) => Math.trunc(typeof v === "number" ? v : Number(v)),
|
|
40
|
+
parseLiteral: (ast) => {
|
|
41
|
+
if (ast.kind !== Kind.INT) throw new TypeError("Invalid literal");
|
|
42
|
+
return Number(ast.value);
|
|
31
43
|
},
|
|
32
|
-
jsonSchema: { type:
|
|
33
|
-
}),
|
|
34
|
-
Float_unsecure: () => new
|
|
35
|
-
name:
|
|
36
|
-
description:
|
|
37
|
-
zod:
|
|
38
|
-
parseValue: (
|
|
39
|
-
|
|
40
|
-
return
|
|
44
|
+
jsonSchema: { type: "integer" }
|
|
45
|
+
}),
|
|
46
|
+
Float_unsecure: () => new FieldType({
|
|
47
|
+
name: "Float_unsecure",
|
|
48
|
+
description: "Unvalidated float scalar",
|
|
49
|
+
zod: z$1.number(),
|
|
50
|
+
parseValue: (v) => {
|
|
51
|
+
const num = typeof v === "number" ? v : Number(v);
|
|
52
|
+
return z$1.number().parse(num);
|
|
41
53
|
},
|
|
42
|
-
serialize: (
|
|
43
|
-
parseLiteral: (
|
|
44
|
-
if (
|
|
45
|
-
return Number(
|
|
54
|
+
serialize: (v) => Number(v),
|
|
55
|
+
parseLiteral: (ast) => {
|
|
56
|
+
if (ast.kind !== Kind.FLOAT && ast.kind !== Kind.INT) throw new TypeError("Invalid literal");
|
|
57
|
+
return Number(ast.value);
|
|
46
58
|
},
|
|
47
|
-
jsonSchema: { type:
|
|
48
|
-
}),
|
|
49
|
-
Boolean: () => new
|
|
50
|
-
name:
|
|
51
|
-
description:
|
|
52
|
-
zod:
|
|
53
|
-
parseValue: (
|
|
54
|
-
serialize: (
|
|
55
|
-
parseLiteral: (
|
|
56
|
-
if (
|
|
57
|
-
return
|
|
59
|
+
jsonSchema: { type: "number" }
|
|
60
|
+
}),
|
|
61
|
+
Boolean: () => new FieldType({
|
|
62
|
+
name: "Boolean",
|
|
63
|
+
description: "Unvalidated boolean scalar",
|
|
64
|
+
zod: z$1.boolean(),
|
|
65
|
+
parseValue: (v) => z$1.coerce.boolean().parse(v),
|
|
66
|
+
serialize: (v) => Boolean(v),
|
|
67
|
+
parseLiteral: (ast) => {
|
|
68
|
+
if (ast.kind !== Kind.BOOLEAN) throw new TypeError("Invalid literal");
|
|
69
|
+
return ast.value;
|
|
58
70
|
},
|
|
59
|
-
jsonSchema: { type:
|
|
60
|
-
}),
|
|
61
|
-
ID: () => new
|
|
62
|
-
name:
|
|
63
|
-
description:
|
|
64
|
-
zod:
|
|
65
|
-
parseValue: (
|
|
66
|
-
serialize: (
|
|
67
|
-
parseLiteral: (
|
|
68
|
-
if (
|
|
69
|
-
return
|
|
71
|
+
jsonSchema: { type: "boolean" }
|
|
72
|
+
}),
|
|
73
|
+
ID: () => new FieldType({
|
|
74
|
+
name: "ID",
|
|
75
|
+
description: "Unvalidated id scalar",
|
|
76
|
+
zod: z$1.string(),
|
|
77
|
+
parseValue: (v) => z$1.string().parse(v),
|
|
78
|
+
serialize: (v) => String(v),
|
|
79
|
+
parseLiteral: (ast) => {
|
|
80
|
+
if (ast.kind !== Kind.STRING) throw new TypeError("Invalid literal");
|
|
81
|
+
return ast.value;
|
|
70
82
|
},
|
|
71
|
-
jsonSchema: { type:
|
|
83
|
+
jsonSchema: { type: "string" }
|
|
72
84
|
}),
|
|
73
|
-
JSON: () => new
|
|
74
|
-
name:
|
|
75
|
-
zod:
|
|
76
|
-
parseValue: (
|
|
77
|
-
serialize: (
|
|
85
|
+
JSON: () => new FieldType({
|
|
86
|
+
name: "JSON",
|
|
87
|
+
zod: z$1.any(),
|
|
88
|
+
parseValue: (v) => v,
|
|
89
|
+
serialize: (v) => v,
|
|
78
90
|
jsonSchema: {}
|
|
79
91
|
}),
|
|
80
|
-
JSONObject: () => new
|
|
81
|
-
name:
|
|
82
|
-
zod:
|
|
83
|
-
parseValue: (
|
|
84
|
-
serialize: (
|
|
85
|
-
jsonSchema: { type:
|
|
86
|
-
}),
|
|
87
|
-
Date: () => new
|
|
88
|
-
name:
|
|
89
|
-
zod:
|
|
90
|
-
parseValue: (
|
|
91
|
-
serialize: (
|
|
92
|
+
JSONObject: () => new FieldType({
|
|
93
|
+
name: "JSONObject",
|
|
94
|
+
zod: z$1.record(z$1.string(), z$1.any()),
|
|
95
|
+
parseValue: (v) => z$1.record(z$1.string(), z$1.any()).parse(v),
|
|
96
|
+
serialize: (v) => v ?? {},
|
|
97
|
+
jsonSchema: { type: "object" }
|
|
98
|
+
}),
|
|
99
|
+
Date: () => new FieldType({
|
|
100
|
+
name: "Date",
|
|
101
|
+
zod: z$1.date(),
|
|
102
|
+
parseValue: (v) => v instanceof Date ? v : new Date(String(v)),
|
|
103
|
+
serialize: (v) => v instanceof Date ? v.toISOString().split("T")[0] : String(v),
|
|
92
104
|
jsonSchema: {
|
|
93
|
-
type:
|
|
94
|
-
format:
|
|
105
|
+
type: "string",
|
|
106
|
+
format: "date"
|
|
95
107
|
}
|
|
96
108
|
}),
|
|
97
|
-
DateTime: () => new
|
|
98
|
-
name:
|
|
99
|
-
zod:
|
|
100
|
-
parseValue: (
|
|
101
|
-
serialize: (
|
|
109
|
+
DateTime: () => new FieldType({
|
|
110
|
+
name: "DateTime",
|
|
111
|
+
zod: z$1.date(),
|
|
112
|
+
parseValue: (v) => v instanceof Date ? v : new Date(String(v)),
|
|
113
|
+
serialize: (v) => {
|
|
114
|
+
return v instanceof Date ? v.toISOString() : String(v);
|
|
115
|
+
},
|
|
102
116
|
jsonSchema: {
|
|
103
|
-
type:
|
|
104
|
-
format:
|
|
117
|
+
type: "string",
|
|
118
|
+
format: "date-time"
|
|
105
119
|
}
|
|
106
120
|
}),
|
|
107
|
-
Time: () => new
|
|
108
|
-
name:
|
|
109
|
-
zod:
|
|
110
|
-
parseValue: (
|
|
111
|
-
serialize: (
|
|
121
|
+
Time: () => new FieldType({
|
|
122
|
+
name: "Time",
|
|
123
|
+
zod: z$1.string().regex(/^\d{2}:\d{2}(:\d{2})?$/),
|
|
124
|
+
parseValue: (v) => z$1.string().regex(/^\d{2}:\d{2}(:\d{2})?$/).parse(v),
|
|
125
|
+
serialize: (v) => String(v),
|
|
112
126
|
jsonSchema: {
|
|
113
|
-
type:
|
|
114
|
-
pattern:
|
|
127
|
+
type: "string",
|
|
128
|
+
pattern: "^\\d{2}:\\d{2}(:\\d{2})?$"
|
|
115
129
|
}
|
|
116
130
|
}),
|
|
117
|
-
EmailAddress: () => new
|
|
118
|
-
name:
|
|
119
|
-
zod:
|
|
120
|
-
parseValue: (
|
|
121
|
-
serialize: (
|
|
131
|
+
EmailAddress: () => new FieldType({
|
|
132
|
+
name: "EmailAddress",
|
|
133
|
+
zod: z$1.string().email(),
|
|
134
|
+
parseValue: (v) => z$1.string().email().parse(v),
|
|
135
|
+
serialize: (v) => String(v),
|
|
122
136
|
jsonSchema: {
|
|
123
|
-
type:
|
|
124
|
-
format:
|
|
137
|
+
type: "string",
|
|
138
|
+
format: "email"
|
|
125
139
|
}
|
|
126
140
|
}),
|
|
127
|
-
URL: () => new
|
|
128
|
-
name:
|
|
129
|
-
zod:
|
|
130
|
-
parseValue: (
|
|
131
|
-
serialize: (
|
|
141
|
+
URL: () => new FieldType({
|
|
142
|
+
name: "URL",
|
|
143
|
+
zod: z$1.string().url(),
|
|
144
|
+
parseValue: (v) => z$1.string().url().parse(v),
|
|
145
|
+
serialize: (v) => String(v),
|
|
132
146
|
jsonSchema: {
|
|
133
|
-
type:
|
|
134
|
-
format:
|
|
147
|
+
type: "string",
|
|
148
|
+
format: "uri"
|
|
135
149
|
}
|
|
136
150
|
}),
|
|
137
|
-
PhoneNumber: () => new
|
|
138
|
-
name:
|
|
139
|
-
zod:
|
|
140
|
-
parseValue: (
|
|
141
|
-
serialize: (
|
|
151
|
+
PhoneNumber: () => new FieldType({
|
|
152
|
+
name: "PhoneNumber",
|
|
153
|
+
zod: z$1.string().regex(phoneRegex),
|
|
154
|
+
parseValue: (v) => z$1.string().regex(phoneRegex).parse(v),
|
|
155
|
+
serialize: (v) => String(v),
|
|
142
156
|
jsonSchema: {
|
|
143
|
-
type:
|
|
144
|
-
pattern:
|
|
157
|
+
type: "string",
|
|
158
|
+
pattern: phoneRegex.source
|
|
145
159
|
}
|
|
146
160
|
}),
|
|
147
|
-
NonEmptyString: () => new
|
|
148
|
-
name:
|
|
149
|
-
zod:
|
|
150
|
-
parseValue: (
|
|
151
|
-
serialize: (
|
|
161
|
+
NonEmptyString: () => new FieldType({
|
|
162
|
+
name: "NonEmptyString",
|
|
163
|
+
zod: z$1.string().min(1),
|
|
164
|
+
parseValue: (v) => z$1.string().min(1).parse(v),
|
|
165
|
+
serialize: (v) => String(v),
|
|
152
166
|
jsonSchema: {
|
|
153
|
-
type:
|
|
167
|
+
type: "string",
|
|
154
168
|
minLength: 1
|
|
155
169
|
}
|
|
156
170
|
}),
|
|
157
|
-
Locale: () => new
|
|
158
|
-
name:
|
|
159
|
-
zod:
|
|
160
|
-
parseValue: (
|
|
161
|
-
serialize: (
|
|
171
|
+
Locale: () => new FieldType({
|
|
172
|
+
name: "Locale",
|
|
173
|
+
zod: z$1.string().regex(localeRegex),
|
|
174
|
+
parseValue: (v) => z$1.string().regex(localeRegex).parse(v),
|
|
175
|
+
serialize: (v) => String(v),
|
|
162
176
|
jsonSchema: {
|
|
163
|
-
type:
|
|
164
|
-
pattern:
|
|
177
|
+
type: "string",
|
|
178
|
+
pattern: localeRegex.source
|
|
165
179
|
}
|
|
166
180
|
}),
|
|
167
|
-
TimeZone: () => new
|
|
168
|
-
name:
|
|
169
|
-
zod:
|
|
170
|
-
parseValue: (
|
|
171
|
-
serialize: (
|
|
181
|
+
TimeZone: () => new FieldType({
|
|
182
|
+
name: "TimeZone",
|
|
183
|
+
zod: z$1.string().regex(timezoneRegex),
|
|
184
|
+
parseValue: (v) => z$1.string().regex(timezoneRegex).parse(v),
|
|
185
|
+
serialize: (v) => String(v),
|
|
172
186
|
jsonSchema: {
|
|
173
|
-
type:
|
|
174
|
-
pattern:
|
|
187
|
+
type: "string",
|
|
188
|
+
pattern: timezoneRegex.source
|
|
175
189
|
}
|
|
176
190
|
}),
|
|
177
|
-
Latitude: () => new
|
|
178
|
-
name:
|
|
179
|
-
zod:
|
|
180
|
-
parseValue: (
|
|
181
|
-
serialize: (
|
|
191
|
+
Latitude: () => new FieldType({
|
|
192
|
+
name: "Latitude",
|
|
193
|
+
zod: z$1.number().min(latMin).max(latMax),
|
|
194
|
+
parseValue: (v) => z$1.coerce.number().min(latMin).max(latMax).parse(v),
|
|
195
|
+
serialize: (v) => Number(v),
|
|
182
196
|
jsonSchema: {
|
|
183
|
-
type:
|
|
184
|
-
minimum:
|
|
185
|
-
maximum:
|
|
197
|
+
type: "number",
|
|
198
|
+
minimum: latMin,
|
|
199
|
+
maximum: latMax
|
|
186
200
|
}
|
|
187
201
|
}),
|
|
188
|
-
Longitude: () => new
|
|
189
|
-
name:
|
|
190
|
-
zod:
|
|
191
|
-
parseValue: (
|
|
192
|
-
serialize: (
|
|
202
|
+
Longitude: () => new FieldType({
|
|
203
|
+
name: "Longitude",
|
|
204
|
+
zod: z$1.number().min(lonMin).max(lonMax),
|
|
205
|
+
parseValue: (v) => z$1.coerce.number().min(lonMin).max(lonMax).parse(v),
|
|
206
|
+
serialize: (v) => Number(v),
|
|
193
207
|
jsonSchema: {
|
|
194
|
-
type:
|
|
195
|
-
minimum:
|
|
196
|
-
maximum:
|
|
208
|
+
type: "number",
|
|
209
|
+
minimum: lonMin,
|
|
210
|
+
maximum: lonMax
|
|
197
211
|
}
|
|
198
212
|
}),
|
|
199
|
-
Currency: () => new
|
|
200
|
-
name:
|
|
201
|
-
zod:
|
|
202
|
-
parseValue: (
|
|
203
|
-
serialize: (
|
|
213
|
+
Currency: () => new FieldType({
|
|
214
|
+
name: "Currency",
|
|
215
|
+
zod: z$1.string().regex(currencyRegex),
|
|
216
|
+
parseValue: (v) => z$1.string().regex(currencyRegex).parse(v),
|
|
217
|
+
serialize: (v) => String(v),
|
|
204
218
|
jsonSchema: {
|
|
205
|
-
type:
|
|
206
|
-
pattern:
|
|
219
|
+
type: "string",
|
|
220
|
+
pattern: currencyRegex.source
|
|
207
221
|
}
|
|
208
222
|
}),
|
|
209
|
-
CountryCode: () => new
|
|
210
|
-
name:
|
|
211
|
-
zod:
|
|
212
|
-
parseValue: (
|
|
213
|
-
serialize: (
|
|
223
|
+
CountryCode: () => new FieldType({
|
|
224
|
+
name: "CountryCode",
|
|
225
|
+
zod: z$1.string().regex(countryRegex),
|
|
226
|
+
parseValue: (v) => z$1.string().regex(countryRegex).parse(v),
|
|
227
|
+
serialize: (v) => String(v),
|
|
214
228
|
jsonSchema: {
|
|
215
|
-
type:
|
|
216
|
-
pattern:
|
|
229
|
+
type: "string",
|
|
230
|
+
pattern: countryRegex.source
|
|
217
231
|
}
|
|
218
232
|
})
|
|
219
233
|
};
|
|
220
234
|
|
|
221
235
|
//#endregion
|
|
222
|
-
export {
|
|
236
|
+
export { ScalarTypeEnum };
|
|
@@ -1,23 +1,34 @@
|
|
|
1
1
|
import "./EnumType.js";
|
|
2
2
|
import "./FieldType.js";
|
|
3
|
-
import * as
|
|
3
|
+
import * as z$1 from "zod";
|
|
4
4
|
|
|
5
5
|
//#region ../../libs/contracts/dist/schema/dist/SchemaModel.js
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
/**
|
|
7
|
+
* Named object model built from FieldType/EnumType/SchemaModel fields.
|
|
8
|
+
* Provides zod and GraphQL input helpers, and supports arrays/optional fields.
|
|
9
|
+
*/
|
|
10
|
+
var SchemaModel = class {
|
|
11
|
+
constructor(config) {
|
|
12
|
+
this.config = config;
|
|
9
13
|
}
|
|
14
|
+
/**
|
|
15
|
+
* Build a typed ZodObject from the model fields, preserving each field's
|
|
16
|
+
* Zod schema and optionality at the type level when possible.
|
|
17
|
+
*/
|
|
10
18
|
getZod() {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
19
|
+
const shape = Object.entries(this.config.fields).reduce((acc, [key, def]) => {
|
|
20
|
+
const base = def.type.getZod();
|
|
21
|
+
const withArray = def.isArray ? z$1.array(base) : base;
|
|
22
|
+
acc[key] = def.isOptional ? withArray.optional() : withArray;
|
|
23
|
+
return acc;
|
|
14
24
|
}, {});
|
|
15
|
-
return
|
|
25
|
+
return z$1.object(shape);
|
|
16
26
|
}
|
|
27
|
+
/** Input object name for GraphQL builder adapters. */
|
|
17
28
|
getPothosInput() {
|
|
18
29
|
return this.config.name;
|
|
19
30
|
}
|
|
20
31
|
};
|
|
21
32
|
|
|
22
33
|
//#endregion
|
|
23
|
-
export {
|
|
34
|
+
export { SchemaModel };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import
|
|
1
|
+
import z from "zod";
|
|
@@ -1,25 +1,34 @@
|
|
|
1
1
|
//#region ../../libs/contracts/dist/spec.js
|
|
2
|
-
|
|
3
|
-
|
|
2
|
+
/**
|
|
3
|
+
* Helper to define a Command (write operation).
|
|
4
|
+
* Sets `kind: 'command'` and defaults `idempotent: false`.
|
|
5
|
+
*/
|
|
6
|
+
const defineCommand = (spec) => ({
|
|
7
|
+
...spec,
|
|
4
8
|
meta: {
|
|
5
|
-
...
|
|
6
|
-
kind:
|
|
9
|
+
...spec.meta,
|
|
10
|
+
kind: "command"
|
|
7
11
|
},
|
|
8
12
|
policy: {
|
|
9
|
-
...
|
|
10
|
-
idempotent:
|
|
13
|
+
...spec.policy,
|
|
14
|
+
idempotent: spec.policy?.["policy"]?.idempotent ?? false
|
|
11
15
|
}
|
|
12
|
-
})
|
|
13
|
-
|
|
16
|
+
});
|
|
17
|
+
/**
|
|
18
|
+
* Helper to define a Query (read-only operation).
|
|
19
|
+
* Sets `kind: 'query'` and forces `idempotent: true`.
|
|
20
|
+
*/
|
|
21
|
+
const defineQuery = (spec) => ({
|
|
22
|
+
...spec,
|
|
14
23
|
meta: {
|
|
15
|
-
...
|
|
16
|
-
kind:
|
|
24
|
+
...spec.meta,
|
|
25
|
+
kind: "query"
|
|
17
26
|
},
|
|
18
27
|
policy: {
|
|
19
|
-
...
|
|
20
|
-
idempotent:
|
|
28
|
+
...spec.policy,
|
|
29
|
+
idempotent: true
|
|
21
30
|
}
|
|
22
31
|
});
|
|
23
32
|
|
|
24
33
|
//#endregion
|
|
25
|
-
export {
|
|
34
|
+
export { defineCommand, defineQuery };
|
|
@@ -1,40 +1,56 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as z$1 from "zod";
|
|
2
2
|
import { GraphQLEnumType } from "graphql";
|
|
3
3
|
|
|
4
4
|
//#region ../../libs/schema/dist/EnumType.js
|
|
5
|
-
|
|
5
|
+
/**
|
|
6
|
+
* Strongly-typed string enum wrapper with one source of truth for zod, GraphQL, and JSON Schema.
|
|
7
|
+
*/
|
|
8
|
+
var EnumType = class {
|
|
6
9
|
name;
|
|
7
10
|
values;
|
|
8
11
|
gqlEnum;
|
|
9
|
-
constructor(
|
|
10
|
-
this.name =
|
|
12
|
+
constructor(name, values) {
|
|
13
|
+
this.name = name;
|
|
14
|
+
this.values = values;
|
|
15
|
+
this.gqlEnum = new GraphQLEnumType({
|
|
11
16
|
name: this.name,
|
|
12
|
-
values: Object.fromEntries(
|
|
17
|
+
values: Object.fromEntries(values.map((v) => [v, { value: v }]))
|
|
13
18
|
});
|
|
14
19
|
}
|
|
20
|
+
/** Enum type name (used by GraphQL and JSON Schema). */
|
|
15
21
|
getName() {
|
|
16
22
|
return this.name;
|
|
17
23
|
}
|
|
24
|
+
/** Returns the literal tuple of allowed values. */
|
|
18
25
|
getEnumValues() {
|
|
19
26
|
return this.values;
|
|
20
27
|
}
|
|
28
|
+
/** GraphQL enum instance suitable for Pothos or vanilla GraphQL schemas. */
|
|
21
29
|
getPothos() {
|
|
22
30
|
return this.gqlEnum;
|
|
23
31
|
}
|
|
32
|
+
/** zod schema representing this enum. */
|
|
24
33
|
getZod() {
|
|
25
|
-
return
|
|
34
|
+
return z$1.enum(this.values);
|
|
26
35
|
}
|
|
36
|
+
/** Minimal JSON representation (alias of getJsonSchema). */
|
|
27
37
|
getJson() {
|
|
28
38
|
return {
|
|
29
|
-
type:
|
|
39
|
+
type: "string",
|
|
30
40
|
enum: this.values
|
|
31
41
|
};
|
|
32
42
|
}
|
|
43
|
+
/** JSON Schema for this enum. */
|
|
33
44
|
getJsonSchema() {
|
|
34
45
|
return this.getJson();
|
|
35
46
|
}
|
|
36
47
|
};
|
|
37
|
-
|
|
48
|
+
/**
|
|
49
|
+
* Helper to define an EnumType.
|
|
50
|
+
* @param name Display/type name used across GraphQL and JSON Schema
|
|
51
|
+
* @param values Literal tuple of allowed string values (at least one)
|
|
52
|
+
*/
|
|
53
|
+
const defineEnum = (name, values) => new EnumType(name, values);
|
|
38
54
|
|
|
39
55
|
//#endregion
|
|
40
|
-
export {
|
|
56
|
+
export { EnumType, defineEnum };
|
|
@@ -2,38 +2,48 @@ import "zod";
|
|
|
2
2
|
import { GraphQLScalarType } from "graphql";
|
|
3
3
|
|
|
4
4
|
//#region ../../libs/schema/dist/FieldType.js
|
|
5
|
-
|
|
5
|
+
/**
|
|
6
|
+
* GraphQL scalar wrapper that carries zod and JSON Schema metadata.
|
|
7
|
+
*
|
|
8
|
+
* TInternal is the runtime representation; TExternal is the GraphQL output.
|
|
9
|
+
*/
|
|
10
|
+
var FieldType = class extends GraphQLScalarType {
|
|
6
11
|
zodSchema;
|
|
7
12
|
jsonSchemaDef;
|
|
8
|
-
constructor(
|
|
9
|
-
super(
|
|
13
|
+
constructor(config) {
|
|
14
|
+
super(config);
|
|
15
|
+
this.zodSchema = config.zod;
|
|
16
|
+
this.jsonSchemaDef = config.jsonSchema;
|
|
10
17
|
}
|
|
18
|
+
/** Return the attached zod schema for validation. */
|
|
11
19
|
getZod() {
|
|
12
20
|
return this.zodSchema;
|
|
13
21
|
}
|
|
22
|
+
/** GraphQL scalar instance usable by Pothos or vanilla GraphQL. */
|
|
14
23
|
getPothos() {
|
|
15
24
|
return this;
|
|
16
25
|
}
|
|
26
|
+
/** Return the JSON Schema (evaluates factory if provided). */
|
|
17
27
|
getJson() {
|
|
18
|
-
return typeof this.jsonSchemaDef
|
|
28
|
+
return typeof this.jsonSchemaDef === "function" ? this.jsonSchemaDef() : this.jsonSchemaDef;
|
|
19
29
|
}
|
|
20
30
|
getJsonSchemaDef() {
|
|
21
31
|
return this.jsonSchemaDef;
|
|
22
32
|
}
|
|
23
33
|
getJsonSchema() {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
if (Array.isArray(
|
|
27
|
-
if (
|
|
28
|
-
|
|
29
|
-
for (
|
|
30
|
-
return
|
|
34
|
+
const deepResolve = (v) => {
|
|
35
|
+
const value = typeof v === "function" ? v() : v;
|
|
36
|
+
if (Array.isArray(value)) return value.map((item) => deepResolve(item));
|
|
37
|
+
if (value && typeof value === "object") {
|
|
38
|
+
const obj = {};
|
|
39
|
+
for (const [k, val] of Object.entries(value)) obj[k] = deepResolve(val);
|
|
40
|
+
return obj;
|
|
31
41
|
}
|
|
32
|
-
return
|
|
42
|
+
return value;
|
|
33
43
|
};
|
|
34
|
-
return
|
|
44
|
+
return deepResolve(this.getJson());
|
|
35
45
|
}
|
|
36
46
|
};
|
|
37
47
|
|
|
38
48
|
//#endregion
|
|
39
|
-
export {
|
|
49
|
+
export { FieldType };
|