syncorejs 0.2.0 → 0.2.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.
Files changed (135) hide show
  1. package/README.md +2 -1
  2. package/dist/_vendor/cli/app.d.mts.map +1 -1
  3. package/dist/_vendor/cli/app.mjs +323 -42
  4. package/dist/_vendor/cli/app.mjs.map +1 -1
  5. package/dist/_vendor/cli/context.mjs +27 -9
  6. package/dist/_vendor/cli/context.mjs.map +1 -1
  7. package/dist/_vendor/cli/doctor.mjs +513 -46
  8. package/dist/_vendor/cli/doctor.mjs.map +1 -1
  9. package/dist/_vendor/cli/messages.mjs +5 -4
  10. package/dist/_vendor/cli/messages.mjs.map +1 -1
  11. package/dist/_vendor/cli/project.mjs +110 -12
  12. package/dist/_vendor/cli/project.mjs.map +1 -1
  13. package/dist/_vendor/cli/render.mjs +57 -9
  14. package/dist/_vendor/cli/render.mjs.map +1 -1
  15. package/dist/_vendor/cli/targets.mjs +4 -3
  16. package/dist/_vendor/cli/targets.mjs.map +1 -1
  17. package/dist/_vendor/core/cli.d.mts +13 -3
  18. package/dist/_vendor/core/cli.d.mts.map +1 -1
  19. package/dist/_vendor/core/cli.mjs +242 -91
  20. package/dist/_vendor/core/cli.mjs.map +1 -1
  21. package/dist/_vendor/core/devtools-auth.mjs +60 -0
  22. package/dist/_vendor/core/devtools-auth.mjs.map +1 -0
  23. package/dist/_vendor/core/index.d.mts +5 -3
  24. package/dist/_vendor/core/index.mjs +22 -2
  25. package/dist/_vendor/core/index.mjs.map +1 -1
  26. package/dist/_vendor/core/runtime/components.d.mts +111 -0
  27. package/dist/_vendor/core/runtime/components.d.mts.map +1 -0
  28. package/dist/_vendor/core/runtime/components.mjs +186 -0
  29. package/dist/_vendor/core/runtime/components.mjs.map +1 -0
  30. package/dist/_vendor/core/runtime/devtools.d.mts +4 -4
  31. package/dist/_vendor/core/runtime/devtools.d.mts.map +1 -1
  32. package/dist/_vendor/core/runtime/devtools.mjs +52 -41
  33. package/dist/_vendor/core/runtime/devtools.mjs.map +1 -1
  34. package/dist/_vendor/core/runtime/functions.d.mts +10 -10
  35. package/dist/_vendor/core/runtime/functions.d.mts.map +1 -1
  36. package/dist/_vendor/core/runtime/functions.mjs +2 -2
  37. package/dist/_vendor/core/runtime/functions.mjs.map +1 -1
  38. package/dist/_vendor/core/runtime/internal/engines/devtoolsEngine.mjs +77 -0
  39. package/dist/_vendor/core/runtime/internal/engines/devtoolsEngine.mjs.map +1 -0
  40. package/dist/_vendor/core/runtime/internal/engines/executionEngine.mjs +617 -0
  41. package/dist/_vendor/core/runtime/internal/engines/executionEngine.mjs.map +1 -0
  42. package/dist/_vendor/core/runtime/internal/engines/reactivityEngine.mjs +186 -0
  43. package/dist/_vendor/core/runtime/internal/engines/reactivityEngine.mjs.map +1 -0
  44. package/dist/_vendor/core/runtime/internal/engines/schedulerEngine.mjs +220 -0
  45. package/dist/_vendor/core/runtime/internal/engines/schedulerEngine.mjs.map +1 -0
  46. package/dist/_vendor/core/runtime/internal/engines/schemaEngine.mjs +203 -0
  47. package/dist/_vendor/core/runtime/internal/engines/schemaEngine.mjs.map +1 -0
  48. package/dist/_vendor/core/runtime/internal/engines/shared.mjs +177 -0
  49. package/dist/_vendor/core/runtime/internal/engines/shared.mjs.map +1 -0
  50. package/dist/_vendor/core/runtime/internal/engines/storageEngine.mjs +144 -0
  51. package/dist/_vendor/core/runtime/internal/engines/storageEngine.mjs.map +1 -0
  52. package/dist/_vendor/core/runtime/internal/runtimeKernel.mjs +220 -0
  53. package/dist/_vendor/core/runtime/internal/runtimeKernel.mjs.map +1 -0
  54. package/dist/_vendor/core/runtime/internal/runtimeStatus.mjs +32 -0
  55. package/dist/_vendor/core/runtime/internal/runtimeStatus.mjs.map +1 -0
  56. package/dist/_vendor/core/runtime/internal/systemMeta.mjs +61 -0
  57. package/dist/_vendor/core/runtime/internal/systemMeta.mjs.map +1 -0
  58. package/dist/_vendor/core/runtime/internal/transactionCoordinator.mjs +37 -0
  59. package/dist/_vendor/core/runtime/internal/transactionCoordinator.mjs.map +1 -0
  60. package/dist/_vendor/core/runtime/runtime.d.mts +159 -205
  61. package/dist/_vendor/core/runtime/runtime.d.mts.map +1 -1
  62. package/dist/_vendor/core/runtime/runtime.mjs +16 -1371
  63. package/dist/_vendor/core/runtime/runtime.mjs.map +1 -1
  64. package/dist/_vendor/core/transport.d.mts +111 -0
  65. package/dist/_vendor/core/transport.d.mts.map +1 -0
  66. package/dist/_vendor/core/transport.mjs +419 -0
  67. package/dist/_vendor/core/transport.mjs.map +1 -0
  68. package/dist/_vendor/devtools-protocol/index.d.ts +39 -1
  69. package/dist/_vendor/devtools-protocol/index.d.ts.map +1 -1
  70. package/dist/_vendor/devtools-protocol/index.js +25 -9
  71. package/dist/_vendor/devtools-protocol/index.js.map +1 -1
  72. package/dist/_vendor/next/index.d.ts +1 -1
  73. package/dist/_vendor/next/index.d.ts.map +1 -1
  74. package/dist/_vendor/next/index.js +31 -13
  75. package/dist/_vendor/next/index.js.map +1 -1
  76. package/dist/_vendor/platform-expo/index.d.ts +12 -12
  77. package/dist/_vendor/platform-expo/index.d.ts.map +1 -1
  78. package/dist/_vendor/platform-expo/index.js +4 -2
  79. package/dist/_vendor/platform-expo/index.js.map +1 -1
  80. package/dist/_vendor/platform-expo/react.d.ts.map +1 -1
  81. package/dist/_vendor/platform-expo/react.js +11 -10
  82. package/dist/_vendor/platform-expo/react.js.map +1 -1
  83. package/dist/_vendor/platform-node/index.d.mts +23 -19
  84. package/dist/_vendor/platform-node/index.d.mts.map +1 -1
  85. package/dist/_vendor/platform-node/index.mjs +13 -5
  86. package/dist/_vendor/platform-node/index.mjs.map +1 -1
  87. package/dist/_vendor/platform-node/ipc-react.d.mts.map +1 -1
  88. package/dist/_vendor/platform-node/ipc-react.mjs +15 -2
  89. package/dist/_vendor/platform-node/ipc-react.mjs.map +1 -1
  90. package/dist/_vendor/platform-node/ipc.d.mts +11 -35
  91. package/dist/_vendor/platform-node/ipc.d.mts.map +1 -1
  92. package/dist/_vendor/platform-node/ipc.mjs +3 -273
  93. package/dist/_vendor/platform-node/ipc.mjs.map +1 -1
  94. package/dist/_vendor/platform-web/external-change.d.ts +2 -1
  95. package/dist/_vendor/platform-web/external-change.d.ts.map +1 -1
  96. package/dist/_vendor/platform-web/external-change.js +2 -1
  97. package/dist/_vendor/platform-web/external-change.js.map +1 -1
  98. package/dist/_vendor/platform-web/index.d.ts +21 -21
  99. package/dist/_vendor/platform-web/index.d.ts.map +1 -1
  100. package/dist/_vendor/platform-web/index.js +44 -7
  101. package/dist/_vendor/platform-web/index.js.map +1 -1
  102. package/dist/_vendor/platform-web/react.d.ts.map +1 -1
  103. package/dist/_vendor/platform-web/react.js +29 -13
  104. package/dist/_vendor/platform-web/react.js.map +1 -1
  105. package/dist/_vendor/platform-web/worker.d.ts +11 -35
  106. package/dist/_vendor/platform-web/worker.d.ts.map +1 -1
  107. package/dist/_vendor/platform-web/worker.js +3 -267
  108. package/dist/_vendor/platform-web/worker.js.map +1 -1
  109. package/dist/_vendor/react/index.d.ts +36 -20
  110. package/dist/_vendor/react/index.d.ts.map +1 -1
  111. package/dist/_vendor/react/index.js +279 -57
  112. package/dist/_vendor/react/index.js.map +1 -1
  113. package/dist/_vendor/schema/definition.d.ts +48 -63
  114. package/dist/_vendor/schema/definition.d.ts.map +1 -1
  115. package/dist/_vendor/schema/definition.js +22 -39
  116. package/dist/_vendor/schema/definition.js.map +1 -1
  117. package/dist/_vendor/schema/index.d.ts +4 -4
  118. package/dist/_vendor/schema/index.js +2 -2
  119. package/dist/_vendor/schema/planner.d.ts +19 -2
  120. package/dist/_vendor/schema/planner.d.ts.map +1 -1
  121. package/dist/_vendor/schema/planner.js +79 -3
  122. package/dist/_vendor/schema/planner.js.map +1 -1
  123. package/dist/_vendor/schema/validators.d.ts +141 -121
  124. package/dist/_vendor/schema/validators.d.ts.map +1 -1
  125. package/dist/_vendor/schema/validators.js +300 -42
  126. package/dist/_vendor/schema/validators.js.map +1 -1
  127. package/dist/_vendor/svelte/index.d.ts +47 -19
  128. package/dist/_vendor/svelte/index.d.ts.map +1 -1
  129. package/dist/_vendor/svelte/index.js +250 -20
  130. package/dist/_vendor/svelte/index.js.map +1 -1
  131. package/dist/components.d.ts +2 -0
  132. package/dist/components.js +2 -0
  133. package/dist/index.d.ts +3 -2
  134. package/dist/index.js +2 -1
  135. package/package.json +8 -3
