@payloadcms/db-postgres 0.8.6 → 0.8.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (67) hide show
  1. package/dist/connect.d.ts.map +1 -1
  2. package/dist/connect.js +5 -52
  3. package/dist/count.d.ts.map +1 -1
  4. package/dist/count.js +3 -3
  5. package/dist/createMigration.d.ts.map +1 -1
  6. package/dist/createMigration.js +10 -4
  7. package/dist/find/buildFindManyArgs.d.ts.map +1 -1
  8. package/dist/find/buildFindManyArgs.js +2 -1
  9. package/dist/find/findMany.d.ts.map +1 -1
  10. package/dist/find/findMany.js +3 -3
  11. package/dist/find/traverseFields.d.ts +2 -1
  12. package/dist/find/traverseFields.d.ts.map +1 -1
  13. package/dist/find/traverseFields.js +9 -3
  14. package/dist/init.js +3 -2
  15. package/dist/migrate.js +3 -3
  16. package/dist/migrateDown.js +2 -2
  17. package/dist/migrateRefresh.js +2 -2
  18. package/dist/migrateReset.js +3 -3
  19. package/dist/migrateStatus.js +2 -2
  20. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  21. package/dist/queries/getTableColumnFromPath.js +4 -3
  22. package/dist/queries/parseParams.d.ts.map +1 -1
  23. package/dist/queries/parseParams.js +3 -1
  24. package/dist/queries/sanitizeQueryValue.d.ts +2 -1
  25. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
  26. package/dist/queries/sanitizeQueryValue.js +11 -2
  27. package/dist/schema/build.d.ts +10 -2
  28. package/dist/schema/build.d.ts.map +1 -1
  29. package/dist/schema/build.js +23 -6
  30. package/dist/schema/traverseFields.d.ts +6 -1
  31. package/dist/schema/traverseFields.d.ts.map +1 -1
  32. package/dist/schema/traverseFields.js +46 -17
  33. package/dist/transform/read/hasManyNumber.d.ts +2 -1
  34. package/dist/transform/read/hasManyNumber.d.ts.map +1 -1
  35. package/dist/transform/read/hasManyNumber.js +14 -4
  36. package/dist/transform/read/hasManyText.d.ts +2 -1
  37. package/dist/transform/read/hasManyText.d.ts.map +1 -1
  38. package/dist/transform/read/hasManyText.js +14 -4
  39. package/dist/transform/read/relationship.d.ts +2 -1
  40. package/dist/transform/read/relationship.d.ts.map +1 -1
  41. package/dist/transform/read/relationship.js +16 -7
  42. package/dist/transform/read/traverseFields.d.ts +5 -1
  43. package/dist/transform/read/traverseFields.d.ts.map +1 -1
  44. package/dist/transform/read/traverseFields.js +118 -85
  45. package/dist/transform/write/array.d.ts +6 -1
  46. package/dist/transform/write/array.d.ts.map +1 -1
  47. package/dist/transform/write/array.js +7 -3
  48. package/dist/transform/write/blocks.d.ts +6 -1
  49. package/dist/transform/write/blocks.d.ts.map +1 -1
  50. package/dist/transform/write/blocks.js +5 -3
  51. package/dist/transform/write/traverseFields.d.ts +6 -1
  52. package/dist/transform/write/traverseFields.d.ts.map +1 -1
  53. package/dist/transform/write/traverseFields.js +40 -15
  54. package/dist/types.d.ts +9 -5
  55. package/dist/types.d.ts.map +1 -1
  56. package/dist/upsertRow/insertArrays.d.ts.map +1 -1
  57. package/dist/upsertRow/insertArrays.js +5 -2
  58. package/dist/utilities/migrationTableExists.d.ts +2 -2
  59. package/dist/utilities/migrationTableExists.d.ts.map +1 -1
  60. package/dist/utilities/migrationTableExists.js +10 -6
  61. package/dist/utilities/pushDevSchema.d.ts +9 -0
  62. package/dist/utilities/pushDevSchema.d.ts.map +1 -0
  63. package/dist/utilities/pushDevSchema.js +59 -0
  64. package/dist/utilities/requireDrizzleKit.d.ts +14 -0
  65. package/dist/utilities/requireDrizzleKit.d.ts.map +1 -0
  66. package/dist/utilities/requireDrizzleKit.js +13 -0
  67. package/package.json +6 -6
@@ -3,11 +3,12 @@ import type { PostgresAdapter } from '../types';
3
3
  type SanitizeQueryValueArgs = {
4
4
  adapter: PostgresAdapter;
5
5
  field: Field | TabAsField;
6
+ isUUID: boolean;
6
7
  operator: string;
7
8
  relationOrPath: string;
8
9
  val: any;
9
10
  };
