@snowtop/ent 0.1.0-alpha12 → 0.1.0-alpha120

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 (164) hide show
  1. package/action/action.d.ts +37 -31
  2. package/action/action.js +22 -7
  3. package/action/executor.d.ts +3 -3
  4. package/action/executor.js +8 -3
  5. package/action/experimental_action.d.ts +32 -22
  6. package/action/experimental_action.js +35 -9
  7. package/action/index.d.ts +2 -0
  8. package/action/index.js +7 -1
  9. package/action/orchestrator.d.ts +33 -14
  10. package/action/orchestrator.js +251 -54
  11. package/action/privacy.d.ts +2 -2
  12. package/action/relative_value.d.ts +47 -0
  13. package/action/relative_value.js +125 -0
  14. package/action/transaction.d.ts +10 -0
  15. package/action/transaction.js +23 -0
  16. package/auth/auth.d.ts +1 -1
  17. package/core/base.d.ts +60 -37
  18. package/core/base.js +7 -1
  19. package/core/clause.d.ts +84 -40
  20. package/core/clause.js +358 -64
  21. package/core/config.d.ts +12 -1
  22. package/core/config.js +7 -1
  23. package/core/const.d.ts +3 -0
  24. package/core/const.js +6 -0
  25. package/core/context.d.ts +6 -4
  26. package/core/context.js +20 -2
  27. package/core/convert.d.ts +1 -1
  28. package/core/date.js +1 -5
  29. package/core/db.d.ts +11 -8
  30. package/core/db.js +20 -8
  31. package/core/ent.d.ts +86 -30
  32. package/core/ent.js +641 -193
  33. package/core/loaders/assoc_count_loader.d.ts +3 -2
  34. package/core/loaders/assoc_count_loader.js +10 -2
  35. package/core/loaders/assoc_edge_loader.d.ts +2 -2
  36. package/core/loaders/assoc_edge_loader.js +8 -11
  37. package/core/loaders/index.d.ts +1 -1
  38. package/core/loaders/index.js +1 -3
  39. package/core/loaders/index_loader.d.ts +3 -3
  40. package/core/loaders/loader.d.ts +2 -2
  41. package/core/loaders/loader.js +5 -5
  42. package/core/loaders/object_loader.d.ts +11 -10
  43. package/core/loaders/object_loader.js +70 -60
  44. package/core/loaders/query_loader.d.ts +7 -13
  45. package/core/loaders/query_loader.js +52 -11
  46. package/core/loaders/raw_count_loader.d.ts +2 -2
  47. package/core/loaders/raw_count_loader.js +5 -1
  48. package/core/logger.d.ts +1 -1
  49. package/core/logger.js +1 -0
  50. package/core/privacy.d.ts +25 -24
  51. package/core/privacy.js +21 -25
  52. package/core/query/assoc_query.d.ts +7 -6
  53. package/core/query/assoc_query.js +9 -1
  54. package/core/query/custom_clause_query.d.ts +27 -0
  55. package/core/query/custom_clause_query.js +84 -0
  56. package/core/query/custom_query.d.ts +20 -5
  57. package/core/query/custom_query.js +87 -12
  58. package/core/query/index.d.ts +1 -0
  59. package/core/query/index.js +3 -1
  60. package/core/query/query.d.ts +8 -4
  61. package/core/query/query.js +101 -53
  62. package/core/query/shared_assoc_test.d.ts +2 -1
  63. package/core/query/shared_assoc_test.js +35 -45
  64. package/core/query/shared_test.d.ts +8 -1
  65. package/core/query/shared_test.js +469 -236
  66. package/core/viewer.d.ts +3 -3
  67. package/core/viewer.js +1 -1
  68. package/graphql/graphql.d.ts +15 -7
  69. package/graphql/graphql.js +23 -7
  70. package/graphql/index.d.ts +1 -1
  71. package/graphql/index.js +3 -4
  72. package/graphql/query/connection_type.d.ts +9 -9
  73. package/graphql/query/edge_connection.d.ts +9 -9
  74. package/graphql/query/page_info.d.ts +1 -1
  75. package/graphql/query/shared_assoc_test.js +1 -1
  76. package/graphql/query/shared_edge_connection.js +1 -19
  77. package/graphql/scalars/orderby_direction.d.ts +2 -0
  78. package/graphql/scalars/orderby_direction.js +15 -0
  79. package/imports/index.d.ts +6 -1
  80. package/imports/index.js +19 -4
  81. package/index.d.ts +12 -5
  82. package/index.js +20 -7
  83. package/package.json +17 -16
  84. package/parse_schema/parse.d.ts +30 -9
  85. package/parse_schema/parse.js +145 -12
  86. package/schema/base_schema.d.ts +5 -3
  87. package/schema/base_schema.js +6 -0
  88. package/schema/field.d.ts +75 -20
  89. package/schema/field.js +175 -69
  90. package/schema/index.d.ts +2 -2
  91. package/schema/index.js +5 -1
  92. package/schema/json_field.d.ts +16 -4
  93. package/schema/json_field.js +32 -2
  94. package/schema/schema.d.ts +87 -20
  95. package/schema/schema.js +13 -14
  96. package/schema/struct_field.d.ts +11 -1
  97. package/schema/struct_field.js +57 -21
  98. package/scripts/custom_compiler.js +10 -6
  99. package/scripts/custom_graphql.js +124 -31
  100. package/scripts/migrate_v0.1.js +36 -0
  101. package/scripts/move_types.js +117 -0
  102. package/scripts/read_schema.js +20 -5
  103. package/testutils/action/complex_schemas.d.ts +69 -0
  104. package/testutils/action/complex_schemas.js +398 -0
  105. package/testutils/builder.d.ts +43 -47
  106. package/testutils/builder.js +76 -49
  107. package/testutils/db/fixture.d.ts +10 -0
  108. package/testutils/db/fixture.js +26 -0
  109. package/testutils/db/{test_db.d.ts → temp_db.d.ts} +24 -8
  110. package/testutils/db/{test_db.js → temp_db.js} +182 -45
  111. package/testutils/db/value.d.ts +7 -0
  112. package/testutils/db/value.js +251 -0
  113. package/testutils/db_mock.d.ts +16 -4
  114. package/testutils/db_mock.js +51 -6
  115. package/testutils/db_time_zone.d.ts +4 -0
  116. package/testutils/db_time_zone.js +41 -0
  117. package/testutils/ent-graphql-tests/index.d.ts +7 -1
  118. package/testutils/ent-graphql-tests/index.js +52 -23
  119. package/testutils/fake_data/const.d.ts +2 -1
  120. package/testutils/fake_data/const.js +3 -0
  121. package/testutils/fake_data/fake_contact.d.ts +8 -4
  122. package/testutils/fake_data/fake_contact.js +15 -8
  123. package/testutils/fake_data/fake_event.d.ts +5 -2
  124. package/testutils/fake_data/fake_event.js +9 -7
  125. package/testutils/fake_data/fake_tag.d.ts +36 -0
  126. package/testutils/fake_data/fake_tag.js +89 -0
  127. package/testutils/fake_data/fake_user.d.ts +10 -7
  128. package/testutils/fake_data/fake_user.js +18 -16
  129. package/testutils/fake_data/index.js +5 -1
  130. package/testutils/fake_data/internal.d.ts +2 -0
  131. package/testutils/fake_data/internal.js +7 -1
  132. package/testutils/fake_data/tag_query.d.ts +13 -0
  133. package/testutils/fake_data/tag_query.js +43 -0
  134. package/testutils/fake_data/test_helpers.d.ts +11 -4
  135. package/testutils/fake_data/test_helpers.js +28 -12
  136. package/testutils/fake_data/user_query.d.ts +13 -6
  137. package/testutils/fake_data/user_query.js +54 -22
  138. package/testutils/fake_log.d.ts +3 -3
  139. package/testutils/parse_sql.d.ts +6 -0
  140. package/testutils/parse_sql.js +16 -2
  141. package/testutils/test_edge_global_schema.d.ts +15 -0
  142. package/testutils/test_edge_global_schema.js +62 -0
  143. package/testutils/write.d.ts +2 -2
  144. package/testutils/write.js +33 -7
  145. package/tsc/ast.d.ts +25 -2
  146. package/tsc/ast.js +141 -17
  147. package/tsc/compilerOptions.js +5 -1
  148. package/tsc/move_generated.d.ts +1 -0
  149. package/tsc/move_generated.js +164 -0
  150. package/tsc/transform.d.ts +22 -0
  151. package/tsc/transform.js +181 -0
  152. package/tsc/transform_action.d.ts +22 -0
  153. package/tsc/transform_action.js +183 -0
  154. package/tsc/transform_ent.d.ts +17 -0
  155. package/tsc/transform_ent.js +60 -0
  156. package/tsc/transform_schema.d.ts +27 -0
  157. package/{scripts → tsc}/transform_schema.js +146 -117
  158. package/graphql/enums.d.ts +0 -3
  159. package/graphql/enums.js +0 -25
  160. package/scripts/move_generated.js +0 -142
  161. package/scripts/transform_code.js +0 -113
  162. package/scripts/transform_schema.d.ts +0 -1
  163. /package/scripts/{move_generated.d.ts → migrate_v0.1.d.ts} +0 -0
  164. /package/scripts/{transform_code.d.ts → move_types.d.ts} +0 -0