@@ -1,61 +1,132 @@
1
1
  //#region src/validators.ts
2
- var StringValidator = class {
3
- kind = "string";
2
+ var BaseValidator = class {
3
+ constructor(kind) {
4
+ this.kind = kind;
5
+ }
6
+ serialize(value, path = "value") {
7
+ return this.parse(value, path);
8
+ }
9
+ deserialize(value, path = "value") {
10
+ return this.parse(value, path);
11
+ }
12
+ };
13
+ var StringValidator = class extends BaseValidator {
14
+ constructor() {
15
+ super("string");
16
+ }
4
17
  parse(value, path = "value") {
5
18
  if (typeof value !== "string") throw new Error(`${path} must be a string.`);
6
19
  return value;
7
20
  }
21
+ describe() {
22
+ return { kind: "string" };
23
+ }
8
24
  };
9
- var NumberValidator = class {
10
- kind = "number";
25
+ var NumberValidator = class extends BaseValidator {
26
+ constructor() {
27
+ super("number");
28
+ }
11
29
  parse(value, path = "value") {
12
30
  if (typeof value !== "number" || Number.isNaN(value)) throw new Error(`${path} must be a number.`);
13
31
  return value;
14
32
  }
33
+ describe() {
34
+ return { kind: "number" };
35
+ }
15
36
  };
16
- var BooleanValidator = class {
17
- kind = "boolean";
37
+ var BooleanValidator = class extends BaseValidator {
38
+ constructor() {
39
+ super("boolean");
40
+ }
18
41
  parse(value, path = "value") {
19
42
  if (typeof value !== "boolean") throw new Error(`${path} must be a boolean.`);
20
43
  return value;
21
44
  }
45
+ describe() {
46
+ return { kind: "boolean" };
47
+ }
22
48
  };
23
- var NullValidator = class {
24
- kind = "null";
49
+ var NullValidator = class extends BaseValidator {
50
+ constructor() {
51
+ super("null");
52
+ }
25
53
  parse(value, path = "value") {
26
54
  if (value !== null) throw new Error(`${path} must be null.`);
27
55
  return null;
28
56
  }
57
+ describe() {
58
+ return { kind: "null" };
59
+ }
29
60
  };
30
- var AnyValidator = class {
31
- kind = "any";
61
+ var AnyValidator = class extends BaseValidator {
62
+ constructor() {
63
+ super("any");
64
+ }
32
65
  parse(value) {
33
66
  return value;
34
67
  }
68
+ describe() {
69
+ return { kind: "any" };
70
+ }
35
71
  };
36
- var LiteralValidator = class {
37
- kind = "literal";
72
+ var LiteralValidator = class extends BaseValidator {
38
73
  constructor(literalValue) {
74
+ super("literal");
39
75
  this.literalValue = literalValue;
40
76
  }
41
77
  parse(value, path = "value") {
42
78
  if (value !== this.literalValue) throw new Error(`${path} must equal ${String(this.literalValue)}.`);
43
79
  return this.literalValue;
44
80
  }
81
+ describe() {
82
+ return {
83
+ kind: "literal",
84
+ value: this.literalValue
85
+ };
86
+ }
87
+ };
88
+ var EnumValidator = class extends BaseValidator {
89
+ constructor(values) {
90
+ super("enum");
91
+ this.values = values;
92
+ }
93
+ parse(value, path = "value") {
94
+ if (typeof value !== "string" || !this.values.includes(value)) throw new Error(`${path} must be one of ${this.values.map((item) => JSON.stringify(item)).join(", ")}.`);
95
+ return value;
96
+ }
97
+ describe() {
98
+ return {
99
+ kind: "enum",
100
+ values: [...this.values]
101
+ };
102
+ }
45
103
  };
46
- var ArrayValidator = class {
47
- kind = "array";
104
+ var ArrayValidator = class extends BaseValidator {
48
105
  constructor(itemValidator) {
106
+ super("array");
49
107
  this.itemValidator = itemValidator;
50
108
  }
51
109
  parse(value, path = "value") {
52
110
  if (!Array.isArray(value)) throw new Error(`${path} must be an array.`);
53
111
  return value.map((item, index) => this.itemValidator.parse(item, `${path}[${index}]`));
54
112
  }
113
+ serialize(value, path = "value") {
114
+ return this.parse(value, path).map((item, index) => serializeValue(this.itemValidator, item, `${path}[${index}]`));
115
+ }
116
+ deserialize(value, path = "value") {
117
+ if (!Array.isArray(value)) throw new Error(`${path} must be an array.`);
118
+ return value.map((item, index) => deserializeValue(this.itemValidator, item, `${path}[${index}]`));
119
+ }
120
+ describe() {
121
+ return {
122
+ kind: "array",
123
+ item: describeValidator(this.itemValidator)
124
+ };
125
+ }
55
126
  };
56
- var ObjectValidator = class {
57
- kind = "object";
127
+ var ObjectValidator = class extends BaseValidator {
58
128
  constructor(shape) {
129
+ super("object");
59
130
  this.shape = shape;
60
131
  }
61
132
  parse(value, path = "value") {
@@ -68,59 +139,218 @@ var ObjectValidator = class {
68
139
  }
69
140
  return parsed;
70
141
  }
142
+ serialize(value, path = "value") {
143
+ const parsed = this.parse(value, path);
144
+ const serialized = {};
145
+ for (const [key, validator] of Object.entries(this.shape)) {
146
+ if (parsed[key] === void 0 && validator.kind === "optional") continue;
147
+ serialized[key] = serializeValue(validator, parsed[key], `${path}.${key}`);
148
+ }
149
+ return serialized;
150
+ }
151
+ deserialize(value, path = "value") {
152
+ if (typeof value !== "object" || value === null || Array.isArray(value)) throw new Error(`${path} must be an object.`);
153
+ const source = value;
154
+ const parsed = {};
155
+ for (const [key, validator] of Object.entries(this.shape)) {
156
+ if (validator.kind === "optional" && source[key] === void 0) continue;
157
+ parsed[key] = deserializeValue(validator, source[key], `${path}.${key}`);
158
+ }
159
+ return parsed;
160
+ }
161
+ describe() {
162
+ return {
163
+ kind: "object",
164
+ shape: Object.fromEntries(Object.entries(this.shape).map(([key, validator]) => [key, {
165
+ validator: validator.kind === "optional" ? describeValidator(validator.inner) : describeValidator(validator),
166
+ optional: validator.kind === "optional"
167
+ }]))
168
+ };
169
+ }
71
170
  };
72
- var IdValidator = class {
73
- kind = "id";
171
+ var IdValidator = class extends BaseValidator {
74
172
  constructor(tableName) {
173
+ super("id");
75
174
  this.tableName = tableName;
76
175
  }
77
176
  parse(value, path = "value") {
78
177
  if (typeof value !== "string" || value.length === 0) throw new Error(`${path} must be a non-empty id string.`);
79
178
  return value;
80
179
  }
180
+ describe() {
181
+ return {
182
+ kind: "id",
183
+ tableName: this.tableName
184
+ };
185
+ }
81
186
  };
82
- var OptionalValidator = class {
83
- kind = "optional";
187
+ var OptionalValidator = class extends BaseValidator {
84
188
  constructor(inner) {
189
+ super("optional");
85
190
  this.inner = inner;
86
191
  }
87
192
  parse(value, path = "value") {
88
193
  if (value === void 0) return;
89
194
  return this.inner.parse(value, path);
90
195
  }
196
+ serialize(value, path = "value") {
197
+ if (value === void 0) return;
198
+ return serializeValue(this.inner, value, path);
199
+ }
200
+ deserialize(value, path = "value") {
201
+ if (value === void 0) return;
202
+ return deserializeValue(this.inner, value, path);
203
+ }
204
+ describe() {
205
+ return {
206
+ kind: "optional",
207
+ inner: describeValidator(this.inner)
208
+ };
209
+ }
210
+ };
211
+ var RecordValidator = class extends BaseValidator {
212
+ constructor(keyValidator, valueValidator) {
213
+ super("record");
214
+ this.keyValidator = keyValidator;
215
+ this.valueValidator = valueValidator;
216
+ }
217
+ parse(value, path = "value") {
218
+ if (typeof value !== "object" || value === null || Array.isArray(value)) throw new Error(`${path} must be an object.`);
219
+ const source = value;
220
+ const parsed = {};
221
+ for (const [key, item] of Object.entries(source)) {
222
+ const parsedKey = this.keyValidator.parse(key, `${path}.{key}`);
223
+ parsed[parsedKey] = this.valueValidator.parse(item, `${path}.${key}`);
224
+ }
225
+ return parsed;
226
+ }
227
+ serialize(value, path = "value") {
228
+ const parsed = this.parse(value, path);
229
+ const serialized = {};
230
+ for (const [key, item] of Object.entries(parsed)) serialized[key] = serializeValue(this.valueValidator, item, `${path}.${key}`);
231
+ return serialized;
232
+ }
233
+ deserialize(value, path = "value") {
234
+ if (typeof value !== "object" || value === null || Array.isArray(value)) throw new Error(`${path} must be an object.`);
235
+ const source = value;
236
+ const parsed = {};
237
+ for (const [key, item] of Object.entries(source)) {
238
+ const parsedKey = this.keyValidator.parse(key, `${path}.{key}`);
239
+ parsed[parsedKey] = deserializeValue(this.valueValidator, item, `${path}.${key}`);
240
+ }
241
+ return parsed;
242
+ }
243
+ describe() {
244
+ return {
245
+ kind: "record",
246
+ key: describeValidator(this.keyValidator),
247
+ value: describeValidator(this.valueValidator)
248
+ };
249
+ }
250
+ };
251
+ var UnionValidator = class extends BaseValidator {
252
+ constructor(members) {
253
+ super("union");
254
+ this.members = members;
255
+ }
256
+ parse(value, path = "value") {
257
+ for (const member of this.members) try {
258
+ return member.parse(value, path);
259
+ } catch {
260
+ continue;
261
+ }
262
+ throw new Error(`${path} did not match any union member.`);
263
+ }
264
+ serialize(value, path = "value") {
265
+ for (const member of this.members) try {
266
+ return serializeValue(member, member.parse(value, path), path);
267
+ } catch {
268
+ continue;
269
+ }
270
+ throw new Error(`${path} did not match any union member.`);
271
+ }
272
+ deserialize(value, path = "value") {
273
+ for (const member of this.members) try {
274
+ return deserializeValue(member, value, path);
275
+ } catch {
276
+ continue;
277
+ }
278
+ throw new Error(`${path} did not match any union member.`);
279
+ }
280
+ describe() {
281
+ return {
282
+ kind: "union",
283
+ members: this.members.map((member) => describeValidator(member))
284
+ };
285
+ }
286
+ };
287
+ var CodecValidator = class extends BaseValidator {
288
+ constructor(valueValidator, storageValidator, codec) {
289
+ super("codec");
290
+ this.valueValidator = valueValidator;
291
+ this.storageValidator = storageValidator;
292
+ this.codec = codec;
293
+ }
294
+ parse(value, path = "value") {
295
+ return this.valueValidator.parse(value, path);
296
+ }
297
+ serialize(value, path = "value") {
298
+ const parsed = this.valueValidator.parse(value, path);
299
+ const serialized = this.codec.serialize(parsed);
300
+ return serializeValue(this.storageValidator, this.storageValidator.parse(serialized, path), path);
301
+ }
302
+ deserialize(value, path = "value") {
303
+ const parsedStored = deserializeValue(this.storageValidator, value, path);
304
+ return this.valueValidator.parse(this.codec.deserialize(parsedStored), path);
305
+ }
306
+ describe() {
307
+ return {
308
+ kind: "codec",
309
+ value: describeValidator(this.valueValidator),
310
+ storage: describeValidator(this.storageValidator)
311
+ };
312
+ }
91
313
  };
92
- function isValidator(value) {
93
- return typeof value.parse === "function";
94
- }
95
- function ensureObjectValidator(value) {
96
- if (isValidator(value)) return value;
97
- return new ObjectValidator(value);
98
- }
99
314
  /**
100
- * Build runtime validators for schemas, function args, and return values.
101
- *
102
- * @example
103
- * ```ts
104
- * defineTable({
105
- * text: v.string(),
106
- * done: v.boolean(),
107
- * ownerId: v.optional(v.id("users"))
108
- * });
109
- * ```
315
+ * Primary schema builder namespace for Syncore's data-model DSL.
110
316
  */
111
- const v = {
317
+ const s = {
112
318
  string: () => new StringValidator(),
113
319
  number: () => new NumberValidator(),
114
320
  boolean: () => new BooleanValidator(),
115
321
  null: () => new NullValidator(),
116
322
  any: () => new AnyValidator(),
117
323
  literal: (literalValue) => new LiteralValidator(literalValue),
324
+ enum: (values) => new EnumValidator(values),
118
325
  array: (itemValidator) => new ArrayValidator(itemValidator),
119
326
  object: (shape) => new ObjectValidator(shape),
120
327
  id: (tableName) => new IdValidator(tableName),
121
- optional: (inner) => new OptionalValidator(inner)
328
+ optional: (inner) => new OptionalValidator(inner),
329
+ record: (keyValidator, valueValidator) => new RecordValidator(keyValidator, valueValidator),
330
+ union: (...members) => new UnionValidator(members),
331
+ nullable: (inner) => new UnionValidator([inner, new NullValidator()]),
332
+ codec: (valueValidator, config) => new CodecValidator(valueValidator, config.storage, {
333
+ serialize: (value) => config.serialize(value),
334
+ deserialize: (value) => config.deserialize(value)
335
+ })
122
336
  };
337
+ function isValidator(value) {
338
+ return typeof value.parse === "function";
339
+ }
340
+ function ensureObjectValidator(value) {
341
+ if (isValidator(value)) return value;
342
+ return new ObjectValidator(value);
343
+ }
344
+ function serializeValue(validator, value, path = "value") {
345
+ if (validator.serialize) return validator.serialize(value, path);
346
+ return value;
347
+ }
348
+ function deserializeValue(validator, value, path = "value") {
349
+ if (validator.deserialize) return validator.deserialize(value, path);
350
+ return validator.parse(value, path);
351
+ }
123
352
  function describeValidator(validator) {
353
+ if (validator.describe) return validator.describe();
124
354
  switch (validator.kind) {
125
355
  case "string":
126
356
  case "number":
@@ -131,17 +361,40 @@ function describeValidator(validator) {
131
361
  kind: "literal",
132
362
  value: validator.literalValue
133
363
  };
364
+ case "enum": return {
365
+ kind: "enum",
366
+ values: [...validator.values]
367
+ };
134
368
  case "array": return {
135
369
  kind: "array",
136
370
  item: describeValidator(validator.itemValidator)
137
371
  };
138
372
  case "object": {
139
- const objectValidator = validator;
373
+ const objectShape = "shape" in validator ? validator.shape : {};
140
374
  return {
141
375
  kind: "object",
142
- shape: Object.fromEntries(Object.entries(objectValidator.shape).map(([key, nested]) => [key, describeValidator(nested)]))
376
+ shape: Object.fromEntries(Object.entries(objectShape).map(([key, field]) => {
377
+ if (isValidator(field)) return [key, {
378
+ validator: field.kind === "optional" ? describeValidator(field.inner) : describeValidator(field),
379
+ optional: field.kind === "optional"
380
+ }];
381
+ const metadata = field;
382
+ return [key, {
383
+ validator: metadata.validator ?? metadata.field ?? { kind: "any" },
384
+ optional: metadata.optional ?? false
385
+ }];
386
+ }))
143
387
  };
144
388
  }
389
+ case "record": return {
390
+ kind: "record",
391
+ key: describeValidator(validator.keyValidator),
392
+ value: describeValidator(validator.valueValidator)
393
+ };
394
+ case "union": return {
395
+ kind: "union",
396
+ members: validator.members.map((member) => describeValidator(member))
397
+ };
145
398
  case "id": return {
146
399
  kind: "id",
147
400
  tableName: validator.tableName
@@ -150,9 +403,14 @@ function describeValidator(validator) {
150
403
  kind: "optional",
151
404
  inner: describeValidator(validator.inner)
152
405
  };
406
+ case "codec": return {
407
+ kind: "codec",
408
+ value: describeValidator(validator.valueValidator),
409
+ storage: describeValidator(validator.storageValidator)
410
+ };
153
411
  }
154
412
  }
155
413
  //#endregion
156
- export { AnyValidator, ArrayValidator, BooleanValidator, IdValidator, LiteralValidator, NullValidator, NumberValidator, ObjectValidator, OptionalValidator, StringValidator, describeValidator, ensureObjectValidator, v };
414
+ export { AnyValidator, ArrayValidator, BooleanValidator, CodecValidator, EnumValidator, IdValidator, LiteralValidator, NullValidator, NumberValidator, ObjectValidator, OptionalValidator, RecordValidator, StringValidator, UnionValidator, describeValidator, deserializeValue, ensureObjectValidator, isValidator, s, serializeValue };
157
415
 
158
416
  //# sourceMappingURL=validators.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","names":[],"sources":["../src/validators.ts"],"sourcesContent":["export type ValidatorKind =\n | \"string\"\n | \"number\"\n | \"boolean\"\n | \"literal\"\n | \"array\"\n | \"object\"\n | \"id\"\n | \"optional\"\n | \"any\"\n | \"null\";\n\n/**\n * Validates unknown input at runtime and carries its parsed TypeScript type.\n *\n * Syncore uses validators for function arguments, return values, and table\n * definitions. Most apps create validators through {@link v} instead of\n * instantiating validator classes directly.\n */\nexport interface Validator<TValue> {\n readonly kind: ValidatorKind;\n\n /**\n * Parse and validate an unknown value.\n *\n * @param value - The value to validate.\n * @param path - A human-readable path used in validation errors.\n * @returns The parsed value when validation succeeds.\n */\n parse(value: unknown, path?: string): TValue;\n}\n\nexport type ValidatorDescription =\n | { kind: \"string\" }\n | { kind: \"number\" }\n | { kind: \"boolean\" }\n | { kind: \"null\" }\n | { kind: \"any\" }\n | { kind: \"literal\"; value: string | number | boolean | null }\n | { kind: \"array\"; item: ValidatorDescription }\n | { kind: \"object\"; shape: Record<string, ValidatorDescription> }\n | { kind: \"id\"; tableName: string }\n | { kind: \"optional\"; inner: ValidatorDescription };\n\nexport interface ObjectValidatorShape {\n [key: string]: Validator<unknown>;\n}\n\nexport class StringValidator implements Validator<string> {\n readonly kind = \"string\" as const;\n\n parse(value: unknown, path = \"value\"): string {\n if (typeof value !== \"string\") {\n throw new Error(`${path} must be a string.`);\n }\n return value;\n }\n}\n\nexport class NumberValidator implements Validator<number> {\n readonly kind = \"number\" as const;\n\n parse(value: unknown, path = \"value\"): number {\n if (typeof value !== \"number\" || Number.isNaN(value)) {\n throw new Error(`${path} must be a number.`);\n }\n return value;\n }\n}\n\nexport class BooleanValidator implements Validator<boolean> {\n readonly kind = \"boolean\" as const;\n\n parse(value: unknown, path = \"value\"): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`${path} must be a boolean.`);\n }\n return value;\n }\n}\n\nexport class NullValidator implements Validator<null> {\n readonly kind = \"null\" as const;\n\n parse(value: unknown, path = \"value\"): null {\n if (value !== null) {\n throw new Error(`${path} must be null.`);\n }\n return null;\n }\n}\n\nexport class AnyValidator implements Validator<unknown> {\n readonly kind = \"any\" as const;\n\n parse(value: unknown): unknown {\n return value;\n }\n}\n\nexport class LiteralValidator<\n TValue extends string | number | boolean | null\n> implements Validator<TValue> {\n readonly kind = \"literal\" as const;\n\n constructor(public readonly literalValue: TValue) {}\n\n parse(value: unknown, path = \"value\"): TValue {\n if (value !== this.literalValue) {\n throw new Error(`${path} must equal ${String(this.literalValue)}.`);\n }\n return this.literalValue;\n }\n}\n\nexport class ArrayValidator<TItem> implements Validator<TItem[]> {\n readonly kind = \"array\" as const;\n\n constructor(public readonly itemValidator: Validator<TItem>) {}\n\n parse(value: unknown, path = \"value\"): TItem[] {\n if (!Array.isArray(value)) {\n throw new Error(`${path} must be an array.`);\n }\n return value.map((item, index) =>\n this.itemValidator.parse(item, `${path}[${index}]`)\n );\n }\n}\n\nexport class ObjectValidator<\n TShape extends ObjectValidatorShape\n> implements Validator<{ [TKey in keyof TShape]: Infer<TShape[TKey]> }> {\n readonly kind = \"object\" as const;\n\n constructor(public readonly shape: TShape) {}\n\n parse(\n value: unknown,\n path = \"value\"\n ): { [TKey in keyof TShape]: Infer<TShape[TKey]> } {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n throw new Error(`${path} must be an object.`);\n }\n\n const source = value as Record<string, unknown>;\n const parsed: Record<string, unknown> = {};\n\n for (const [key, validator] of Object.entries(this.shape)) {\n const optional =\n validator.kind === \"optional\" && source[key] === undefined;\n if (optional) {\n continue;\n }\n parsed[key] = validator.parse(source[key], `${path}.${key}`);\n }\n\n return parsed as { [TKey in keyof TShape]: Infer<TShape[TKey]> };\n }\n}\n\nexport class IdValidator<\n TTableName extends string\n> implements Validator<string> {\n readonly kind = \"id\" as const;\n\n constructor(public readonly tableName: TTableName) {}\n\n parse(value: unknown, path = \"value\"): string {\n if (typeof value !== \"string\" || value.length === 0) {\n throw new Error(`${path} must be a non-empty id string.`);\n }\n return value;\n }\n}\n\nexport class OptionalValidator<TValue> implements Validator<\n TValue | undefined\n> {\n readonly kind = \"optional\" as const;\n\n constructor(public readonly inner: Validator<TValue>) {}\n\n parse(value: unknown, path = \"value\"): TValue | undefined {\n if (value === undefined) {\n return undefined;\n }\n return this.inner.parse(value, path);\n }\n}\n\nexport type Infer<TValidator> =\n TValidator extends Validator<infer TValue> ? TValue : never;\n\nexport type ValidatorMap = Record<string, Validator<unknown>>;\n\n/**\n * The public validator builder API.\n *\n * Hover each property in your editor to see what it validates and how to use it.\n */\nexport interface ValidatorBuilderApi {\n /**\n * Validate a string value.\n *\n * @returns A validator that accepts JavaScript strings.\n */\n string(): StringValidator;\n\n /**\n * Validate a number value.\n *\n * @returns A validator that accepts finite JavaScript numbers.\n */\n number(): NumberValidator;\n\n /**\n * Validate a boolean value.\n *\n * @returns A validator that accepts `true` and `false`.\n */\n boolean(): BooleanValidator;\n\n /**\n * Validate the literal value `null`.\n *\n * @returns A validator that only accepts `null`.\n */\n null(): NullValidator;\n\n /**\n * Accept any value without validation.\n *\n * Use this sparingly for escape hatches when you do not want Syncore to\n * enforce a more specific runtime shape.\n */\n any(): AnyValidator;\n\n /**\n * Validate a single literal value.\n *\n * @param literalValue - The exact value that must be provided.\n * @returns A validator that only accepts that one value.\n */\n literal<TValue extends string | number | boolean | null>(\n literalValue: TValue\n ): LiteralValidator<TValue>;\n\n /**\n * Validate an array whose items all use the same validator.\n *\n * @param itemValidator - The validator for each item in the array.\n * @returns A validator for arrays of the provided item type.\n */\n array<TItem>(itemValidator: Validator<TItem>): ArrayValidator<TItem>;\n\n /**\n * Validate an object with a fixed property shape.\n *\n * @param shape - The validators for each property on the object.\n * @returns A validator for objects matching that shape.\n */\n object<TShape extends ObjectValidatorShape>(\n shape: TShape\n ): ObjectValidator<TShape>;\n\n /**\n * Validate an identifier string that points at a table.\n *\n * Use this for document ids that come from Syncore tables.\n *\n * @param tableName - The name of the referenced table.\n * @returns A validator for ids belonging to that table.\n */\n id<TTableName extends string>(tableName: TTableName): IdValidator<TTableName>;\n\n /**\n * Make another validator optional.\n *\n * @param inner - The validator for the defined case.\n * @returns A validator that accepts `undefined` or the inner value.\n */\n optional<TValue>(inner: Validator<TValue>): OptionalValidator<TValue>;\n}\n\nfunction isValidator(\n value: Validator<unknown> | ValidatorMap\n): value is Validator<unknown> {\n return typeof (value as Validator<unknown>).parse === \"function\";\n}\n\nexport function ensureObjectValidator(\n value: Validator<unknown> | ValidatorMap\n): Validator<unknown> {\n if (isValidator(value)) {\n return value;\n }\n return new ObjectValidator(value);\n}\n\n/**\n * Build runtime validators for schemas, function args, and return values.\n *\n * @example\n * ```ts\n * defineTable({\n * text: v.string(),\n * done: v.boolean(),\n * ownerId: v.optional(v.id(\"users\"))\n * });\n * ```\n */\nexport const v: ValidatorBuilderApi = {\n string: () => new StringValidator(),\n number: () => new NumberValidator(),\n boolean: () => new BooleanValidator(),\n null: () => new NullValidator(),\n any: () => new AnyValidator(),\n literal: <TValue extends string | number | boolean | null>(\n literalValue: TValue\n ) => new LiteralValidator(literalValue),\n array: <TItem>(itemValidator: Validator<TItem>) =>\n new ArrayValidator(itemValidator),\n object: <TShape extends ObjectValidatorShape>(shape: TShape) =>\n new ObjectValidator(shape),\n id: <TTableName extends string>(tableName: TTableName) =>\n new IdValidator(tableName),\n optional: <TValue>(inner: Validator<TValue>) => new OptionalValidator(inner)\n};\n\nexport function describeValidator(\n validator: Validator<unknown>\n): ValidatorDescription {\n switch (validator.kind) {\n case \"string\":\n case \"number\":\n case \"boolean\":\n case \"null\":\n case \"any\":\n return { kind: validator.kind };\n case \"literal\":\n return {\n kind: \"literal\",\n value: (validator as LiteralValidator<string | number | boolean | null>)\n .literalValue\n };\n case \"array\":\n return {\n kind: \"array\",\n item: describeValidator(\n (validator as ArrayValidator<unknown>).itemValidator\n )\n };\n case \"object\": {\n const objectValidator =\n validator as ObjectValidator<ObjectValidatorShape>;\n return {\n kind: \"object\",\n shape: Object.fromEntries(\n Object.entries(objectValidator.shape).map(([key, nested]) => [\n key,\n describeValidator(nested)\n ])\n )\n };\n }\n case \"id\":\n return {\n kind: \"id\",\n tableName: (validator as IdValidator<string>).tableName\n };\n case \"optional\":\n return {\n kind: \"optional\",\n inner: describeValidator(\n (validator as OptionalValidator<unknown>).inner\n )\n };\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"validators.js","names":[],"sources":["../src/validators.ts"],"sourcesContent":["type Expand<T> = { [TKey in keyof T]: T[TKey] } & {};\n\nexport type ValidatorKind =\n | \"string\"\n | \"number\"\n | \"boolean\"\n | \"literal\"\n | \"enum\"\n | \"array\"\n | \"object\"\n | \"record\"\n | \"union\"\n | \"id\"\n | \"optional\"\n | \"any\"\n | \"null\"\n | \"codec\";\n\n/**\n * A schema field definition that combines validation, serialization, and\n * field-path metadata for Syncore's data model.\n */\nexport interface Validator<\n TValue = unknown,\n TStorage = TValue,\n TFieldPaths extends string = never\n> {\n readonly kind: ValidatorKind;\n readonly fieldPaths?: TFieldPaths;\n parse(value: unknown, path?: string): TValue;\n serialize?(value: TValue, path?: string): TStorage;\n deserialize?(value: unknown, path?: string): TValue;\n describe?(): ValidatorDescription;\n}\n\nexport type ValidatorDescription =\n | { kind: \"string\" }\n | { kind: \"number\" }\n | { kind: \"boolean\" }\n | { kind: \"null\" }\n | { kind: \"any\" }\n | { kind: \"literal\"; value: string | number | boolean | null }\n | { kind: \"enum\"; values: string[] }\n | { kind: \"array\"; item: ValidatorDescription }\n | {\n kind: \"object\";\n shape: Record<\n string,\n {\n validator: ValidatorDescription;\n optional: boolean;\n }\n >;\n }\n | { kind: \"record\"; key: ValidatorDescription; value: ValidatorDescription }\n | { kind: \"union\"; members: ValidatorDescription[] }\n | { kind: \"id\"; tableName: string }\n | { kind: \"optional\"; inner: ValidatorDescription }\n | {\n kind: \"codec\";\n value: ValidatorDescription;\n storage: ValidatorDescription;\n };\n\nexport type Infer<TValidator> =\n TValidator extends Validator<infer TValue, unknown, string> ? TValue : never;\n\nexport type InferStorage<TValidator> =\n TValidator extends Validator<unknown, infer TStorage, string>\n ? TStorage\n : never;\n\nexport type FieldPaths<TValidator> =\n TValidator extends Validator<unknown, unknown, infer TFieldPaths>\n ? TFieldPaths\n : never;\n\nexport interface ObjectValidatorShape {\n [key: string]: Validator<unknown, unknown, string>;\n}\n\nexport type ValidatorMap = Record<string, Validator<unknown, unknown, string>>;\n\ntype OptionalKeys<TShape extends ObjectValidatorShape> = {\n [TKey in keyof TShape]:\n TShape[TKey] extends OptionalValidator<unknown, unknown, string>\n ? TKey\n : never;\n}[keyof TShape];\n\ntype RequiredKeys<TShape extends ObjectValidatorShape> = Exclude<\n keyof TShape,\n OptionalKeys<TShape>\n>;\n\ntype InferObject<TShape extends ObjectValidatorShape> = Expand<\n {\n [TKey in OptionalKeys<TShape>]?: Exclude<Infer<TShape[TKey]>, undefined>;\n } & {\n [TKey in RequiredKeys<TShape>]: Infer<TShape[TKey]>;\n }\n>;\n\ntype InferStoredObject<TShape extends ObjectValidatorShape> = Expand<\n {\n [TKey in OptionalKeys<TShape>]?: Exclude<\n InferStorage<TShape[TKey]>,\n undefined\n >;\n } & {\n [TKey in RequiredKeys<TShape>]: InferStorage<TShape[TKey]>;\n }\n>;\n\nexport type JoinFieldPaths<\n TStart extends string,\n TEnd extends string\n> = `${TStart}.${TEnd}`;\n\ntype ShapeFieldPaths<TShape extends ObjectValidatorShape> = {\n [TKey in keyof TShape & string]: FieldPaths<TShape[TKey]> extends never\n ? TKey\n : TKey | JoinFieldPaths<TKey, FieldPaths<TShape[TKey]>>;\n}[keyof TShape & string];\n\nabstract class BaseValidator<\n TValue,\n TStorage = TValue,\n TFieldPaths extends string = never\n> implements Validator<TValue, TStorage, TFieldPaths> {\n declare readonly fieldPaths: TFieldPaths;\n\n constructor(public readonly kind: ValidatorKind) {}\n\n abstract parse(value: unknown, path?: string): TValue;\n\n serialize(value: TValue, path = \"value\"): TStorage {\n return this.parse(value, path) as unknown as TStorage;\n }\n\n deserialize(value: unknown, path = \"value\"): TValue {\n return this.parse(value, path);\n }\n\n abstract describe(): ValidatorDescription;\n}\n\nexport class StringValidator extends BaseValidator<string> {\n constructor() {\n super(\"string\");\n }\n\n parse(value: unknown, path = \"value\"): string {\n if (typeof value !== \"string\") {\n throw new Error(`${path} must be a string.`);\n }\n return value;\n }\n\n describe(): ValidatorDescription {\n return { kind: \"string\" };\n }\n}\n\nexport class NumberValidator extends BaseValidator<number> {\n constructor() {\n super(\"number\");\n }\n\n parse(value: unknown, path = \"value\"): number {\n if (typeof value !== \"number\" || Number.isNaN(value)) {\n throw new Error(`${path} must be a number.`);\n }\n return value;\n }\n\n describe(): ValidatorDescription {\n return { kind: \"number\" };\n }\n}\n\nexport class BooleanValidator extends BaseValidator<boolean> {\n constructor() {\n super(\"boolean\");\n }\n\n parse(value: unknown, path = \"value\"): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`${path} must be a boolean.`);\n }\n return value;\n }\n\n describe(): ValidatorDescription {\n return { kind: \"boolean\" };\n }\n}\n\nexport class NullValidator extends BaseValidator<null> {\n constructor() {\n super(\"null\");\n }\n\n parse(value: unknown, path = \"value\"): null {\n if (value !== null) {\n throw new Error(`${path} must be null.`);\n }\n return null;\n }\n\n describe(): ValidatorDescription {\n return { kind: \"null\" };\n }\n}\n\nexport class AnyValidator extends BaseValidator<unknown, unknown, never> {\n constructor() {\n super(\"any\");\n }\n\n parse(value: unknown): unknown {\n return value;\n }\n\n describe(): ValidatorDescription {\n return { kind: \"any\" };\n }\n}\n\nexport class LiteralValidator<\n TValue extends string | number | boolean | null\n> extends BaseValidator<TValue> {\n constructor(public readonly literalValue: TValue) {\n super(\"literal\");\n }\n\n parse(value: unknown, path = \"value\"): TValue {\n if (value !== this.literalValue) {\n throw new Error(`${path} must equal ${String(this.literalValue)}.`);\n }\n return this.literalValue;\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"literal\",\n value: this.literalValue\n };\n }\n}\n\nexport class EnumValidator<\n TValues extends readonly [string, ...string[]]\n> extends BaseValidator<TValues[number]> {\n constructor(public readonly values: TValues) {\n super(\"enum\");\n }\n\n parse(value: unknown, path = \"value\"): TValues[number] {\n if (typeof value !== \"string\" || !this.values.includes(value)) {\n throw new Error(\n `${path} must be one of ${this.values.map((item) => JSON.stringify(item)).join(\", \")}.`\n );\n }\n return value as TValues[number];\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"enum\",\n values: [...this.values]\n };\n }\n}\n\nexport class ArrayValidator<\n TItem,\n TItemStorage,\n TItemValidator extends Validator<TItem, TItemStorage, string>\n> extends BaseValidator<TItem[], TItemStorage[], never> {\n constructor(public readonly itemValidator: TItemValidator) {\n super(\"array\");\n }\n\n parse(value: unknown, path = \"value\"): TItem[] {\n if (!Array.isArray(value)) {\n throw new Error(`${path} must be an array.`);\n }\n return value.map((item, index) =>\n this.itemValidator.parse(item, `${path}[${index}]`)\n );\n }\n\n override serialize(value: TItem[], path = \"value\"): TItemStorage[] {\n const parsed = this.parse(value, path);\n return parsed.map((item, index) =>\n serializeValue(this.itemValidator, item, `${path}[${index}]`)\n );\n }\n\n override deserialize(value: unknown, path = \"value\"): TItem[] {\n if (!Array.isArray(value)) {\n throw new Error(`${path} must be an array.`);\n }\n return value.map((item, index) =>\n deserializeValue(this.itemValidator, item, `${path}[${index}]`)\n );\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"array\",\n item: describeValidator(this.itemValidator)\n };\n }\n}\n\nexport class ObjectValidator<\n TShape extends ObjectValidatorShape\n> extends BaseValidator<\n InferObject<TShape>,\n InferStoredObject<TShape>,\n ShapeFieldPaths<TShape>\n> {\n constructor(public readonly shape: TShape) {\n super(\"object\");\n }\n\n parse(value: unknown, path = \"value\"): InferObject<TShape> {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n throw new Error(`${path} must be an object.`);\n }\n\n const source = value as Record<string, unknown>;\n const parsed: Record<string, unknown> = {};\n\n for (const [key, validator] of Object.entries(this.shape)) {\n if (validator.kind === \"optional\" && source[key] === undefined) {\n continue;\n }\n parsed[key] = validator.parse(source[key], `${path}.${key}`);\n }\n\n return parsed as InferObject<TShape>;\n }\n\n override serialize(\n value: InferObject<TShape>,\n path = \"value\"\n ): InferStoredObject<TShape> {\n const parsed = this.parse(value, path) as Record<string, unknown>;\n const serialized: Record<string, unknown> = {};\n\n for (const [key, validator] of Object.entries(this.shape)) {\n if (parsed[key] === undefined && validator.kind === \"optional\") {\n continue;\n }\n serialized[key] = serializeValue(\n validator,\n parsed[key],\n `${path}.${key}`\n );\n }\n\n return serialized as InferStoredObject<TShape>;\n }\n\n override deserialize(value: unknown, path = \"value\"): InferObject<TShape> {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n throw new Error(`${path} must be an object.`);\n }\n\n const source = value as Record<string, unknown>;\n const parsed: Record<string, unknown> = {};\n\n for (const [key, validator] of Object.entries(this.shape)) {\n if (validator.kind === \"optional\" && source[key] === undefined) {\n continue;\n }\n parsed[key] = deserializeValue(validator, source[key], `${path}.${key}`);\n }\n\n return parsed as InferObject<TShape>;\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"object\",\n shape: Object.fromEntries(\n Object.entries(this.shape).map(([key, validator]) => [\n key,\n {\n validator:\n validator.kind === \"optional\"\n ? describeValidator(\n (validator as OptionalValidator<unknown, unknown, string>).inner\n )\n : describeValidator(validator),\n optional: validator.kind === \"optional\"\n }\n ])\n )\n };\n }\n}\n\nexport class IdValidator<\n TTableName extends string\n> extends BaseValidator<string> {\n constructor(public readonly tableName: TTableName) {\n super(\"id\");\n }\n\n parse(value: unknown, path = \"value\"): string {\n if (typeof value !== \"string\" || value.length === 0) {\n throw new Error(`${path} must be a non-empty id string.`);\n }\n return value;\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"id\",\n tableName: this.tableName\n };\n }\n}\n\nexport class OptionalValidator<\n TValue,\n TStorage = TValue,\n TFieldPaths extends string = never\n> extends BaseValidator<\n TValue | undefined,\n TStorage | undefined,\n TFieldPaths\n> {\n constructor(public readonly inner: Validator<TValue, TStorage, TFieldPaths>) {\n super(\"optional\");\n }\n\n parse(value: unknown, path = \"value\"): TValue | undefined {\n if (value === undefined) {\n return undefined;\n }\n return this.inner.parse(value, path);\n }\n\n override serialize(\n value: TValue | undefined,\n path = \"value\"\n ): TStorage | undefined {\n if (value === undefined) {\n return undefined;\n }\n return serializeValue(this.inner, value, path);\n }\n\n override deserialize(\n value: unknown,\n path = \"value\"\n ): TValue | undefined {\n if (value === undefined) {\n return undefined;\n }\n return deserializeValue(this.inner, value, path);\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"optional\",\n inner: describeValidator(this.inner)\n };\n }\n}\n\nexport class RecordValidator<\n TKey extends string,\n TValue,\n TStorage,\n TKeyValidator extends Validator<TKey, string, string>,\n TValueValidator extends Validator<TValue, TStorage, string>\n> extends BaseValidator<Record<TKey, TValue>, Record<TKey, TStorage>, never> {\n constructor(\n public readonly keyValidator: TKeyValidator,\n public readonly valueValidator: TValueValidator\n ) {\n super(\"record\");\n }\n\n parse(value: unknown, path = \"value\"): Record<TKey, TValue> {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n throw new Error(`${path} must be an object.`);\n }\n const source = value as Record<string, unknown>;\n const parsed: Record<string, TValue> = {};\n for (const [key, item] of Object.entries(source)) {\n const parsedKey = this.keyValidator.parse(key, `${path}.{key}`);\n parsed[parsedKey] = this.valueValidator.parse(item, `${path}.${key}`);\n }\n return parsed as Record<TKey, TValue>;\n }\n\n override serialize(\n value: Record<TKey, TValue>,\n path = \"value\"\n ): Record<TKey, TStorage> {\n const parsed = this.parse(value, path);\n const serialized: Record<string, TStorage> = {};\n for (const [key, item] of Object.entries(parsed)) {\n serialized[key] = serializeValue(this.valueValidator, item, `${path}.${key}`);\n }\n return serialized as Record<TKey, TStorage>;\n }\n\n override deserialize(\n value: unknown,\n path = \"value\"\n ): Record<TKey, TValue> {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n throw new Error(`${path} must be an object.`);\n }\n const source = value as Record<string, unknown>;\n const parsed: Record<string, TValue> = {};\n for (const [key, item] of Object.entries(source)) {\n const parsedKey = this.keyValidator.parse(key, `${path}.{key}`);\n parsed[parsedKey] = deserializeValue(\n this.valueValidator,\n item,\n `${path}.${key}`\n );\n }\n return parsed as Record<TKey, TValue>;\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"record\",\n key: describeValidator(this.keyValidator),\n value: describeValidator(this.valueValidator)\n };\n }\n}\n\nexport class UnionValidator<\n TMembers extends readonly Validator<unknown, unknown, string>[]\n> extends BaseValidator<\n Infer<TMembers[number]>,\n InferStorage<TMembers[number]>,\n FieldPaths<TMembers[number]>\n> {\n constructor(public readonly members: TMembers) {\n super(\"union\");\n }\n\n parse(value: unknown, path = \"value\"): Infer<TMembers[number]> {\n for (const member of this.members) {\n try {\n return member.parse(value, path) as Infer<TMembers[number]>;\n } catch {\n continue;\n }\n }\n throw new Error(`${path} did not match any union member.`);\n }\n\n override serialize(\n value: Infer<TMembers[number]>,\n path = \"value\"\n ): InferStorage<TMembers[number]> {\n for (const member of this.members) {\n try {\n const parsed = member.parse(value, path);\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n return serializeValue(\n member as Validator<\n Infer<TMembers[number]>,\n InferStorage<TMembers[number]>,\n string\n >,\n parsed,\n path\n ) as InferStorage<TMembers[number]>;\n } catch {\n continue;\n }\n }\n throw new Error(`${path} did not match any union member.`);\n }\n\n override deserialize(\n value: unknown,\n path = \"value\"\n ): Infer<TMembers[number]> {\n for (const member of this.members) {\n try {\n return deserializeValue(\n member as Validator<Infer<TMembers[number]>, InferStorage<TMembers[number]>, string>,\n value,\n path\n );\n } catch {\n continue;\n }\n }\n throw new Error(`${path} did not match any union member.`);\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"union\",\n members: this.members.map((member) => describeValidator(member))\n };\n }\n}\n\nexport class CodecValidator<\n TValue,\n TStored,\n TStorageFieldValidator extends Validator<TStored, unknown, string>,\n TValueFieldValidator extends Validator<TValue, unknown, string>\n> extends BaseValidator<\n TValue,\n InferStorage<TStorageFieldValidator>,\n FieldPaths<TValueFieldValidator>\n> {\n constructor(\n public readonly valueValidator: TValueFieldValidator,\n public readonly storageValidator: TStorageFieldValidator,\n private readonly codec: {\n serialize(value: TValue): TStored;\n deserialize(value: TStored): TValue;\n }\n ) {\n super(\"codec\");\n }\n\n parse(value: unknown, path = \"value\"): TValue {\n return this.valueValidator.parse(value, path);\n }\n\n override serialize(\n value: TValue,\n path = \"value\"\n ): InferStorage<TStorageFieldValidator> {\n const parsed = this.valueValidator.parse(value, path);\n const serialized = this.codec.serialize(parsed);\n return serializeValue(\n this.storageValidator,\n this.storageValidator.parse(serialized, path),\n path\n ) as InferStorage<TStorageFieldValidator>;\n }\n\n override deserialize(value: unknown, path = \"value\"): TValue {\n const parsedStored = deserializeValue(this.storageValidator, value, path);\n return this.valueValidator.parse(\n this.codec.deserialize(parsedStored),\n path\n );\n }\n\n describe(): ValidatorDescription {\n return {\n kind: \"codec\",\n value: describeValidator(this.valueValidator),\n storage: describeValidator(this.storageValidator)\n };\n }\n}\n\n/**\n * Public builder namespace for declaring Syncore schema fields and codecs.\n */\nexport interface ValidatorBuilderApi {\n string(): StringValidator;\n number(): NumberValidator;\n boolean(): BooleanValidator;\n null(): NullValidator;\n any(): AnyValidator;\n literal<TValue extends string | number | boolean | null>(\n literalValue: TValue\n ): LiteralValidator<TValue>;\n enum<TValues extends readonly [string, ...string[]]>(\n values: TValues\n ): EnumValidator<TValues>;\n array<\n TItem,\n TItemStorage,\n TValidator extends Validator<TItem, TItemStorage, string>\n >(itemValidator: TValidator): ArrayValidator<TItem, TItemStorage, TValidator>;\n object<TShape extends ObjectValidatorShape>(\n shape: TShape\n ): ObjectValidator<TShape>;\n id<TTableName extends string>(tableName: TTableName): IdValidator<TTableName>;\n optional<TValue, TStorage, TFieldPaths extends string>(\n inner: Validator<TValue, TStorage, TFieldPaths>\n ): OptionalValidator<TValue, TStorage, TFieldPaths>;\n record<\n TKey extends string,\n TValue,\n TStorage,\n TKeyValidator extends Validator<TKey, string, string>,\n TValueValidator extends Validator<TValue, TStorage, string>\n >(\n keyValidator: TKeyValidator,\n valueValidator: TValueValidator\n ): RecordValidator<TKey, TValue, TStorage, TKeyValidator, TValueValidator>;\n union<\n TMembers extends readonly Validator<unknown, unknown, string>[]\n >(...members: TMembers): UnionValidator<TMembers>;\n nullable<TValue, TStorage, TFieldPaths extends string>(\n inner: Validator<TValue, TStorage, TFieldPaths>\n ): UnionValidator<\n readonly [Validator<TValue, TStorage, TFieldPaths>, NullValidator]\n >;\n codec<\n TValue,\n TStored,\n TStorageFieldValidator extends Validator<TStored, unknown, string>,\n TValueFieldValidator extends Validator<TValue, unknown, string>\n >(\n valueValidator: TValueFieldValidator,\n config: {\n storage: TStorageFieldValidator;\n serialize(value: TValue): TStored;\n deserialize(value: TStored): TValue;\n }\n ): CodecValidator<\n TValue,\n TStored,\n TStorageFieldValidator,\n TValueFieldValidator\n >;\n}\n\n/**\n * Primary schema builder namespace for Syncore's data-model DSL.\n */\nexport const s: ValidatorBuilderApi = {\n string: () => new StringValidator(),\n number: () => new NumberValidator(),\n boolean: () => new BooleanValidator(),\n null: () => new NullValidator(),\n any: () => new AnyValidator(),\n literal: <TValue extends string | number | boolean | null>(\n literalValue: TValue\n ) => new LiteralValidator(literalValue),\n enum: <TValues extends readonly [string, ...string[]]>(values: TValues) =>\n new EnumValidator(values),\n array: <\n TItem,\n TItemStorage,\n TValidator extends Validator<TItem, TItemStorage, string>\n >(\n itemValidator: TValidator\n ) =>\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n new ArrayValidator(itemValidator) as ArrayValidator<TItem, TItemStorage, TValidator>,\n object: <TShape extends ObjectValidatorShape>(shape: TShape) =>\n new ObjectValidator(shape),\n id: <TTableName extends string>(tableName: TTableName) =>\n new IdValidator(tableName),\n optional: <TValue, TStorage, TFieldPaths extends string>(\n inner: Validator<TValue, TStorage, TFieldPaths>\n ) => new OptionalValidator(inner),\n record: <\n TKey extends string,\n TValue,\n TStorage,\n TKeyValidator extends Validator<TKey, string, string>,\n TValueValidator extends Validator<TValue, TStorage, string>\n >(\n keyValidator: TKeyValidator,\n valueValidator: TValueValidator\n ) =>\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n new RecordValidator(keyValidator, valueValidator) as RecordValidator<\n TKey,\n TValue,\n TStorage,\n TKeyValidator,\n TValueValidator\n >,\n union: <TMembers extends readonly Validator<unknown, unknown, string>[]>(\n ...members: TMembers\n ) => new UnionValidator(members),\n nullable: <TValue, TStorage, TFieldPaths extends string>(\n inner: Validator<TValue, TStorage, TFieldPaths>\n ) => new UnionValidator([inner, new NullValidator()] as const),\n codec: <\n TValue,\n TStored,\n TStorageFieldValidator extends Validator<TStored, unknown, string>,\n TValueFieldValidator extends Validator<TValue, unknown, string>\n >(\n valueValidator: TValueFieldValidator,\n config: {\n storage: TStorageFieldValidator;\n serialize(value: TValue): TStored;\n deserialize(value: TStored): TValue;\n }\n ) =>\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n new CodecValidator(valueValidator, config.storage, {\n serialize: (value) => config.serialize(value),\n deserialize: (value) => config.deserialize(value)\n }) as CodecValidator<\n TValue,\n TStored,\n TStorageFieldValidator,\n TValueFieldValidator\n >\n};\n\nexport function isValidator(\n value: Validator<unknown, unknown, string> | ValidatorMap\n): value is Validator<unknown, unknown, string> {\n return typeof (value as Validator<unknown, unknown, string>).parse === \"function\";\n}\n\nexport function ensureObjectValidator<TShape extends ObjectValidatorShape>(\n value: TShape\n): ObjectValidator<TShape>;\nexport function ensureObjectValidator<TValidator extends Validator<unknown, unknown, string>>(\n value: TValidator\n): TValidator;\nexport function ensureObjectValidator(\n value: Validator<unknown, unknown, string> | ValidatorMap\n): Validator<unknown, unknown, string> {\n if (isValidator(value)) {\n return value;\n }\n return new ObjectValidator(value);\n}\n\nexport function serializeValue<TValue, TStorage, TFieldPaths extends string>(\n validator: Validator<TValue, TStorage, TFieldPaths>,\n value: TValue,\n path = \"value\"\n): TStorage {\n if (validator.serialize) {\n return validator.serialize(value, path);\n }\n return value as unknown as TStorage;\n}\n\nexport function deserializeValue<\n TValue,\n TStorage,\n TFieldPaths extends string\n>(\n validator: Validator<TValue, TStorage, TFieldPaths>,\n value: unknown,\n path = \"value\"\n): TValue {\n if (validator.deserialize) {\n return validator.deserialize(value, path);\n }\n return validator.parse(value, path);\n}\n\nexport function describeValidator(\n validator: Validator<unknown, unknown, string>\n): ValidatorDescription {\n if (validator.describe) {\n return validator.describe();\n }\n\n switch (validator.kind) {\n case \"string\":\n case \"number\":\n case \"boolean\":\n case \"null\":\n case \"any\":\n return { kind: validator.kind };\n case \"literal\":\n return {\n kind: \"literal\",\n value: (validator as LiteralValidator<string | number | boolean | null>)\n .literalValue\n };\n case \"enum\":\n return {\n kind: \"enum\",\n values: [...(validator as EnumValidator<readonly [string, ...string[]]>).values]\n };\n case \"array\":\n return {\n kind: \"array\",\n item: describeValidator(\n (validator as ArrayValidator<unknown, unknown, Validator<unknown, unknown, string>>)\n .itemValidator\n )\n };\n case \"object\": {\n const objectShape =\n \"shape\" in validator\n ? (validator as {\n shape: Record<\n string,\n | Validator<unknown, unknown, string>\n | {\n validator?: ValidatorDescription;\n field?: ValidatorDescription;\n optional?: boolean;\n }\n >;\n }).shape\n : {};\n\n return {\n kind: \"object\",\n shape: Object.fromEntries(\n Object.entries(objectShape).map(([key, field]) => {\n if (isValidator(field as Validator<unknown, unknown, string>)) {\n return [\n key,\n {\n validator:\n (field as Validator<unknown, unknown, string>).kind === \"optional\"\n ? describeValidator(\n (\n field as OptionalValidator<unknown, unknown, string>\n ).inner\n )\n : describeValidator(\n field as Validator<unknown, unknown, string>\n ),\n optional:\n (field as Validator<unknown, unknown, string>).kind === \"optional\"\n }\n ];\n }\n const metadata = field as {\n validator?: ValidatorDescription;\n field?: ValidatorDescription;\n optional?: boolean;\n };\n return [\n key,\n {\n validator:\n metadata.validator ??\n metadata.field ??\n ({ kind: \"any\" } satisfies ValidatorDescription),\n optional: metadata.optional ?? false\n }\n ];\n })\n )\n };\n }\n case \"record\":\n return {\n kind: \"record\",\n key: describeValidator(\n (validator as RecordValidator<\n string,\n unknown,\n unknown,\n Validator<string, string, string>,\n Validator<unknown, unknown, string>\n >).keyValidator\n ),\n value: describeValidator(\n (validator as RecordValidator<\n string,\n unknown,\n unknown,\n Validator<string, string, string>,\n Validator<unknown, unknown, string>\n >).valueValidator\n )\n };\n case \"union\":\n return {\n kind: \"union\",\n members: (\n validator as UnionValidator<readonly Validator<unknown, unknown, string>[]>\n ).members.map((member) => describeValidator(member))\n };\n case \"id\":\n return {\n kind: \"id\",\n tableName: (validator as IdValidator<string>).tableName\n };\n case \"optional\":\n return {\n kind: \"optional\",\n inner: describeValidator(\n (validator as OptionalValidator<unknown, unknown, string>).inner\n )\n };\n case \"codec\":\n return {\n kind: \"codec\",\n value: describeValidator(\n (validator as CodecValidator<\n unknown,\n unknown,\n Validator<unknown, unknown, string>,\n Validator<unknown, unknown, string>\n >).valueValidator\n ),\n storage: describeValidator(\n (validator as CodecValidator<\n unknown,\n unknown,\n Validator<unknown, unknown, string>,\n Validator<unknown, unknown, string>\n >).storageValidator\n )\n };\n }\n}\n"],"mappings":"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"}