10
- export declare const sanitizeQueryValue: ({ adapter, field, operator: operatorArg, relationOrPath, val, }: SanitizeQueryValueArgs) => {
11
+ export declare const sanitizeQueryValue: ({ adapter, field, isUUID, operator: operatorArg, relationOrPath, val, }: SanitizeQueryValueArgs) => {
11
12
  operator: string;
12
13
  value: unknown;
13
14
  };
@@ -1 +1 @@
1
- {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAG7E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,KAAK,sBAAsB,GAAG;IAC5B,OAAO,EAAE,eAAe,CAAA;IACxB,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,oEAM5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;CAyF7D,CAAA"}
1
+ {"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAI7E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,KAAK,sBAAsB,GAAG;IAC5B,OAAO,EAAE,eAAe,CAAA;IACxB,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,MAAM,EAAE,OAAO,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,4EAO5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;CAmG7D,CAAA"}
@@ -11,7 +11,8 @@ Object.defineProperty(exports, "sanitizeQueryValue", {
11
11
  const _errors = require("payload/errors");
12
12
  const _types = require("payload/types");
13
13
  const _utilities = require("payload/utilities");
14
- const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrPath, val })=>{
14
+ const _uuid = require("uuid");
15
+ const sanitizeQueryValue = ({ adapter, field, isUUID, operator: operatorArg, relationOrPath, val })=>{
15
16
  let operator = operatorArg;
16
17
  let formattedValue = val;
17
18
  if (!(0, _types.fieldAffectsData)(field)) return {
@@ -53,6 +54,14 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
53
54
  }
54
55
  if (field.type === 'number' && typeof formattedValue === 'string') {
55
56
  formattedValue = Number(val);
57
+ if (Number.isNaN(formattedValue)) {
58
+ formattedValue = null;
59
+ }
60
+ }
61
+ if (isUUID && typeof formattedValue === 'string') {
62
+ if (!(0, _uuid.validate)(val)) {
63
+ formattedValue = null;
64
+ }
56
65
  }
57
66
  if (field.type === 'date' && operator !== 'exists') {
58
67
  if (typeof val === 'string') {
@@ -97,4 +106,4 @@ const sanitizeQueryValue = ({ adapter, field, operator: operatorArg, relationOrP
97
106
  };
98
107
  };
99
108
 
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL3Nhbml0aXplUXVlcnlWYWx1ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUElFcnJvciB9IGZyb20gJ3BheWxvYWQvZXJyb3JzJ1xuaW1wb3J0IHsgdHlwZSBGaWVsZCwgdHlwZSBUYWJBc0ZpZWxkLCBmaWVsZEFmZmVjdHNEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcbmltcG9ydCB7IGNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MgPSB7XG4gIGFkYXB0ZXI6IFBvc3RncmVzQWRhcHRlclxuICBmaWVsZDogRmllbGQgfCBUYWJBc0ZpZWxkXG4gIG9wZXJhdG9yOiBzdHJpbmdcbiAgcmVsYXRpb25PclBhdGg6IHN0cmluZ1xuICB2YWw6IGFueVxufVxuXG5leHBvcnQgY29uc3Qgc2FuaXRpemVRdWVyeVZhbHVlID0gKHtcbiAgYWRhcHRlcixcbiAgZmllbGQsXG4gIG9wZXJhdG9yOiBvcGVyYXRvckFyZyxcbiAgcmVsYXRpb25PclBhdGgsXG4gIHZhbCxcbn06IFNhbml0aXplUXVlcnlWYWx1ZUFyZ3MpOiB7IG9wZXJhdG9yOiBzdHJpbmc7IHZhbHVlOiB1bmtub3duIH0gPT4ge1xuICBsZXQgb3BlcmF0b3IgPSBvcGVyYXRvckFyZ1xuICBsZXQgZm9ybWF0dGVkVmFsdWUgPSB2YWxcblxuICBpZiAoIWZpZWxkQWZmZWN0c0RhdGEoZmllbGQpKSByZXR1cm4geyBvcGVyYXRvciwgdmFsdWU6IGZvcm1hdHRlZFZhbHVlIH1cblxuICBpZiAoXG4gICAgKGZpZWxkLnR5cGUgPT09ICdyZWxhdGlvbnNoaXAnIHx8IGZpZWxkLnR5cGUgPT09ICd1cGxvYWQnKSAmJlxuICAgICFyZWxhdGlvbk9yUGF0aC5lbmRzV2l0aCgncmVsYXRpb25UbycpICYmXG4gICAgQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSlcbiAgKSB7XG4gICAgY29uc3QgYWxsUG9zc2libGVJRFR5cGVzOiAobnVtYmVyIHwgc3RyaW5nKVtdID0gW11cbiAgICBmb3JtYXR0ZWRWYWx1ZS5mb3JFYWNoKCh2YWwpID0+IHtcbiAgICAgIGlmIChhZGFwdGVyLmlkVHlwZSAhPT0gJ3V1aWQnICYmIHR5cGVvZiB2YWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGFsbFBvc3NpYmxlSURUeXBlcy5wdXNoKHZhbCwgcGFyc2VJbnQodmFsKSlcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYWxsUG9zc2libGVJRFR5cGVzLnB1c2godmFsLCBTdHJpbmcodmFsKSlcbiAgICAgIH1cbiAgICB9KVxuICAgIGZvcm1hdHRlZFZhbHVlID0gYWxsUG9zc2libGVJRFR5cGVzXG4gIH1cblxuICAvLyBDYXN0IGluY29taW5nIHZhbHVlcyBhcyBwcm9wZXIgc2VhcmNoYWJsZSB0eXBlc1xuICBpZiAoZmllbGQudHlwZSA9PT0gJ2NoZWNrYm94JyAmJiB0eXBlb2YgdmFsID09PSAnc3RyaW5nJykge1xuICAgIGlmICh2YWwudG9Mb3dlckNhc2UoKSA9PT0gJ3RydWUnKSBmb3JtYXR0ZWRWYWx1ZSA9IHRydWVcbiAgICBpZiAodmFsLnRvTG93ZXJDYXNlKCkgPT09ICdmYWxzZScpIGZvcm1hdHRlZFZhbHVlID0gZmFsc2VcbiAgfVxuXG4gIGlmIChbJ2FsbCcsICdpbicsICdub3RfaW4nXS5pbmNsdWRlcyhvcGVyYXRvcikpIHtcbiAgICBpZiAodHlwZW9mIGZvcm1hdHRlZFZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBjcmVhdGVBcnJheUZyb21Db21tYURlbGluZWF0ZWQoZm9ybWF0dGVkVmFsdWUpXG5cbiAgICAgIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJykge1xuICAgICAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlLm1hcCgoYXJyYXlWYWwpID0+IHBhcnNlRmxvYXQoYXJyYXlWYWwpKVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghQXJyYXkuaXNBcnJheShmb3JtYXR0ZWRWYWx1ZSkgfHwgZm9ybWF0dGVkVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cbiAgfVxuXG4gIGlmIChmaWVsZC50eXBlID09PSAnbnVtYmVyJyAmJiB0eXBlb2YgZm9ybWF0dGVkVmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBOdW1iZXIodmFsKVxuICB9XG5cbiAgaWYgKGZpZWxkLnR5cGUgPT09ICdkYXRlJyAmJiBvcGVyYXRvciAhPT0gJ2V4aXN0cycpIHtcbiAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IERhdGUodmFsKVxuICAgICAgaWYgKE51bWJlci5pc05hTihEYXRlLnBhcnNlKGZvcm1hdHRlZFZhbHVlKSkpIHtcbiAgICAgICAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiB1bmRlZmluZWQgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsID09PSAnbnVtYmVyJykge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgRGF0ZSh2YWwpXG4gICAgfVxuICB9XG5cbiAgaWYgKFsncmVsYXRpb25zaGlwJywgJ3VwbG9hZCddLmluY2x1ZGVzKGZpZWxkLnR5cGUpKSB7XG4gICAgaWYgKHZhbCA9PT0gJ251bGwnKSB7XG4gICAgICBmb3JtYXR0ZWRWYWx1ZSA9IG51bGxcbiAgICB9XG4gIH1cblxuICBpZiAoJ2hhc01hbnknIGluIGZpZWxkICYmIGZpZWxkLmhhc01hbnkgJiYgb3BlcmF0b3IgPT09ICdjb250YWlucycpIHtcbiAgICBvcGVyYXRvciA9ICdlcXVhbHMnXG4gIH1cblxuICBpZiAob3BlcmF0b3IgPT09ICduZWFyJyB8fCBvcGVyYXRvciA9PT0gJ3dpdGhpbicgfHwgb3BlcmF0b3IgPT09ICdpbnRlcnNlY3RzJykge1xuICAgIHRocm93IG5ldyBBUElFcnJvcihcbiAgICAgIGBRdWVyeWluZyB3aXRoICcke29wZXJhdG9yfScgaXMgbm90IHN1cHBvcnRlZCB3aXRoIHRoZSBwb3N0Z3JlcyBkYXRhYmFzZSBhZGFwdGVyLmAsXG4gICAgKVxuICB9XG5cbiAgaWYgKG9wZXJhdG9yID09PSAnY29udGFpbnMnKSB7XG4gICAgZm9ybWF0dGVkVmFsdWUgPSBgJSR7Zm9ybWF0dGVkVmFsdWV9JWBcbiAgfVxuXG4gIGlmIChvcGVyYXRvciA9PT0gJ2V4aXN0cycpIHtcbiAgICBmb3JtYXR0ZWRWYWx1ZSA9IGZvcm1hdHRlZFZhbHVlID09PSAndHJ1ZScgfHwgZm9ybWF0dGVkVmFsdWUgPT09IHRydWVcbiAgICBpZiAoZm9ybWF0dGVkVmFsdWUgPT09IGZhbHNlKSB7XG4gICAgICBvcGVyYXRvciA9ICdpc051bGwnXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgb3BlcmF0b3IsIHZhbHVlOiBmb3JtYXR0ZWRWYWx1ZSB9XG59XG4iXSwibmFtZXMiOlsic2FuaXRpemVRdWVyeVZhbHVlIiwiYWRhcHRlciIsImZpZWxkIiwib3BlcmF0b3IiLCJvcGVyYXRvckFyZyIsInJlbGF0aW9uT3JQYXRoIiwidmFsIiwiZm9ybWF0dGVkVmFsdWUiLCJmaWVsZEFmZmVjdHNEYXRhIiwidmFsdWUiLCJ0eXBlIiwiZW5kc1dpdGgiLCJBcnJheSIsImlzQXJyYXkiLCJhbGxQb3NzaWJsZUlEVHlwZXMiLCJmb3JFYWNoIiwiaWRUeXBlIiwicHVzaCIsInBhcnNlSW50IiwiU3RyaW5nIiwidG9Mb3dlckNhc2UiLCJpbmNsdWRlcyIsImNyZWF0ZUFycmF5RnJvbUNvbW1hRGVsaW5lYXRlZCIsIm1hcCIsImFycmF5VmFsIiwicGFyc2VGbG9hdCIsImxlbmd0aCIsIk51bWJlciIsIkRhdGUiLCJpc05hTiIsInBhcnNlIiwidW5kZWZpbmVkIiwiaGFzTWFueSIsIkFQSUVycm9yIl0sInJhbmdlTWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7IiwibWFwcGluZ3MiOiI7Ozs7K0JBY2FBOzs7ZUFBQUE7Ozt3QkFkWTt1QkFDcUM7MkJBQ2Y7QUFZeEMsTUFBTUEscUJBQXFCLENBQUMsRUFDakNDLE9BQU8sRUFDUEMsS0FBSyxFQUNMQyxVQUFVQyxXQUFXLEVBQ3JCQyxjQUFjLEVBQ2RDLEdBQUcsRUFDb0I7SUFDdkIsSUFBSUgsV0FBV0M7SUFDZixJQUFJRyxpQkFBaUJEO0lBRXJCLElBQUksQ0FBQ0UsSUFBQUEsdUJBQWdCLEVBQUNOLFFBQVEsT0FBTztRQUFFQztRQUFVTSxPQUFPRjtJQUFlO0lBRXZFLElBQ0UsQUFBQ0wsQ0FBQUEsTUFBTVEsSUFBSSxLQUFLLGtCQUFrQlIsTUFBTVEsSUFBSSxLQUFLLFFBQU8sS0FDeEQsQ0FBQ0wsZUFBZU0sUUFBUSxDQUFDLGlCQUN6QkMsTUFBTUMsT0FBTyxDQUFDTixpQkFDZDtRQUNBLE1BQU1PLHFCQUEwQyxFQUFFO1FBQ2xEUCxlQUFlUSxPQUFPLENBQUMsQ0FBQ1Q7WUFDdEIsSUFBSUwsUUFBUWUsTUFBTSxLQUFLLFVBQVUsT0FBT1YsUUFBUSxVQUFVO2dCQUN4RFEsbUJBQW1CRyxJQUFJLENBQUNYLEtBQUtZLFNBQVNaO1lBQ3hDLE9BQU8sSUFBSSxPQUFPQSxRQUFRLFVBQVU7Z0JBQ2xDUSxtQkFBbUJHLElBQUksQ0FBQ1g7WUFDMUIsT0FBTztnQkFDTFEsbUJBQW1CRyxJQUFJLENBQUNYLEtBQUthLE9BQU9iO1lBQ3RDO1FBQ0Y7UUFDQUMsaUJBQWlCTztJQUNuQjtJQUVBLGtEQUFrRDtJQUNsRCxJQUFJWixNQUFNUSxJQUFJLEtBQUssY0FBYyxPQUFPSixRQUFRLFVBQVU7UUFDeEQsSUFBSUEsSUFBSWMsV0FBVyxPQUFPLFFBQVFiLGlCQUFpQjtRQUNuRCxJQUFJRCxJQUFJYyxXQUFXLE9BQU8sU0FBU2IsaUJBQWlCO0lBQ3REO0lBRUEsSUFBSTtRQUFDO1FBQU87UUFBTTtLQUFTLENBQUNjLFFBQVEsQ0FBQ2xCLFdBQVc7UUFDOUMsSUFBSSxPQUFPSSxtQkFBbUIsVUFBVTtZQUN0Q0EsaUJBQWlCZSxJQUFBQSx5Q0FBOEIsRUFBQ2Y7WUFFaEQsSUFBSUwsTUFBTVEsSUFBSSxLQUFLLFVBQVU7Z0JBQzNCSCxpQkFBaUJBLGVBQWVnQixHQUFHLENBQUMsQ0FBQ0MsV0FBYUMsV0FBV0Q7WUFDL0Q7UUFDRjtRQUVBLElBQUksQ0FBQ1osTUFBTUMsT0FBTyxDQUFDTixtQkFBbUJBLGVBQWVtQixNQUFNLEtBQUssR0FBRztZQUNqRSxPQUFPO1FBQ1Q7SUFDRjtJQUVBLElBQUl4QixNQUFNUSxJQUFJLEtBQUssWUFBWSxPQUFPSCxtQkFBbUIsVUFBVTtRQUNqRUEsaUJBQWlCb0IsT0FBT3JCO0lBQzFCO0lBRUEsSUFBSUosTUFBTVEsSUFBSSxLQUFLLFVBQVVQLGFBQWEsVUFBVTtRQUNsRCxJQUFJLE9BQU9HLFFBQVEsVUFBVTtZQUMzQkMsaUJBQWlCLElBQUlxQixLQUFLdEI7WUFDMUIsSUFBSXFCLE9BQU9FLEtBQUssQ0FBQ0QsS0FBS0UsS0FBSyxDQUFDdkIsa0JBQWtCO2dCQUM1QyxPQUFPO29CQUFFSjtvQkFBVU0sT0FBT3NCO2dCQUFVO1lBQ3RDO1FBQ0Y7UUFFQSxJQUFJLE9BQU96QixRQUFRLFVBQVU7WUFDM0JDLGlCQUFpQixJQUFJcUIsS0FBS3RCO1FBQzVCO0lBQ0Y7SUFFQSxJQUFJO1FBQUM7UUFBZ0I7S0FBUyxDQUFDZSxRQUFRLENBQUNuQixNQUFNUSxJQUFJLEdBQUc7UUFDbkQsSUFBSUosUUFBUSxRQUFRO1lBQ2xCQyxpQkFBaUI7UUFDbkI7SUFDRjtJQUVBLElBQUksYUFBYUwsU0FBU0EsTUFBTThCLE9BQU8sSUFBSTdCLGFBQWEsWUFBWTtRQUNsRUEsV0FBVztJQUNiO0lBRUEsSUFBSUEsYUFBYSxVQUFVQSxhQUFhLFlBQVlBLGFBQWEsY0FBYztRQUM3RSxNQUFNLElBQUk4QixnQkFBUSxDQUNoQixDQUFDLGVBQWUsRUFBRTlCLFNBQVMsc0RBQXNELENBQUM7SUFFdEY7SUFFQSxJQUFJQSxhQUFhLFlBQVk7UUFDM0JJLGlCQUFpQixDQUFDLENBQUMsRUFBRUEsZUFBZSxDQUFDLENBQUM7SUFDeEM7SUFFQSxJQUFJSixhQUFhLFVBQVU7UUFDekJJLGlCQUFpQkEsbUJBQW1CLFVBQVVBLG1CQUFtQjtRQUNqRSxJQUFJQSxtQkFBbUIsT0FBTztZQUM1QkosV0FBVztRQUNiO0lBQ0Y7SUFFQSxPQUFPO1FBQUVBO1FBQVVNLE9BQU9GO0lBQWU7QUFDM0MifQ==
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/sanitizeQueryValue.ts"],"sourcesContent":["import { APIError } from 'payload/errors'\nimport { type Field, type TabAsField, fieldAffectsData } from 'payload/types'\nimport { createArrayFromCommaDelineated } from 'payload/utilities'\nimport { validate as uuidValidate } from 'uuid'\n\nimport type { PostgresAdapter } from '../types'\n\ntype SanitizeQueryValueArgs = {\n  adapter: PostgresAdapter\n  field: Field | TabAsField\n  isUUID: boolean\n  operator: string\n  relationOrPath: string\n  val: any\n}\n\nexport const sanitizeQueryValue = ({\n  adapter,\n  field,\n  isUUID,\n  operator: operatorArg,\n  relationOrPath,\n  val,\n}: SanitizeQueryValueArgs): { operator: string; value: unknown } => {\n  let operator = operatorArg\n  let formattedValue = val\n\n  if (!fieldAffectsData(field)) return { operator, value: formattedValue }\n\n  if (\n    (field.type === 'relationship' || field.type === 'upload') &&\n    !relationOrPath.endsWith('relationTo') &&\n    Array.isArray(formattedValue)\n  ) {\n    const allPossibleIDTypes: (number | string)[] = []\n    formattedValue.forEach((val) => {\n      if (adapter.idType !== 'uuid' && typeof val === 'string') {\n        allPossibleIDTypes.push(val, parseInt(val))\n      } else if (typeof val === 'string') {\n        allPossibleIDTypes.push(val)\n      } else {\n        allPossibleIDTypes.push(val, String(val))\n      }\n    })\n    formattedValue = allPossibleIDTypes\n  }\n\n  // Cast incoming values as proper searchable types\n  if (field.type === 'checkbox' && typeof val === 'string') {\n    if (val.toLowerCase() === 'true') formattedValue = true\n    if (val.toLowerCase() === 'false') formattedValue = false\n  }\n\n  if (['all', 'in', 'not_in'].includes(operator)) {\n    if (typeof formattedValue === 'string') {\n      formattedValue = createArrayFromCommaDelineated(formattedValue)\n\n      if (field.type === 'number') {\n        formattedValue = formattedValue.map((arrayVal) => parseFloat(arrayVal))\n      }\n    }\n\n    if (!Array.isArray(formattedValue) || formattedValue.length === 0) {\n      return null\n    }\n  }\n\n  if (field.type === 'number' && typeof formattedValue === 'string') {\n    formattedValue = Number(val)\n\n    if (Number.isNaN(formattedValue)) {\n      formattedValue = null\n    }\n  }\n\n  if (isUUID && typeof formattedValue === 'string') {\n    if (!uuidValidate(val)) {\n      formattedValue = null\n    }\n  }\n\n  if (field.type === 'date' && operator !== 'exists') {\n    if (typeof val === 'string') {\n      formattedValue = new Date(val)\n      if (Number.isNaN(Date.parse(formattedValue))) {\n        return { operator, value: undefined }\n      }\n    }\n\n    if (typeof val === 'number') {\n      formattedValue = new Date(val)\n    }\n  }\n\n  if (['relationship', 'upload'].includes(field.type)) {\n    if (val === 'null') {\n      formattedValue = null\n    }\n  }\n\n  if ('hasMany' in field && field.hasMany && operator === 'contains') {\n    operator = 'equals'\n  }\n\n  if (operator === 'near' || operator === 'within' || operator === 'intersects') {\n    throw new APIError(\n      `Querying with '${operator}' is not supported with the postgres database adapter.`,\n    )\n  }\n\n  if (operator === 'contains') {\n    formattedValue = `%${formattedValue}%`\n  }\n\n  if (operator === 'exists') {\n    formattedValue = formattedValue === 'true' || formattedValue === true\n    if (formattedValue === false) {\n      operator = 'isNull'\n    }\n  }\n\n  return { operator, value: formattedValue }\n}\n"],"names":["sanitizeQueryValue","adapter","field","isUUID","operator","operatorArg","relationOrPath","val","formattedValue","fieldAffectsData","value","type","endsWith","Array","isArray","allPossibleIDTypes","forEach","idType","push","parseInt","String","toLowerCase","includes","createArrayFromCommaDelineated","map","arrayVal","parseFloat","length","Number","isNaN","uuidValidate","Date","parse","undefined","hasMany","APIError"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import type { ForeignKeyBuilder, IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core';
2
- import { Field } from 'payload/types';
2
+ import type { Field } from 'payload/types';
3
3
  import type { GenericColumns, PostgresAdapter } from '../types';
4
4
  export type BaseExtraConfig = Record<string, (cols: GenericColumns) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder>;
5
5
  type Args = {
@@ -19,12 +19,20 @@ type Args = {
19
19
  tableName: string;
20
20
  timestamps?: boolean;
21
21
  versions: boolean;
22
+ /**
23
+ * Tracks whether or not this table is built
24
+ * from the result of a localized array or block field at some point
25
+ */
26
+ withinLocalizedArrayOrBlock?: boolean;
22
27
  };
23
28
  type Result = {
29
+ hasLocalizedManyNumberField: boolean;
30
+ hasLocalizedManyTextField: boolean;
31
+ hasLocalizedRelationshipField: boolean;
24
32
  hasManyNumberField: 'index' | boolean;
25
33
  hasManyTextField: 'index' | boolean;
26
34
  relationsToBuild: Map<string, string>;
27
35
  };
28
- export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions, }: Args) => Result;
36
+ export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions, withinLocalizedArrayOrBlock, }: Args) => Result;
29
37
  export {};
30
38
  //# sourceMappingURL=build.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,iBAAiB,EACjB,YAAY,EACZ,eAAe,EAEf,uBAAuB,EACxB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAA;AAevD,OAAO,KAAK,EAAE,cAAc,EAAwB,eAAe,EAAE,MAAM,UAAU,CAAA;AAOrF,MAAM,MAAM,eAAe,GAAG,MAAM,CAClC,MAAM,EACN,CAAC,IAAI,EAAE,cAAc,KAAK,iBAAiB,GAAG,YAAY,GAAG,uBAAuB,CACrF,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,eAAe,CAAA;IACjC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,OAAO,CAAA;CAClB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,wQAiBpB,IAAI,KAAG,MAoWT,CAAA"}
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,iBAAiB,EACjB,YAAY,EACZ,eAAe,EAEf,uBAAuB,EACxB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,OAAO,KAAK,EAAE,cAAc,EAAwB,eAAe,EAAE,MAAM,UAAU,CAAA;AAQrF,MAAM,MAAM,eAAe,GAAG,MAAM,CAClC,MAAM,EACN,CAAC,IAAI,EAAE,cAAc,KAAK,iBAAiB,GAAG,YAAY,GAAG,uBAAuB,CACrF,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,eAAe,CAAA;IACjC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,OAAO,CAAA;IACjB;;;OAGG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAA;CACtC,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,qSAkBpB,IAAI,KAAG,MAwXT,CAAA"}
@@ -8,10 +8,11 @@ Object.defineProperty(exports, "buildTable", {
8
8
  return buildTable;
9
9
  }
10
10
  });
11
- const _types = require("payload/types");
12
11
  const _drizzleorm = require("drizzle-orm");
13
12
  const _pgcore = require("drizzle-orm/pg-core");
13
+ const _types = require("payload/types");
14
14
  const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
15
+ const _createIndex = require("./createIndex");
15
16
  const _createTableName = require("./createTableName");
16
17
  const _parentIDColumnMap = require("./parentIDColumnMap");
17
18
  const _setColumnID = require("./setColumnID");
@@ -21,7 +22,7 @@ function _interop_require_default(obj) {
21
22
  default: obj
22
23
  };
23
24
  }
24
- const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions })=>{
25
+ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, versions, withinLocalizedArrayOrBlock })=>{
25
26
  const rootTableName = incomingRootTableName || tableName;
26
27
  const columns = baseColumns;
27
28
  const indexes = {};
@@ -59,7 +60,8 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
59
60
  rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
60
61
  rootTableIDColType: rootTableIDColType || idColType,
61
62
  rootTableName,
62
- versions
63
+ versions,
64
+ withinLocalizedArrayOrBlock
63
65
  });