@@ -1,34 +1,36 @@
1
1
  import { Schema, Field, AssocEdge, AssocEdgeGroup, Action } from "../schema";
2
- import { ActionField, Type } from "../schema/schema";
2
+ import { ActionField, Type, GlobalSchema, TransformReadBetaResult } from "../schema/schema";
3
3
  declare enum NullableResult {
4
4
  CONTENTS = "contents",
5
5
  CONTENTS_AND_LIST = "contentsAndList",
6
6
  ITEM = "true"
7
7
  }
8
- declare type ProcessedActionField = Omit<ActionField, "nullable"> & {
8
+ type ProcessedActionField = Omit<ActionField, "nullable"> & {
9
9
  nullable?: NullableResult;
10
10
  };
11
- declare type ProcessedAssocEdge = Omit<AssocEdge, "actionOnlyFields" | "edgeActions"> & {
11
+ type ProcessedAssocEdge = Omit<AssocEdge, "actionOnlyFields" | "edgeActions"> & {
12
12
  patternName?: string;
13
13
  edgeActions?: OutputAction[];
14
14
  };
15
15
  interface TransformFlags {
16
16
  transformsSelect?: boolean;
17
17
  transformsDelete?: boolean;
18
+ transformsLoaderCodegen?: TransformReadBetaResult;
18
19
  transformsInsert?: boolean;
19
20
  transformsUpdate?: boolean;
20
21
  }
21
- declare type ProcessedSchema = Omit<Schema, "edges" | "actions" | "edgeGroups" | "fields"> & TransformFlags & {
22
+ type ProcessedSchema = Omit<Schema, "edges" | "actions" | "edgeGroups" | "fields"> & TransformFlags & {
22
23
  actions: OutputAction[];
23
24
  assocEdges: ProcessedAssocEdge[];
24
25
  assocEdgeGroups: ProcessedAssocEdgeGroup[];
25
26
  fields: ProcessedField[];
26
27
  schemaPath?: string;
28
+ patternNames?: string[];
27
29
  };
28
- declare type ProcessedAssocEdgeGroup = Omit<AssocEdgeGroup, "edgeAction"> & {
30
+ type ProcessedAssocEdgeGroup = Omit<AssocEdgeGroup, "edgeAction"> & {
29
31
  edgeAction?: OutputAction;
30
32
  };
31
- declare type OutputAction = Omit<Action, "actionOnlyFields"> & {
33
+ type OutputAction = Omit<Action, "actionOnlyFields"> & {
32
34
  actionOnlyFields?: ProcessedActionField[];
33
35
  };
34
36
  interface schemasDict {
@@ -38,13 +40,14 @@ interface ProcessedPattern {
38
40
  name: string;
39
41
  assocEdges: ProcessedAssocEdge[];
40
42
  fields: ProcessedField[];
43
+ disableMixin?: boolean;
41
44
  }
42
- declare type ProcessedType = Omit<Type, "subFields" | "listElemType" | "unionFields"> & {
45
+ type ProcessedType = Omit<Type, "subFields" | "listElemType" | "unionFields"> & {
43
46
  subFields?: ProcessedField[];
44
47
  listElemType?: ProcessedType;
45
48
  unionFields?: ProcessedField[];
46
49
  };
47
- declare type ProcessedField = Omit<Field, "defaultValueOnEdit" | "defaultValueOnCreate" | "privacyPolicy" | "type"> & {
50
+ type ProcessedField = Omit<Field, "defaultValueOnEdit" | "defaultValueOnCreate" | "privacyPolicy" | "type" | "serverDefault"> & {
48
51
  name: string;
49
52
  hasDefaultValueOnCreate?: boolean;
50
53
  hasDefaultValueOnEdit?: boolean;
@@ -52,6 +55,7 @@ declare type ProcessedField = Omit<Field, "defaultValueOnEdit" | "defaultValueOn
52
55
  hasFieldPrivacy?: boolean;
53
56
  derivedFields?: ProcessedField[];
54
57
  type: ProcessedType;
58
+ serverDefault?: string;
55
59
  };
56
60
  interface patternsDict {
57
61
  [key: string]: ProcessedPattern;
@@ -59,9 +63,26 @@ interface patternsDict {
59
63
  interface Result {
60
64
  schemas: schemasDict;
61
65
  patterns: patternsDict;
66
+ globalSchema?: ProcessedGlobalSchema;
67
+ config?: {
68
+ rome?: RomeConfig;
69
+ };
62
70
  }
63
71
  declare type PotentialSchemas = {
64
72
  [key: string]: any;
65
73
  };
66
- export declare function parseSchema(potentialSchemas: PotentialSchemas): Result;
74
+ export declare function parseSchema(potentialSchemas: PotentialSchemas, globalSchema?: GlobalSchema): Promise<Result>;
75
+ interface RomeConfig {
76
+ indentStyle?: string;
77
+ lineWidth?: number;
78
+ indentSize?: number;
79
+ quoteStyle?: string;
80
+ quoteProperties?: string;
81
+ trailingComma?: string;
82
+ }
83
+ interface ProcessedGlobalSchema {
84
+ globalEdges: ProcessedAssocEdge[];
85
+ extraEdgeFields: ProcessedField[];
86
+ initForEdges?: boolean;
87
+ }
67
88
  export {};
@@ -1,7 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.parseSchema = void 0;
4
- function processFields(src, patternName) {
4
+ const cosmiconfig_1 = require("cosmiconfig");
5
+ const const_1 = require("../core/const");
6
+ async function processFields(src, patternName) {
5
7
  const ret = [];
6
8
  let m = {};
7
9
  if (Array.isArray(src)) {
@@ -36,6 +38,19 @@ function processFields(src, patternName) {
36
38
  else {
37
39
  delete f.polymorphic;
38
40
  }
41
+ if (field.private) {
42
+ // convert boolean into object
43
+ // we keep boolean as an option to keep API simple
44
+ if (typeof field.private === "boolean") {
45
+ f.private = {};
46
+ }
47
+ else {
48
+ f.private = field.private;
49
+ }
50
+ }
51
+ else {
52
+ delete f.private;
53
+ }
39
54
  // convert string to object to make API consumed by go simple
40
55
  if (f.fieldEdge && f.fieldEdge.inverseEdge) {
41
56
  if (typeof f.fieldEdge.inverseEdge === "string") {
@@ -47,26 +62,48 @@ function processFields(src, patternName) {
47
62
  if (patternName) {
48
63
  f.patternName = patternName;
49
64
  }
65
+ if (field.serverDefault !== undefined) {
66
+ f.serverDefault = await transformServerDefault(name, field, field.serverDefault);
67
+ }
50
68
  transformType(field.type);
51
69
  if (field.getDerivedFields) {
52
- f.derivedFields = processFields(field.getDerivedFields(name));
70
+ f.derivedFields = await processFields(field.getDerivedFields(name));
53
71
  }
54
72
  if (field.type.subFields) {
55
- f.type.subFields = processFields(field.type.subFields);
73
+ f.type.subFields = await processFields(field.type.subFields);
56
74
  }
57
75
  if (field.type.unionFields) {
58
- f.type.unionFields = processFields(field.type.unionFields);
76
+ f.type.unionFields = await processFields(field.type.unionFields);
59
77
  }
60
78
  if (field.type.listElemType &&
61
79
  field.type.listElemType.subFields &&
62
80
  // check to avoid ts-ignore below. exists just for tsc
63
81
  f.type.listElemType) {
64
- f.type.listElemType.subFields = processFields(field.type.listElemType.subFields);
82
+ f.type.listElemType.subFields = await processFields(field.type.listElemType.subFields);
65
83
  }
66
84
  ret.push(f);
67
85
  }
68
86
  return ret;
69
87
  }
88
+ async function transformServerDefault(name, f, value) {
89
+ if (f.valid) {
90
+ if (!(await f.valid(value))) {
91
+ throw new Error(`invalid value ${value} passed to field ${name}`);
92
+ }
93
+ }
94
+ if (f.format) {
95
+ value = await f.format(value);
96
+ }
97
+ switch (typeof value) {
98
+ case "boolean":
99
+ case "number":
100
+ case "bigint":
101
+ case "string":
102
+ return `${value}`;
103
+ default:
104
+ throw new Error(`invalid value ${value} passed to field ${name}`);
105
+ }
106
+ }
70
107
  function transformImportType(typ) {
71
108
  if (!typ.importType) {
72
109
  return;
@@ -108,12 +145,12 @@ function processEdgeGroups(processedSchema, edgeGroups) {
108
145
  processedSchema.assocEdgeGroups.push(group2);
109
146
  }
110
147
  }
111
- function processPattern(patterns, pattern, processedSchema) {
148
+ async function processPattern(patterns, pattern, processedSchema) {
112
149
  let ret = {
113
150
  ...pattern,
114
151
  };
115
152
  const name = pattern.name;
116
- const fields = processFields(pattern.fields, pattern.name);
153
+ const fields = await processFields(pattern.fields, pattern.name);
117
154
  processedSchema.fields.push(...fields);
118
155
  if (pattern.edges) {
119
156
  const edges = processEdges(pattern.edges, pattern.name);
@@ -122,6 +159,23 @@ function processPattern(patterns, pattern, processedSchema) {
122
159
  // flag transformsSelect
123
160
  if (pattern.transformRead) {
124
161
  ret.transformsSelect = true;
162
+ if (pattern.transformReadCodegen_BETA) {
163
+ const r = pattern.transformReadCodegen_BETA();
164
+ if (typeof r === "string") {
165
+ ret.transformsLoaderCodegen = {
166
+ code: r,
167
+ imports: [
168
+ {
169
+ importPath: const_1.PACKAGE,
170
+ import: "query",
171
+ },
172
+ ],
173
+ };
174
+ }
175
+ else {
176
+ ret.transformsLoaderCodegen = r;
177
+ }
178
+ }
125
179
  }
126
180
  if (patterns[name] === undefined) {
127
181
  // intentionally processing separately and not passing pattern.name
@@ -130,6 +184,7 @@ function processPattern(patterns, pattern, processedSchema) {
130
184
  name: pattern.name,
131
185
  assocEdges: edges,
132
186
  fields: fields,
187
+ disableMixin: pattern.disableMixin,
133
188
  };
134
189
  }
135
190
  else {
@@ -162,18 +217,26 @@ function processAction(action) {
162
217
  if (f.nullable === "contentsAndList") {
163
218
  f2.nullable = NullableResult.CONTENTS_AND_LIST;
164
219
  }
165
- else {
220
+ else if (f.nullable === "contents") {
166
221
  f2.nullable = NullableResult.CONTENTS;
167
222
  }
223
+ else if (f.nullable === "true") {
224
+ // shouldn't happen but ran into weirdness where it did...
225
+ f2.nullable = NullableResult.ITEM;
226
+ }
168
227
  }
169
228
  return f2;
170
229
  });
171
230
  ret.actionOnlyFields = actionOnlyFields;
172
231
  return ret;
173
232
  }
174
- function parseSchema(potentialSchemas) {
233
+ async function parseSchema(potentialSchemas, globalSchema) {
175
234
  let schemas = {};
176
235
  let patterns = {};
236
+ let parsedGlobalSchema;
237
+ if (globalSchema) {
238
+ parsedGlobalSchema = await parseGlobalSchema(globalSchema);
239
+ }
177
240
  for (const key in potentialSchemas) {
178
241
  const value = potentialSchemas[key];
179
242
  let schema;
@@ -189,6 +252,7 @@ function parseSchema(potentialSchemas) {
189
252
  }
190
253
  let processedSchema = {
191
254
  fields: [],
255
+ fieldOverrides: schema.fieldOverrides,
192
256
  schemaPath: schema.schemaPath,
193
257
  tableName: schema.tableName,
194
258
  enumTable: schema.enumTable,
@@ -202,14 +266,20 @@ function parseSchema(potentialSchemas) {
202
266
  };
203
267
  // let's put patterns first just so we have id, created_at, updated_at first
204
268
  // ¯\_(ツ)_/¯
269
+ let patternNames = [];
205
270
  if (schema.patterns) {
206
271
  for (const pattern of schema.patterns) {
207
- const ret = processPattern(patterns, pattern, processedSchema);
272
+ const ret = await processPattern(patterns, pattern, processedSchema);
273
+ patternNames.push(pattern.name);
208
274
  if (ret.transformsSelect) {
209
275
  if (processedSchema.transformsSelect) {
210
276
  throw new Error(`can only have one pattern which transforms default querying behavior`);
211
277
  }
212
278
  processedSchema.transformsSelect = true;
279
+ if (ret.transformsLoaderCodegen) {
280
+ processedSchema.transformsLoaderCodegen =
281
+ ret.transformsLoaderCodegen;
282
+ }
213
283
  }
214
284
  if (ret.transformsDelete) {
215
285
  if (processedSchema.transformsDelete) {
@@ -219,8 +289,9 @@ function parseSchema(potentialSchemas) {
219
289
  }
220
290
  }
221
291
  }
222
- const fields = processFields(schema.fields);
292
+ const fields = await processFields(schema.fields);
223
293
  processedSchema.fields.push(...fields);
294
+ processedSchema.patternNames = patternNames;
224
295
  if (schema.edges) {
225
296
  const edges = processEdges(schema.edges);
226
297
  processedSchema.assocEdges.push(...edges);
@@ -230,6 +301,68 @@ function parseSchema(potentialSchemas) {
230
301
  }
231
302
  schemas[key] = processedSchema;
232
303
  }
233
- return { schemas, patterns };
304
+ const rome = translatePrettier();
305
+ return {
306
+ schemas,
307
+ patterns,
308
+ globalSchema: parsedGlobalSchema,
309
+ config: {
310
+ rome,
311
+ },
312
+ };
234
313
  }
235
314
  exports.parseSchema = parseSchema;
315
+ function translatePrettier() {
316
+ const r = (0, cosmiconfig_1.cosmiconfigSync)("prettier").search();
317
+ if (!r) {
318
+ return;
319
+ }
320
+ const ret = {};
321
+ if (r.config.printWidth !== undefined) {
322
+ ret.lineWidth = parseInt(r.config.printWidth);
323
+ }
324
+ if (r.config.useTabs) {
325
+ ret.indentStyle = "tab";
326
+ }
327
+ else {
328
+ ret.indentStyle = "space";
329
+ }
330
+ if (r.config.tabWidth !== undefined) {
331
+ ret.indentSize = parseInt(r.config.tabWidth);
332
+ }
333
+ if (r.config.singleQuote) {
334
+ ret.quoteStyle = "single";
335
+ }
336
+ else {
337
+ ret.quoteStyle = "double";
338
+ }
339
+ if (r.config.quoteProps !== undefined) {
340
+ if (r.config.quoteProps === "consistent") {
341
+ // rome doesn't support this
342
+ ret.quoteProperties = "as-needed";
343
+ }
344
+ else {
345
+ ret.quoteProperties = r.config.quoteProps;
346
+ }
347
+ }
348
+ if (r.config.trailingComma !== undefined) {
349
+ ret.trailingComma = r.config.trailingComma;
350
+ }
351
+ return ret;
352
+ }
353
+ async function parseGlobalSchema(s) {
354
+ const ret = {
355
+ globalEdges: [],
356
+ extraEdgeFields: [],
357
+ initForEdges: !!s.extraEdgeFields ||
358
+ s.transformEdgeRead !== undefined ||
359
+ s.transformEdgeWrite !== undefined,
360
+ };
361
+ if (s.extraEdgeFields) {
362
+ ret.extraEdgeFields = await processFields(s.extraEdgeFields);
363
+ }
364
+ if (s.edges) {
365
+ ret.globalEdges = processEdges(s.edges);
366
+ }
367
+ return ret;
368
+ }
@@ -1,11 +1,12 @@
1
- import { Field, FieldMap, Pattern } from "./schema";
1
+ import { FieldMap, Pattern, FieldOverrideMap } from "./schema";
2
2
  import { Action, AssocEdgeGroup, Constraint, Edge, Index, Schema } from ".";
3
3
  export declare const Timestamps: Pattern;
4
4
  export declare const Node: Pattern;
5
5
  export interface SchemaConfig extends Schema {
6
6
  }
7
7
  export declare class EntSchema implements Schema {
8
- fields: FieldMap | Field[];
8
+ fields: FieldMap;
9
+ fieldOverrides: FieldOverrideMap | undefined;
9
10
  tableName: string | undefined;
10
11
  patterns: Pattern[];
11
12
  edges: Edge[] | undefined;
@@ -21,7 +22,8 @@ export declare class EntSchema implements Schema {
21
22
  constructor(cfg: SchemaConfig);
22
23
  }
23
24
  export declare class EntSchemaWithTZ implements Schema {
24
- fields: FieldMap | Field[];
25
+ fields: FieldMap;
26
+ fieldOverrides: FieldOverrideMap | undefined;
25
27
  tableName: string | undefined;
26
28
  patterns: Pattern[];
27
29
  edges: Edge[] | undefined;
@@ -17,6 +17,7 @@ let tsFields = {
17
17
  defaultValueOnCreate: () => {
18
18
  return new Date();
19
19
  },
20
+ onlyUpdateIfOtherFieldsBeingSet_BETA: true,
20
21
  defaultValueOnEdit: () => {
21
22
  return new Date();
22
23
  },
@@ -66,6 +67,7 @@ let nodeFieldsWithTZ = {
66
67
  exports.Node = {
67
68
  name: "node",
68
69
  fields: nodeFields,
70
+ disableMixin: true,
69
71
  };
70
72
  // Ent schema. has Node Pattern by default.
71
73
  // exists just to have less typing and easier for clients to implement
@@ -73,6 +75,7 @@ class EntSchema {
73
75
  constructor(cfg) {
74
76
  this.patterns = [exports.Node];
75
77
  this.fields = cfg.fields;
78
+ this.fieldOverrides = cfg.fieldOverrides;
76
79
  this.tableName = cfg.tableName;
77
80
  if (cfg.patterns) {
78
81
  this.patterns.push(...cfg.patterns);
@@ -95,9 +98,11 @@ class EntSchemaWithTZ {
95
98
  // default schema added
96
99
  name: "nodeWithTZ",
97
100
  fields: nodeFieldsWithTZ,
101
+ disableMixin: true,
98
102
  },
99
103
  ];
100
104
  this.fields = cfg.fields;
105
+ this.fieldOverrides = cfg.fieldOverrides;
101
106
  this.tableName = cfg.tableName;
102
107
  if (cfg.patterns) {
103
108
  this.patterns.push(...cfg.patterns);
@@ -131,6 +136,7 @@ class BaseEntSchemaWithTZ {
131
136
  // default schema added
132
137
  name: "nodeWithTZ",
133
138
  fields: nodeFieldsWithTZ,
139
+ disableMixin: true,
134
140
  },
135
141
  ];
136
142
  }
package/schema/field.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ import { Builder } from "../action/action";
1
2
  import { Field, FieldMap, FieldOptions, ForeignKey, PolymorphicOptions, Type } from "./schema";
2
3
  export declare abstract class BaseField {
3
4
  name: string;
@@ -24,31 +25,36 @@ export declare class UUIDField extends BaseField implements Field {
24
25
  valid(val: any): Promise<boolean>;
25
26
  }
26
27
  export declare function UUIDType(options?: FieldOptions): UUIDField;
27
- export interface IntegerOptions extends FieldOptions {
28
- min?: number;
29
- max?: number;
28
+ export interface IntegerOptions extends NumberOptions<number> {
30
29
  }
31
- export declare class IntegerField extends BaseField implements Field {
30
+ export interface NumberOptions<T> extends FieldOptions {
31
+ min?: T;
32
+ max?: T;
33
+ }
34
+ export declare class NumberField<T> extends BaseField {
32
35
  type: Type;
33
36
  private validators;
34
37
  private options;
35
- constructor(options?: IntegerOptions);
36
- getOptions(): IntegerOptions;
38
+ constructor(options?: NumberOptions<T>);
39
+ getOptions(): NumberOptions<T>;
37
40
  private handleOptions;
38
- min(l: number): this;
39
- max(l: number): this;
41
+ min(l: T): this;
42
+ max(l: T): this;
40
43
  valid(val: any): boolean;
41
44
  validate(validator: (str: number) => boolean): this;
42
45
  }
46
+ export declare class IntegerField extends NumberField<number> implements Field {
47
+ type: Type;
48
+ }
43
49
  export declare function IntegerType(options?: IntegerOptions): IntegerField;
44
- export declare class BigIntegerField extends BaseField implements Field {
50
+ export declare class BigIntegerField extends NumberField<BigInt> implements Field {
45
51
  type: Type;
46
52
  }
47
- export declare function BigIntegerType(options: FieldOptions): BigIntegerField;
48
- export declare class FloatField extends BaseField implements Field {
53
+ export declare function BigIntegerType(options?: NumberOptions<BigInt>): BigIntegerField;
54
+ export declare class FloatField extends NumberField<number> implements Field {
49
55
  type: Type;
50
56
  }
51
- export declare function FloatType(options?: FieldOptions): FloatField;
57
+ export declare function FloatType(options?: NumberOptions<number>): FloatField;
52
58
  export declare class BooleanField extends BaseField implements Field {
53
59
  type: Type;
54
60
  }
@@ -88,6 +94,18 @@ export declare class StringField extends BaseField implements Field {
88
94
  trimLeft(): this;
89
95
  trimRight(): this;
90
96
  }
97
+ interface PolymorphicStringOptions extends StringOptions {
98
+ parentFieldToValidate: string;
99
+ types?: string[];
100
+ }
101
+ export declare class PolymorphicStringField extends StringField {
102
+ private opts;
103
+ private camelCaseVals;
104
+ constructor(opts: PolymorphicStringOptions);
105
+ validateWithFullData(val: any, b: Builder<any>): boolean;
106
+ valid(val: any): boolean;
107
+ format(val: any): any;
108
+ }
91
109
  export declare function StringType(options?: StringOptions): StringField;
92
110
  export interface TimestampOptions extends FieldOptions {
93
111
  withTimezone?: boolean;
@@ -118,31 +136,67 @@ export declare class DateField extends BaseField implements Field {
118
136
  format(val: any): any;
119
137
  }
120
138
  export declare function DateType(options?: FieldOptions): DateField;
121
- declare type EnumMap = {
139
+ declare type StringEnumMap = {
122
140
  [key: string]: string;
123
141
  };
142
+ /**
143
+ * @deprecated use StringEnumOptions
144
+ */
124
145
  export interface EnumOptions extends FieldOptions {
125
146
  values?: string[];
126
- map?: EnumMap;
147
+ map?: StringEnumMap;
127
148
  tsType?: string;
128
149
  graphQLType?: string;
129
150
  createEnumType?: boolean;
151
+ disableUnknownType?: boolean;
130
152
  }
153
+ /**
154
+ * @deprecated Use StringEnumField
155
+ */
131
156
  export declare class EnumField extends BaseField implements Field {
132
157
  type: Type;
133
158
  private values?;
134
159
  private map?;
135
- constructor(options: EnumOptions);
136
- convertForGQL(value: string): string;
160
+ constructor(options: StringEnumOptions);
161
+ valid(val: any): boolean;
162
+ format(val: any): any;
163
+ }
164
+ export declare class StringEnumField extends EnumField {
165
+ }
166
+ export interface PolymorphicStringEnumOptions extends EnumOptions {
167
+ parentFieldToValidate: string;
168
+ }
169
+ export interface StringEnumOptions extends EnumOptions {
170
+ }
171
+ export declare function EnumType(options: StringEnumOptions): EnumField;
172
+ declare type IntEnumMap = {
173
+ [key: string]: number;
174
+ };
175
+ export interface IntegerEnumOptions extends FieldOptions {
176
+ map: IntEnumMap;
177
+ deprecated?: IntEnumMap;
178
+ tsType?: string;
179
+ graphQLType?: string;
180
+ disableUnknownType?: boolean;
181
+ }
182
+ export declare class IntegerEnumField extends BaseField implements Field {
183
+ type: Type;
184
+ private map;
185
+ constructor(options: IntegerEnumOptions);
137
186
  valid(val: any): boolean;
138
187
  format(val: any): any;
139
188
  }
140
- export declare function EnumType(options: EnumOptions): EnumField;
189
+ export declare function IntegerEnumType(options: IntegerEnumOptions): IntegerEnumField;
190
+ interface ListOptions extends FieldOptions {
191
+ disableJSONStringify?: boolean;
192
+ }
141
193
  export declare class ListField extends BaseField {
142
194
  private field;
195
+ private options?;
143
196
  type: Type;
144
197
  private validators;
145
- constructor(field: Field, options?: FieldOptions);
198
+ constructor(field: Field, options?: ListOptions | undefined);
199
+ __getElemField(): Field;
146
200
  validate(validator: (val: any[]) => boolean): this;
147
201
  valid(val: any): Promise<boolean>;
148
202
  private postgresVal;
@@ -153,7 +207,7 @@ export declare class ListField extends BaseField {
153
207
  range(start: any, stop: any): this;
154
208
  }
155
209
  export declare function StringListType(options?: StringOptions): ListField;
156
- export declare function IntListType(options: FieldOptions): ListField;
210
+ export declare function IntListType(options?: FieldOptions): ListField;
157
211
  export declare function IntegerListType(options?: FieldOptions): ListField;
158
212
  export declare function FloatListType(options?: FieldOptions): ListField;
159
213
  export declare function BigIntegerListType(options: FieldOptions): ListField;
@@ -163,6 +217,7 @@ export declare function TimestamptzListType(options?: TimestampOptions): ListFie
163
217
  export declare function TimeListType(options?: TimeOptions): ListField;
164
218
  export declare function TimetzListType(options: TimeOptions): ListField;
165
219
  export declare function DateListType(options?: FieldOptions): ListField;
166
- export declare function EnumListType(options: EnumOptions): ListField;
220
+ export declare function EnumListType(options: StringEnumOptions): ListField;
221
+ export declare function IntegerEnumListType(options: IntegerEnumOptions): ListField;
167
222
  export declare function UUIDListType(options?: FieldOptions): ListField;
168
223
  export {};