64
66
  if (timestamps) {
65
67
  columns.createdAt = (0, _pgcore.timestamp)('created_at', {
@@ -237,16 +239,28 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
237
239
  const relatedCollectionCustomIDType = relatedCollectionCustomID?.type;
238
240
  if (relatedCollectionCustomIDType === 'number') colType = 'numeric';
239
241
  if (relatedCollectionCustomIDType === 'text') colType = 'varchar';
240
- relationshipColumns[`${relationTo}ID`] = _parentIDColumnMap.parentIDColumnMap[colType](`${formattedRelationTo}_id`);
242
+ const colName = `${relationTo}ID`;
243
+ relationshipColumns[colName] = _parentIDColumnMap.parentIDColumnMap[colType](`${formattedRelationTo}_id`);
241
244
  relationExtraConfig[`${relationTo}IdFk`] = (cols)=>(0, _pgcore.foreignKey)({
242
245
  name: `${relationshipsTableName}_${(0, _tosnakecase.default)(relationTo)}_fk`,
243
246
  columns: [
244
- cols[`${relationTo}ID`]
247
+ cols[colName]
245
248
  ],
246
249
  foreignColumns: [
247
250
  adapter.tables[formattedRelationTo].id
248
251
  ]
249
252
  }).onDelete('cascade');
253
+ const indexName = [
254
+ colName
255
+ ];
256
+ if (hasLocalizedRelationshipField) {
257
+ indexName.push('locale');
258
+ }
259
+ relationExtraConfig[`${relationTo}IdIdx`] = (0, _createIndex.createIndex)({
260
+ name: indexName,
261
+ columnName: `${formattedRelationTo}_id`,
262
+ tableName: relationshipsTableName
263
+ });
250
264
  });
251
265
  relationshipsTable = adapter.pgSchema.table(relationshipsTableName, relationshipColumns, (cols)=>{
252
266
  const result = Object.entries(relationExtraConfig).reduce((config, [key, func])=>{
@@ -328,10 +342,13 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumb
328
342
  });
329
343
  adapter.relations[`relations_${tableName}`] = tableRelations;
330
344
  return {
345
+ hasLocalizedManyNumberField,
346
+ hasLocalizedManyTextField,
347
+ hasLocalizedRelationshipField,
331
348
  hasManyNumberField,
332
349
  hasManyTextField,
333
350
  relationsToBuild
334
351
  };
335
352
  };
336
353
 
337
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type {\n  ForeignKeyBuilder,\n  IndexBuilder,\n  PgColumnBuilder,\n  PgTableWithColumns,\n  UniqueConstraintBuilder,\n} from 'drizzle-orm/pg-core'\nimport { Field, fieldAffectsData } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  foreignKey,\n  index,\n  integer,\n  numeric,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, IDType, PostgresAdapter } from '../types'\n\nimport { createTableName } from './createTableName'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { setColumnID } from './setColumnID'\nimport { traverseFields } from './traverseFields'\n\nexport type BaseExtraConfig = Record<\n  string,\n  (cols: GenericColumns) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder\n>\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: BaseExtraConfig\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  buildTexts?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n  versions: boolean\n}\n\ntype Result = {\n  hasManyNumberField: 'index' | boolean\n  hasManyTextField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  buildTexts,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n  versions,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable | PgTableWithColumns<any>\n  let textsTable: GenericTable | PgTableWithColumns<any>\n  let numbersTable: GenericTable | PgTableWithColumns<any>\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable | PgTableWithColumns<any>\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType: IDType = setColumnID({ adapter, columns, fields })\n\n  const {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    buildTexts,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n    versions,\n  })\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = adapter.pgSchema.table(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    const result = Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n\n    return result\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}${adapter.localesSuffix}`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id').notNull()\n\n    localesTable = adapter.pgSchema.table(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n          _parentIdFk: foreignKey({\n            name: `${localeTableName}_parent_id_fk`,\n            columns: [cols._parentID],\n            foreignColumns: [table.id],\n          }).onDelete('cascade'),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n      path: varchar('path').notNull(),\n      text: varchar('text'),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = adapter.pgSchema.table(textsTableName, columns, (cols) => {\n      const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n        orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n        parentFk: foreignKey({\n          name: `${textsTableName}_parent_fk`,\n          columns: [cols.parent],\n          foreignColumns: [table.id],\n        }).onDelete('cascade'),\n      }\n\n      if (hasManyTextField === 'index') {\n        config.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        config.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent)\n      }\n\n      return config\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = adapter.pgSchema.table(numbersTableName, columns, (cols) => {\n      const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n        orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n        parentFk: foreignKey({\n          name: `${numbersTableName}_parent_fk`,\n          columns: [cols.parent],\n          foreignColumns: [table.id],\n        }).onDelete('cascade'),\n      }\n\n      if (hasManyNumberField === 'index') {\n        config.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        config.localeParent = index(`${numbersTableName}_locale_parent`).on(\n          cols.locale,\n          cols.parent,\n        )\n      }\n\n      return config\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      const relationExtraConfig: BaseExtraConfig = {}\n\n      const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`\n\n      relationships.forEach((relationTo) => {\n        const relationshipConfig = adapter.payload.collections[relationTo].config\n        const formattedRelationTo = createTableName({\n          adapter,\n          config: relationshipConfig,\n          throwValidationError: true,\n        })\n        let colType = adapter.idType === 'uuid' ? 'uuid' : 'integer'\n\n        const relatedCollectionCustomID = relationshipConfig.fields.find(\n          (field) => fieldAffectsData(field) && field.name === 'id',\n        )\n        const relatedCollectionCustomIDType = relatedCollectionCustomID?.type\n\n        if (relatedCollectionCustomIDType === 'number') colType = 'numeric'\n        if (relatedCollectionCustomIDType === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        )\n\n        relationExtraConfig[`${relationTo}IdFk`] = (cols) =>\n          foreignKey({\n            name: `${relationshipsTableName}_${toSnakeCase(relationTo)}_fk`,\n            columns: [cols[`${relationTo}ID`]],\n            foreignColumns: [adapter.tables[formattedRelationTo].id],\n          }).onDelete('cascade')\n      })\n\n      relationshipsTable = adapter.pgSchema.table(\n        relationshipsTableName,\n        relationshipColumns,\n        (cols) => {\n          const result: Record<string, ForeignKeyBuilder | IndexBuilder> = Object.entries(\n            relationExtraConfig,\n          ).reduce(\n            (config, [key, func]) => {\n              config[key] = func(cols)\n              return config\n            },\n            {\n              order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n              parentFk: foreignKey({\n                name: `${relationshipsTableName}_parent_fk`,\n                columns: [cols.parent],\n                foreignColumns: [table.id],\n              }).onDelete('cascade'),\n              parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n              pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n            },\n          )\n\n          if (hasLocalizedRelationshipField) {\n            result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n          }\n\n          return result\n        },\n      )\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = createTableName({\n            adapter,\n            config: adapter.payload.collections[relationTo].config,\n            throwValidationError: true,\n          })\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyNumberField, hasManyTextField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","buildTexts","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","versions","columns","indexes","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","setColumnID","hasLocalizedField","hasLocalizedManyNumberField","hasLocalizedManyTextField","hasLocalizedRelationshipField","hasManyNumberField","hasManyTextField","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgSchema","cols","extraConfig","Object","entries","reduce","config","key","func","result","acc","colName","tables","localeTableName","localesSuffix","id","serial","primaryKey","_locale","enums","enum__locales","_parentID","parentIDColumnMap","_localeParent","unique","on","_parentIdFk","foreignKey","name","foreignColumns","onDelete","localesTableRelations","relations","one","references","textsTableName","order","integer","parent","path","varchar","text","locale","orderParentIdx","index","parentFk","text_idx","localeParent","textsTableRelations","numbersTableName","number","numeric","numberIdx","numbersTableRelations","size","relationshipColumns","relationExtraConfig","relationshipsTableName","relationshipsSuffix","forEach","relationTo","relationshipConfig","payload","collections","formattedRelationTo","createTableName","throwValidationError","colType","idType","relatedCollectionCustomID","find","field","fieldAffectsData","relatedCollectionCustomIDType","type","toSnakeCase","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
354
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type {\n  ForeignKeyBuilder,\n  IndexBuilder,\n  PgColumnBuilder,\n  PgTableWithColumns,\n  UniqueConstraintBuilder,\n} from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  foreignKey,\n  index,\n  integer,\n  numeric,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, IDType, PostgresAdapter } from '../types'\n\nimport { createIndex } from './createIndex'\nimport { createTableName } from './createTableName'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { setColumnID } from './setColumnID'\nimport { traverseFields } from './traverseFields'\n\nexport type BaseExtraConfig = Record<\n  string,\n  (cols: GenericColumns) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder\n>\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: BaseExtraConfig\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  buildTexts?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n  versions: boolean\n  /**\n   * Tracks whether or not this table is built\n   * from the result of a localized array or block field at some point\n   */\n  withinLocalizedArrayOrBlock?: boolean\n}\n\ntype Result = {\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedManyTextField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n  hasManyTextField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  buildTexts,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n  versions,\n  withinLocalizedArrayOrBlock,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable | PgTableWithColumns<any>\n  let textsTable: GenericTable | PgTableWithColumns<any>\n  let numbersTable: GenericTable | PgTableWithColumns<any>\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable | PgTableWithColumns<any>\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType: IDType = setColumnID({ adapter, columns, fields })\n\n  const {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    buildTexts,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n    versions,\n    withinLocalizedArrayOrBlock,\n  })\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = adapter.pgSchema.table(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    const result = Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n\n    return result\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}${adapter.localesSuffix}`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id').notNull()\n\n    localesTable = adapter.pgSchema.table(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n          _parentIdFk: foreignKey({\n            name: `${localeTableName}_parent_id_fk`,\n            columns: [cols._parentID],\n            foreignColumns: [table.id],\n          }).onDelete('cascade'),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n      path: varchar('path').notNull(),\n      text: varchar('text'),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = adapter.pgSchema.table(textsTableName, columns, (cols) => {\n      const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n        orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n        parentFk: foreignKey({\n          name: `${textsTableName}_parent_fk`,\n          columns: [cols.parent],\n          foreignColumns: [table.id],\n        }).onDelete('cascade'),\n      }\n\n      if (hasManyTextField === 'index') {\n        config.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        config.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent)\n      }\n\n      return config\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = adapter.pgSchema.table(numbersTableName, columns, (cols) => {\n      const config: Record<string, ForeignKeyBuilder | IndexBuilder> = {\n        orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n        parentFk: foreignKey({\n          name: `${numbersTableName}_parent_fk`,\n          columns: [cols.parent],\n          foreignColumns: [table.id],\n        }).onDelete('cascade'),\n      }\n\n      if (hasManyNumberField === 'index') {\n        config.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        config.localeParent = index(`${numbersTableName}_locale_parent`).on(\n          cols.locale,\n          cols.parent,\n        )\n      }\n\n      return config\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id').notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      const relationExtraConfig: BaseExtraConfig = {}\n\n      const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`\n\n      relationships.forEach((relationTo) => {\n        const relationshipConfig = adapter.payload.collections[relationTo].config\n        const formattedRelationTo = createTableName({\n          adapter,\n          config: relationshipConfig,\n          throwValidationError: true,\n        })\n        let colType = adapter.idType === 'uuid' ? 'uuid' : 'integer'\n\n        const relatedCollectionCustomID = relationshipConfig.fields.find(\n          (field) => fieldAffectsData(field) && field.name === 'id',\n        )\n        const relatedCollectionCustomIDType = relatedCollectionCustomID?.type\n\n        if (relatedCollectionCustomIDType === 'number') colType = 'numeric'\n        if (relatedCollectionCustomIDType === 'text') colType = 'varchar'\n\n        const colName = `${relationTo}ID`\n\n        relationshipColumns[colName] = parentIDColumnMap[colType](`${formattedRelationTo}_id`)\n\n        relationExtraConfig[`${relationTo}IdFk`] = (cols) =>\n          foreignKey({\n            name: `${relationshipsTableName}_${toSnakeCase(relationTo)}_fk`,\n            columns: [cols[colName]],\n            foreignColumns: [adapter.tables[formattedRelationTo].id],\n          }).onDelete('cascade')\n\n        const indexName = [colName]\n\n        if (hasLocalizedRelationshipField) {\n          indexName.push('locale')\n        }\n\n        relationExtraConfig[`${relationTo}IdIdx`] = createIndex({\n          name: indexName,\n          columnName: `${formattedRelationTo}_id`,\n          tableName: relationshipsTableName,\n        })\n      })\n\n      relationshipsTable = adapter.pgSchema.table(\n        relationshipsTableName,\n        relationshipColumns,\n        (cols) => {\n          const result: Record<string, ForeignKeyBuilder | IndexBuilder> = Object.entries(\n            relationExtraConfig,\n          ).reduce(\n            (config, [key, func]) => {\n              config[key] = func(cols)\n              return config\n            },\n            {\n              order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n              parentFk: foreignKey({\n                name: `${relationshipsTableName}_parent_fk`,\n                columns: [cols.parent],\n                foreignColumns: [table.id],\n              }).onDelete('cascade'),\n              parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n              pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n            },\n          )\n\n          if (hasLocalizedRelationshipField) {\n            result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n          }\n\n          return result\n        },\n      )\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = createTableName({\n            adapter,\n            config: adapter.payload.collections[relationTo].config,\n            throwValidationError: true,\n          })\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return {\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n    relationsToBuild,\n  }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","buildTexts","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","versions","withinLocalizedArrayOrBlock","columns","indexes","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","setColumnID","hasLocalizedField","hasLocalizedManyNumberField","hasLocalizedManyTextField","hasLocalizedRelationshipField","hasManyNumberField","hasManyTextField","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgSchema","cols","extraConfig","Object","entries","reduce","config","key","func","result","acc","colName","tables","localeTableName","localesSuffix","id","serial","primaryKey","_locale","enums","enum__locales","_parentID","parentIDColumnMap","_localeParent","unique","on","_parentIdFk","foreignKey","name","foreignColumns","onDelete","localesTableRelations","relations","one","references","textsTableName","order","integer","parent","path","varchar","text","locale","orderParentIdx","index","parentFk","text_idx","localeParent","textsTableRelations","numbersTableName","number","numeric","numberIdx","numbersTableRelations","size","relationshipColumns","relationExtraConfig","relationshipsTableName","relationshipsSuffix","forEach","relationTo","relationshipConfig","payload","collections","formattedRelationTo","createTableName","throwValidationError","colType","idType","relatedCollectionCustomID","find","field","fieldAffectsData","relatedCollectionCustomIDType","type","toSnakeCase","indexName","push","createIndex","columnName","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -24,6 +24,11 @@ type Args = {
24
24
  rootTableIDColType: string;
25
25
  rootTableName: string;
26
26
  versions: boolean;
27
+ /**
28
+ * Tracks whether or not this table is built
29
+ * from the result of a localized array or block field at some point
30
+ */
31
+ withinLocalizedArrayOrBlock?: boolean;
27
32
  };
28
33
  type Result = {
29
34
  hasLocalizedField: boolean;
@@ -33,6 +38,6 @@ type Result = {
33
38
  hasManyNumberField: 'index' | boolean;
34
39
  hasManyTextField: 'index' | boolean;
35
40
  };
36
- export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, buildTexts, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, versions, }: Args) => Result;
41
+ export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, buildTexts, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, versions, withinLocalizedArrayOrBlock, }: Args) => Result;
37
42
  export {};
38
43
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACxE,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAsBtD,OAAO,KAAK,EAAE,cAAc,EAAU,eAAe,EAAE,MAAM,UAAU,CAAA;AAWvE,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;IACrB,QAAQ,EAAE,OAAO,CAAA;CAClB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,sUAuBxB,IAAI,KAAG,MAsnBT,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACxE,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAqBtD,OAAO,KAAK,EAAE,cAAc,EAAU,eAAe,EAAE,MAAM,UAAU,CAAA;AAWvE,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;IACrB,QAAQ,EAAE,OAAO,CAAA;IACjB;;;OAGG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAA;CACtC,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,mWAwBxB,IAAI,KAAG,MAqrBT,CAAA"}