@payloadcms/db-sqlite 3.7.0 → 3.7.1-canary.a7f8738

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 (62) hide show
  1. package/dist/columnToCodeConverter.d.ts +3 -0
  2. package/dist/columnToCodeConverter.d.ts.map +1 -0
  3. package/dist/columnToCodeConverter.js +92 -0
  4. package/dist/columnToCodeConverter.js.map +1 -0
  5. package/dist/drizzle-proxy/index.d.ts +2 -0
  6. package/dist/drizzle-proxy/index.d.ts.map +1 -0
  7. package/dist/drizzle-proxy/index.js +3 -0
  8. package/dist/drizzle-proxy/index.js.map +1 -0
  9. package/dist/drizzle-proxy/libsql.d.ts +2 -0
  10. package/dist/drizzle-proxy/libsql.d.ts.map +1 -0
  11. package/dist/drizzle-proxy/libsql.js +3 -0
  12. package/dist/drizzle-proxy/libsql.js.map +1 -0
  13. package/dist/drizzle-proxy/relations.d.ts +2 -0
  14. package/dist/drizzle-proxy/relations.d.ts.map +1 -0
  15. package/dist/drizzle-proxy/relations.js +3 -0
  16. package/dist/drizzle-proxy/relations.js.map +1 -0
  17. package/dist/drizzle-proxy/sqlite-core.d.ts +2 -0
  18. package/dist/drizzle-proxy/sqlite-core.d.ts.map +1 -0
  19. package/dist/drizzle-proxy/sqlite-core.js +3 -0
  20. package/dist/drizzle-proxy/sqlite-core.js.map +1 -0
  21. package/dist/index.d.ts.map +1 -1
  22. package/dist/index.js +10 -1
  23. package/dist/index.js.map +1 -1
  24. package/dist/init.d.ts.map +1 -1
  25. package/dist/init.js +24 -102
  26. package/dist/init.js.map +1 -1
  27. package/dist/schema/buildDrizzleTable.d.ts +3 -0
  28. package/dist/schema/buildDrizzleTable.d.ts.map +1 -0
  29. package/dist/schema/buildDrizzleTable.js +125 -0
  30. package/dist/schema/buildDrizzleTable.js.map +1 -0
  31. package/dist/schema/setColumnID.d.ts +2 -9
  32. package/dist/schema/setColumnID.d.ts.map +1 -1
  33. package/dist/schema/setColumnID.js +15 -4
  34. package/dist/schema/setColumnID.js.map +1 -1
  35. package/dist/types.d.ts +13 -6
  36. package/dist/types.d.ts.map +1 -1
  37. package/dist/types.js.map +1 -1
  38. package/package.json +25 -5
  39. package/dist/schema/build.d.ts +0 -52
  40. package/dist/schema/build.d.ts.map +0 -1
  41. package/dist/schema/build.js +0 -440
  42. package/dist/schema/build.js.map +0 -1
  43. package/dist/schema/createIndex.d.ts +0 -11
  44. package/dist/schema/createIndex.d.ts.map +0 -1
  45. package/dist/schema/createIndex.js +0 -20
  46. package/dist/schema/createIndex.js.map +0 -1
  47. package/dist/schema/getIDColumn.d.ts +0 -8
  48. package/dist/schema/getIDColumn.d.ts.map +0 -1
  49. package/dist/schema/getIDColumn.js +0 -24
  50. package/dist/schema/getIDColumn.js.map +0 -1
  51. package/dist/schema/idToUUID.d.ts +0 -3
  52. package/dist/schema/idToUUID.d.ts.map +0 -1
  53. package/dist/schema/idToUUID.js +0 -11
  54. package/dist/schema/idToUUID.js.map +0 -1
  55. package/dist/schema/traverseFields.d.ts +0 -44
  56. package/dist/schema/traverseFields.d.ts.map +0 -1
  57. package/dist/schema/traverseFields.js +0 -610
  58. package/dist/schema/traverseFields.js.map +0 -1
  59. package/dist/schema/withDefault.d.ts +0 -4
  60. package/dist/schema/withDefault.d.ts.map +0 -1
  61. package/dist/schema/withDefault.js +0 -12
  62. package/dist/schema/withDefault.js.map +0 -1
@@ -1,440 +0,0 @@
1
- import { buildIndexName, createTableName } from '@payloadcms/drizzle';
2
- import { relations, sql } from 'drizzle-orm';
3
- import { foreignKey, index, integer, numeric, sqliteTable, text, unique } from 'drizzle-orm/sqlite-core';
4
- import toSnakeCase from 'to-snake-case';
5
- import { createIndex } from './createIndex.js';
6
- import { getIDColumn } from './getIDColumn.js';
7
- import { setColumnID } from './setColumnID.js';
8
- import { traverseFields } from './traverseFields.js';
9
- export const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, disableNotNull, disableRelsTableUnique, disableUnique = false, fields, locales, rootRelationships, rootRelationsToBuild, rootTableIDColType, rootTableName: incomingRootTableName, rootUniqueRelationships, tableName, timestamps, versions, withinLocalizedArrayOrBlock })=>{
10
- const isRoot = !incomingRootTableName;
11
- const rootTableName = incomingRootTableName || tableName;
12
- const columns = baseColumns;
13
- const indexes = {};
14
- const localesColumns = {};
15
- const localesIndexes = {};
16
- let localesTable;
17
- let textsTable;
18
- let numbersTable;
19
- // Relationships to the base collection
20
- const relationships = rootRelationships || new Set();
21
- const uniqueRelationships = rootUniqueRelationships || new Set();
22
- let relationshipsTable;
23
- // Drizzle relations
24
- const relationsToBuild = new Map();
25
- const idColType = setColumnID({
26
- columns,
27
- fields
28
- });
29
- const { hasLocalizedField, hasLocalizedManyNumberField, hasLocalizedManyTextField, hasLocalizedRelationshipField, hasManyNumberField, hasManyTextField } = traverseFields({
30
- adapter,
31
- columns,
32
- disableNotNull,
33
- disableRelsTableUnique,
34
- disableUnique,
35
- fields,
36
- indexes,
37
- locales,
38
- localesColumns,
39
- localesIndexes,
40
- newTableName: tableName,
41
- parentTableName: tableName,
42
- relationships,
43
- relationsToBuild,
44
- rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
45
- rootTableIDColType: rootTableIDColType || idColType,
46
- rootTableName,
47
- uniqueRelationships,
48
- versions,
49
- withinLocalizedArrayOrBlock
50
- });
51
- // split the relationsToBuild by localized and non-localized
52
- const localizedRelations = new Map();
53
- const nonLocalizedRelations = new Map();
54
- relationsToBuild.forEach(({ type, localized, relationName, target }, key)=>{
55
- const map = localized ? localizedRelations : nonLocalizedRelations;
56
- map.set(key, {
57
- type,
58
- relationName,
59
- target
60
- });
61
- });
62
- if (timestamps) {
63
- columns.createdAt = text('created_at').default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`).notNull();
64
- columns.updatedAt = text('updated_at').default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`).notNull();
65
- }
66
- const table = sqliteTable(tableName, columns, (cols)=>{
67
- const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func])=>{
68
- config[key] = func(cols);
69
- return config;
70
- }, {});
71
- const result = Object.entries(indexes).reduce((acc, [colName, func])=>{
72
- acc[colName] = func(cols);
73
- return acc;
74
- }, extraConfig);
75
- return result;
76
- });
77
- adapter.tables[tableName] = table;
78
- if (hasLocalizedField || localizedRelations.size) {
79
- const localeTableName = `${tableName}${adapter.localesSuffix}`;
80
- localesColumns.id = integer('id', {
81
- mode: 'number'
82
- }).primaryKey({
83
- autoIncrement: true
84
- });
85
- localesColumns._locale = text('_locale', {
86
- enum: locales
87
- }).notNull();
88
- localesColumns._parentID = getIDColumn({
89
- name: '_parent_id',
90
- type: idColType,
91
- notNull: true,
92
- primaryKey: false
93
- });
94
- localesTable = sqliteTable(localeTableName, localesColumns, (cols)=>{
95
- return Object.entries(localesIndexes).reduce((acc, [colName, func])=>{
96
- acc[colName] = func(cols);
97
- return acc;
98
- }, {
99
- _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(cols._locale, cols._parentID),
100
- _parentIdFk: foreignKey({
101
- name: `${localeTableName}_parent_id_fk`,
102
- columns: [
103
- cols._parentID
104
- ],
105
- foreignColumns: [
106
- table.id
107
- ]
108
- }).onDelete('cascade')
109
- });
110
- });
111
- adapter.tables[localeTableName] = localesTable;
112
- adapter.relations[`relations_${localeTableName}`] = relations(localesTable, ({ many, one })=>{
113
- const result = {};
114
- result._parentID = one(table, {
115
- fields: [
116
- localesTable._parentID
117
- ],
118
- references: [
119
- table.id
120
- ],
121
- // name the relationship by what the many() relationName is
122
- relationName: '_locales'
123
- });
124
- localizedRelations.forEach(({ type, target }, key)=>{
125
- if (type === 'one') {
126
- result[key] = one(adapter.tables[target], {
127
- fields: [
128
- localesTable[key]
129
- ],
130
- references: [
131
- adapter.tables[target].id
132
- ],
133
- relationName: key
134
- });
135
- }
136
- if (type === 'many') {
137
- result[key] = many(adapter.tables[target], {
138
- relationName: key
139
- });
140
- }
141
- });
142
- return result;
143
- });
144
- }
145
- if (isRoot) {
146
- if (hasManyTextField) {
147
- const textsTableName = `${rootTableName}_texts`;
148
- const columns = {
149
- id: integer('id', {
150
- mode: 'number'
151
- }).primaryKey({
152
- autoIncrement: true
153
- }),
154
- order: integer('order').notNull(),
155
- parent: getIDColumn({
156
- name: 'parent_id',
157
- type: idColType,
158
- notNull: true,
159
- primaryKey: false
160
- }),
161
- path: text('path').notNull(),
162
- text: text('text')
163
- };
164
- if (hasLocalizedManyTextField) {
165
- columns.locale = text('locale', {
166
- enum: locales
167
- });
168
- }
169
- textsTable = sqliteTable(textsTableName, columns, (cols)=>{
170
- const config = {
171
- orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),
172
- parentFk: foreignKey({
173
- name: `${textsTableName}_parent_fk`,
174
- columns: [
175
- cols.parent
176
- ],
177
- foreignColumns: [
178
- table.id
179
- ]
180
- }).onDelete('cascade')
181
- };
182
- if (hasManyTextField === 'index') {
183
- config.text_idx = index(`${textsTableName}_text_idx`).on(cols.text);
184
- }
185
- if (hasLocalizedManyTextField) {
186
- config.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent);
187
- }
188
- return config;
189
- });
190
- adapter.tables[textsTableName] = textsTable;
191
- adapter.relations[`relations_${textsTableName}`] = relations(textsTable, ({ one })=>({
192
- parent: one(table, {
193
- fields: [
194
- textsTable.parent
195
- ],
196
- references: [
197
- table.id
198
- ],
199
- relationName: '_texts'
200
- })
201
- }));
202
- }
203
- if (hasManyNumberField) {
204
- const numbersTableName = `${rootTableName}_numbers`;
205
- const columns = {
206
- id: integer('id', {
207
- mode: 'number'
208
- }).primaryKey({
209
- autoIncrement: true
210
- }),
211
- number: numeric('number'),
212
- order: integer('order').notNull(),
213
- parent: getIDColumn({
214
- name: 'parent_id',
215
- type: idColType,
216
- notNull: true,
217
- primaryKey: false
218
- }),
219
- path: text('path').notNull()
220
- };
221
- if (hasLocalizedManyNumberField) {
222
- columns.locale = text('locale', {
223
- enum: locales
224
- });
225
- }
226
- numbersTable = sqliteTable(numbersTableName, columns, (cols)=>{
227
- const config = {
228
- orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),
229
- parentFk: foreignKey({
230
- name: `${numbersTableName}_parent_fk`,
231
- columns: [
232
- cols.parent
233
- ],
234
- foreignColumns: [
235
- table.id
236
- ]
237
- }).onDelete('cascade')
238
- };
239
- if (hasManyNumberField === 'index') {
240
- config.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number);
241
- }
242
- if (hasLocalizedManyNumberField) {
243
- config.localeParent = index(`${numbersTableName}_locale_parent`).on(cols.locale, cols.parent);
244
- }
245
- return config;
246
- });
247
- adapter.tables[numbersTableName] = numbersTable;
248
- adapter.relations[`relations_${numbersTableName}`] = relations(numbersTable, ({ one })=>({
249
- parent: one(table, {
250
- fields: [
251
- numbersTable.parent
252
- ],
253
- references: [
254
- table.id
255
- ],
256
- relationName: '_numbers'
257
- })
258
- }));
259
- }
260
- if (relationships.size) {
261
- const relationshipColumns = {
262
- id: integer('id', {
263
- mode: 'number'
264
- }).primaryKey({
265
- autoIncrement: true
266
- }),
267
- order: integer('order'),
268
- parent: getIDColumn({
269
- name: 'parent_id',
270
- type: idColType,
271
- notNull: true,
272
- primaryKey: false
273
- }),
274
- path: text('path').notNull()
275
- };
276
- if (hasLocalizedRelationshipField) {
277
- relationshipColumns.locale = text('locale', {
278
- enum: locales
279
- });
280
- }
281
- const relationExtraConfig = {};
282
- const relationshipsTableName = `${tableName}${adapter.relationshipsSuffix}`;
283
- relationships.forEach((relationTo)=>{
284
- const relationshipConfig = adapter.payload.collections[relationTo].config;
285
- const formattedRelationTo = createTableName({
286
- adapter,
287
- config: relationshipConfig
288
- });
289
- let colType = 'integer';
290
- const relatedCollectionCustomIDType = adapter.payload.collections[relationshipConfig.slug]?.customIDType;
291
- if (relatedCollectionCustomIDType === 'number') {
292
- colType = 'numeric';
293
- }
294
- if (relatedCollectionCustomIDType === 'text') {
295
- colType = 'text';
296
- }
297
- const colName = `${relationTo}ID`;
298
- relationshipColumns[colName] = getIDColumn({
299
- name: `${formattedRelationTo}_id`,
300
- type: colType,
301
- primaryKey: false
302
- });
303
- relationExtraConfig[`${relationTo}IdFk`] = (cols)=>foreignKey({
304
- name: `${relationshipsTableName}_${toSnakeCase(relationTo)}_fk`,
305
- columns: [
306
- cols[colName]
307
- ],
308
- foreignColumns: [
309
- adapter.tables[formattedRelationTo].id
310
- ]
311
- }).onDelete('cascade');
312
- const indexColumns = [
313
- colName
314
- ];
315
- const unique = !disableUnique && uniqueRelationships.has(relationTo);
316
- if (unique) {
317
- indexColumns.push('path');
318
- }
319
- if (hasLocalizedRelationshipField) {
320
- indexColumns.push('locale');
321
- }
322
- const indexName = buildIndexName({
323
- name: `${relationshipsTableName}_${formattedRelationTo}_id`,
324
- adapter: adapter
325
- });
326
- relationExtraConfig[indexName] = createIndex({
327
- name: indexColumns,
328
- indexName,
329
- unique
330
- });
331
- });
332
- relationshipsTable = sqliteTable(relationshipsTableName, relationshipColumns, (cols)=>{
333
- const result = Object.entries(relationExtraConfig).reduce((config, [key, func])=>{
334
- config[key] = func(cols);
335
- return config;
336
- }, {
337
- order: index(`${relationshipsTableName}_order_idx`).on(cols.order),
338
- parentFk: foreignKey({
339
- name: `${relationshipsTableName}_parent_fk`,
340
- columns: [
341
- cols.parent
342
- ],
343
- foreignColumns: [
344
- table.id
345
- ]
346
- }).onDelete('cascade'),
347
- parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),
348
- pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path)
349
- });
350
- if (hasLocalizedRelationshipField) {
351
- result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale);
352
- }
353
- return result;
354
- });
355
- adapter.tables[relationshipsTableName] = relationshipsTable;
356
- adapter.relations[`relations_${relationshipsTableName}`] = relations(relationshipsTable, ({ one })=>{
357
- const result = {
358
- parent: one(table, {
359
- fields: [
360
- relationshipsTable.parent
361
- ],
362
- references: [
363
- table.id
364
- ],
365
- relationName: '_rels'
366
- })
367
- };
368
- relationships.forEach((relationTo)=>{
369
- const relatedTableName = createTableName({
370
- adapter,
371
- config: adapter.payload.collections[relationTo].config
372
- });
373
- const idColumnName = `${relationTo}ID`;
374
- result[idColumnName] = one(adapter.tables[relatedTableName], {
375
- fields: [
376
- relationshipsTable[idColumnName]
377
- ],
378
- references: [
379
- adapter.tables[relatedTableName].id
380
- ],
381
- relationName: relationTo
382
- });
383
- });
384
- return result;
385
- });
386
- }
387
- }
388
- adapter.relations[`relations_${tableName}`] = relations(table, ({ many, one })=>{
389
- const result = {};
390
- nonLocalizedRelations.forEach(({ type, relationName, target }, key)=>{
391
- if (type === 'one') {
392
- result[key] = one(adapter.tables[target], {
393
- fields: [
394
- table[key]
395
- ],
396
- references: [
397
- adapter.tables[target].id
398
- ],
399
- relationName: key
400
- });
401
- }
402
- if (type === 'many') {
403
- result[key] = many(adapter.tables[target], {
404
- relationName: relationName || key
405
- });
406
- }
407
- });
408
- if (hasLocalizedField) {
409
- result._locales = many(localesTable, {
410
- relationName: '_locales'
411
- });
412
- }
413
- if (hasManyTextField) {
414
- result._texts = many(textsTable, {
415
- relationName: '_texts'
416
- });
417
- }
418
- if (hasManyNumberField) {
419
- result._numbers = many(numbersTable, {
420
- relationName: '_numbers'
421
- });
422
- }
423
- if (relationships.size && relationshipsTable) {
424
- result._rels = many(relationshipsTable, {
425
- relationName: '_rels'
426
- });
427
- }
428
- return result;
429
- });
430
- return {
431
- hasLocalizedManyNumberField,
432
- hasLocalizedManyTextField,
433
- hasLocalizedRelationshipField,
434
- hasManyNumberField,
435
- hasManyTextField,
436
- relationsToBuild
437
- };
438
- };
439
-
440
- //# sourceMappingURL=build.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["import type { DrizzleAdapter } from '@payloadcms/drizzle/types'\nimport type { Relation } from 'drizzle-orm'\nimport type {\n AnySQLiteColumn,\n ForeignKeyBuilder,\n IndexBuilder,\n SQLiteColumnBuilder,\n SQLiteTableWithColumns,\n UniqueConstraintBuilder,\n} from 'drizzle-orm/sqlite-core'\nimport type { FlattenedField } from 'payload'\n\nimport { buildIndexName, createTableName } from '@payloadcms/drizzle'\nimport { relations, sql } from 'drizzle-orm'\nimport {\n foreignKey,\n index,\n integer,\n numeric,\n sqliteTable,\n text,\n unique,\n} from 'drizzle-orm/sqlite-core'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, IDType, SQLiteAdapter } from '../types.js'\n\nimport { createIndex } from './createIndex.js'\nimport { getIDColumn } from './getIDColumn.js'\nimport { setColumnID } from './setColumnID.js'\nimport { traverseFields } from './traverseFields.js'\n\nexport type BaseExtraConfig = Record<\n string,\n (cols: {\n [x: string]: AnySQLiteColumn\n }) => ForeignKeyBuilder | IndexBuilder | UniqueConstraintBuilder\n>\n\nexport type RelationMap = Map<\n string,\n {\n localized: boolean\n relationName?: string\n target: string\n type: 'many' | 'one'\n }\n>\n\ntype Args = {\n adapter: SQLiteAdapter\n baseColumns?: Record<string, SQLiteColumnBuilder>\n /**\n * After table is created, run these functions to add extra config to the table\n * ie. indexes, multiple columns, etc\n */\n baseExtraConfig?: BaseExtraConfig\n buildNumbers?: boolean\n buildRelationships?: boolean\n disableNotNull: boolean\n disableRelsTableUnique?: boolean\n disableUnique: boolean\n fields: FlattenedField[]\n locales?: [string, ...string[]]\n rootRelationships?: Set<string>\n rootRelationsToBuild?: RelationMap\n rootTableIDColType?: IDType\n rootTableName?: string\n rootUniqueRelationships?: Set<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: RelationMap\n}\n\nexport const buildTable = ({\n adapter,\n baseColumns = {},\n baseExtraConfig = {},\n disableNotNull,\n disableRelsTableUnique,\n disableUnique = false,\n fields,\n locales,\n rootRelationships,\n rootRelationsToBuild,\n rootTableIDColType,\n rootTableName: incomingRootTableName,\n rootUniqueRelationships,\n tableName,\n timestamps,\n versions,\n withinLocalizedArrayOrBlock,\n}: Args): Result => {\n const isRoot = !incomingRootTableName\n const rootTableName = incomingRootTableName || tableName\n const columns: Record<string, SQLiteColumnBuilder> = baseColumns\n const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n const localesColumns: Record<string, SQLiteColumnBuilder> = {}\n const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n let localesTable: GenericTable | SQLiteTableWithColumns<any>\n let textsTable: GenericTable | SQLiteTableWithColumns<any>\n let numbersTable: GenericTable | SQLiteTableWithColumns<any>\n\n // Relationships to the base collection\n const relationships: Set<string> = rootRelationships || new Set()\n const uniqueRelationships: Set<string> = rootUniqueRelationships || new Set()\n\n let relationshipsTable: GenericTable | SQLiteTableWithColumns<any>\n\n // Drizzle relations\n const relationsToBuild: RelationMap = new Map()\n\n const idColType: IDType = setColumnID({ columns, fields })\n\n const {\n hasLocalizedField,\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n } = traverseFields({\n adapter,\n columns,\n disableNotNull,\n disableRelsTableUnique,\n disableUnique,\n fields,\n indexes,\n locales,\n localesColumns,\n localesIndexes,\n newTableName: tableName,\n parentTableName: tableName,\n relationships,\n relationsToBuild,\n rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n rootTableIDColType: rootTableIDColType || idColType,\n rootTableName,\n uniqueRelationships,\n versions,\n withinLocalizedArrayOrBlock,\n })\n\n // split the relationsToBuild by localized and non-localized\n const localizedRelations = new Map()\n const nonLocalizedRelations = new Map()\n\n relationsToBuild.forEach(({ type, localized, relationName, target }, key) => {\n const map = localized ? localizedRelations : nonLocalizedRelations\n map.set(key, { type, relationName, target })\n })\n\n if (timestamps) {\n columns.createdAt = text('created_at')\n .default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`)\n .notNull()\n columns.updatedAt = text('updated_at')\n .default(sql`(strftime('%Y-%m-%dT%H:%M:%fZ', 'now'))`)\n .notNull()\n }\n\n const table = sqliteTable(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 || localizedRelations.size) {\n const localeTableName = `${tableName}${adapter.localesSuffix}`\n localesColumns.id = integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true })\n localesColumns._locale = text('_locale', { enum: locales }).notNull()\n localesColumns._parentID = getIDColumn({\n name: '_parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n })\n\n localesTable = sqliteTable(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 adapter.relations[`relations_${localeTableName}`] = relations(localesTable, ({ many, one }) => {\n const result: Record<string, Relation<string>> = {}\n\n result._parentID = one(table, {\n fields: [localesTable._parentID],\n references: [table.id],\n // name the relationship by what the many() relationName is\n relationName: '_locales',\n })\n\n localizedRelations.forEach(({ type, target }, key) => {\n if (type === 'one') {\n result[key] = one(adapter.tables[target], {\n fields: [localesTable[key]],\n references: [adapter.tables[target].id],\n relationName: key,\n })\n }\n if (type === 'many') {\n result[key] = many(adapter.tables[target], {\n relationName: key,\n })\n }\n })\n\n return result\n })\n }\n\n if (isRoot) {\n if (hasManyTextField) {\n const textsTableName = `${rootTableName}_texts`\n const columns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n order: integer('order').notNull(),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n text: text('text'),\n }\n\n if (hasLocalizedManyTextField) {\n columns.locale = text('locale', { enum: locales })\n }\n\n textsTable = sqliteTable(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(\n cols.locale,\n cols.parent,\n )\n }\n\n return config\n })\n\n adapter.tables[textsTableName] = textsTable\n\n adapter.relations[`relations_${textsTableName}`] = relations(textsTable, ({ one }) => ({\n parent: one(table, {\n fields: [textsTable.parent],\n references: [table.id],\n relationName: '_texts',\n }),\n }))\n }\n\n if (hasManyNumberField) {\n const numbersTableName = `${rootTableName}_numbers`\n const columns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n number: numeric('number'),\n order: integer('order').notNull(),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n }\n\n if (hasLocalizedManyNumberField) {\n columns.locale = text('locale', { enum: locales })\n }\n\n numbersTable = sqliteTable(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 adapter.relations[`relations_${numbersTableName}`] = relations(numbersTable, ({ one }) => ({\n parent: one(table, {\n fields: [numbersTable.parent],\n references: [table.id],\n relationName: '_numbers',\n }),\n }))\n }\n\n if (relationships.size) {\n const relationshipColumns: Record<string, SQLiteColumnBuilder> = {\n id: integer('id', { mode: 'number' }).primaryKey({ autoIncrement: true }),\n order: integer('order'),\n parent: getIDColumn({\n name: 'parent_id',\n type: idColType,\n notNull: true,\n primaryKey: false,\n }),\n path: text('path').notNull(),\n }\n\n if (hasLocalizedRelationshipField) {\n relationshipColumns.locale = text('locale', { enum: locales })\n }\n\n const relationExtraConfig: BaseExtraConfig = {}\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 })\n let colType: IDType = 'integer'\n const relatedCollectionCustomIDType =\n adapter.payload.collections[relationshipConfig.slug]?.customIDType\n\n if (relatedCollectionCustomIDType === 'number') {\n colType = 'numeric'\n }\n if (relatedCollectionCustomIDType === 'text') {\n colType = 'text'\n }\n\n const colName = `${relationTo}ID`\n\n relationshipColumns[colName] = getIDColumn({\n name: `${formattedRelationTo}_id`,\n type: colType,\n primaryKey: false,\n })\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 indexColumns = [colName]\n\n const unique = !disableUnique && uniqueRelationships.has(relationTo)\n\n if (unique) {\n indexColumns.push('path')\n }\n if (hasLocalizedRelationshipField) {\n indexColumns.push('locale')\n }\n\n const indexName = buildIndexName({\n name: `${relationshipsTableName}_${formattedRelationTo}_id`,\n adapter: adapter as unknown as DrizzleAdapter,\n })\n\n relationExtraConfig[indexName] = createIndex({\n name: indexColumns,\n indexName,\n unique,\n })\n })\n\n relationshipsTable = sqliteTable(relationshipsTableName, relationshipColumns, (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 adapter.tables[relationshipsTableName] = relationshipsTable\n\n adapter.relations[`relations_${relationshipsTableName}`] = relations(\n relationshipsTable,\n ({ 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 })\n const idColumnName = `${relationTo}ID`\n result[idColumnName] = one(adapter.tables[relatedTableName], {\n fields: [relationshipsTable[idColumnName]],\n references: [adapter.tables[relatedTableName].id],\n relationName: relationTo,\n })\n })\n\n return result\n },\n )\n }\n }\n\n adapter.relations[`relations_${tableName}`] = relations(table, ({ many, one }) => {\n const result: Record<string, Relation<string>> = {}\n\n nonLocalizedRelations.forEach(({ type, relationName, target }, key) => {\n if (type === 'one') {\n result[key] = one(adapter.tables[target], {\n fields: [table[key]],\n references: [adapter.tables[target].id],\n relationName: key,\n })\n }\n if (type === 'many') {\n result[key] = many(adapter.tables[target], { relationName: relationName || key })\n }\n })\n\n if (hasLocalizedField) {\n result._locales = many(localesTable, { relationName: '_locales' })\n }\n\n if (hasManyTextField) {\n result._texts = many(textsTable, { relationName: '_texts' })\n }\n\n if (hasManyNumberField) {\n result._numbers = many(numbersTable, { relationName: '_numbers' })\n }\n\n if (relationships.size && relationshipsTable) {\n result._rels = many(relationshipsTable, {\n relationName: '_rels',\n })\n }\n\n return result\n })\n\n return {\n hasLocalizedManyNumberField,\n hasLocalizedManyTextField,\n hasLocalizedRelationshipField,\n hasManyNumberField,\n hasManyTextField,\n relationsToBuild,\n }\n}\n"],"names":["buildIndexName","createTableName","relations","sql","foreignKey","index","integer","numeric","sqliteTable","text","unique","toSnakeCase","createIndex","getIDColumn","setColumnID","traverseFields","buildTable","adapter","baseColumns","baseExtraConfig","disableNotNull","disableRelsTableUnique","disableUnique","fields","locales","rootRelationships","rootRelationsToBuild","rootTableIDColType","rootTableName","incomingRootTableName","rootUniqueRelationships","tableName","timestamps","versions","withinLocalizedArrayOrBlock","isRoot","columns","indexes","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","uniqueRelationships","relationshipsTable","relationsToBuild","Map","idColType","hasLocalizedField","hasLocalizedManyNumberField","hasLocalizedManyTextField","hasLocalizedRelationshipField","hasManyNumberField","hasManyTextField","newTableName","parentTableName","localizedRelations","nonLocalizedRelations","forEach","type","localized","relationName","target","key","map","set","createdAt","default","notNull","updatedAt","table","cols","extraConfig","Object","entries","reduce","config","func","result","acc","colName","tables","size","localeTableName","localesSuffix","id","mode","primaryKey","autoIncrement","_locale","enum","_parentID","name","_localeParent","on","_parentIdFk","foreignColumns","onDelete","many","one","references","textsTableName","order","parent","path","locale","orderParentIdx","parentFk","text_idx","localeParent","numbersTableName","number","numberIdx","relationshipColumns","relationExtraConfig","relationshipsTableName","relationshipsSuffix","relationTo","relationshipConfig","payload","collections","formattedRelationTo","colType","relatedCollectionCustomIDType","slug","customIDType","indexColumns","has","push","indexName","parentIdx","pathIdx","localeIdx","relatedTableName","idColumnName","_locales","_texts","_numbers","_rels"],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- import type { AnySQLiteColumn } from 'drizzle-orm/sqlite-core';
2
- type CreateIndexArgs = {
3
- indexName: string;
4
- name: string | string[];
5
- unique?: boolean;
6
- };
7
- export declare const createIndex: ({ name, indexName, unique }: CreateIndexArgs) => (table: {
8
- [x: string]: AnySQLiteColumn;
9
- }) => import("drizzle-orm/sqlite-core").IndexBuilder;
10
- export {};
11
- //# sourceMappingURL=createIndex.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"createIndex.d.ts","sourceRoot":"","sources":["../../src/schema/createIndex.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAI9D,KAAK,eAAe,GAAG;IACrB,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IACvB,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,WAAW,gCAAiC,eAAe,aACvD;IAAE,CAAC,CAAC,EAAE,MAAM,GAAG,eAAe,CAAA;CAAE,mDAehD,CAAA"}
@@ -1,20 +0,0 @@
1
- import { index, uniqueIndex } from 'drizzle-orm/sqlite-core';
2
- export const createIndex = ({ name, indexName, unique })=>{
3
- return (table)=>{
4
- let columns;
5
- if (Array.isArray(name)) {
6
- columns = name.map((columnName)=>table[columnName])// exclude fields were included in compound indexes but do not exist on the table
7
- .filter((col)=>typeof col !== 'undefined');
8
- } else {
9
- columns = [
10
- table[name]
11
- ];
12
- }
13
- if (unique) {
14
- return uniqueIndex(indexName).on(columns[0], ...columns.slice(1));
15
- }
16
- return index(indexName).on(columns[0], ...columns.slice(1));
17
- };
18
- };
19
-
20
- //# sourceMappingURL=createIndex.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/createIndex.ts"],"sourcesContent":["import type { AnySQLiteColumn } from 'drizzle-orm/sqlite-core'\n\nimport { index, uniqueIndex } from 'drizzle-orm/sqlite-core'\n\ntype CreateIndexArgs = {\n indexName: string\n name: string | string[]\n unique?: boolean\n}\n\nexport const createIndex = ({ name, indexName, unique }: CreateIndexArgs) => {\n return (table: { [x: string]: AnySQLiteColumn }) => {\n let columns\n if (Array.isArray(name)) {\n columns = name\n .map((columnName) => table[columnName])\n // exclude fields were included in compound indexes but do not exist on the table\n .filter((col) => typeof col !== 'undefined')\n } else {\n columns = [table[name]]\n }\n if (unique) {\n return uniqueIndex(indexName).on(columns[0], ...columns.slice(1))\n }\n return index(indexName).on(columns[0], ...columns.slice(1))\n }\n}\n"],"names":["index","uniqueIndex","createIndex","name","indexName","unique","table","columns","Array","isArray","map","columnName","filter","col","on","slice"],"mappings":"AAEA,SAASA,KAAK,EAAEC,WAAW,QAAQ,0BAAyB;AAQ5D,OAAO,MAAMC,cAAc,CAAC,EAAEC,IAAI,EAAEC,SAAS,EAAEC,MAAM,EAAmB;IACtE,OAAO,CAACC;QACN,IAAIC;QACJ,IAAIC,MAAMC,OAAO,CAACN,OAAO;YACvBI,UAAUJ,KACPO,GAAG,CAAC,CAACC,aAAeL,KAAK,CAACK,WAAW,CACtC,iFAAiF;aAChFC,MAAM,CAAC,CAACC,MAAQ,OAAOA,QAAQ;QACpC,OAAO;YACLN,UAAU;gBAACD,KAAK,CAACH,KAAK;aAAC;QACzB;QACA,IAAIE,QAAQ;YACV,OAAOJ,YAAYG,WAAWU,EAAE,CAACP,OAAO,CAAC,EAAE,KAAKA,QAAQQ,KAAK,CAAC;QAChE;QACA,OAAOf,MAAMI,WAAWU,EAAE,CAACP,OAAO,CAAC,EAAE,KAAKA,QAAQQ,KAAK,CAAC;IAC1D;AACF,EAAC"}
@@ -1,8 +0,0 @@
1
- import type { IDType } from '../types.js';
2
- export declare const getIDColumn: ({ name, type, notNull, primaryKey, }: {
3
- name: string;
4
- notNull?: boolean;
5
- primaryKey: boolean;
6
- type: IDType;
7
- }) => any;
8
- //# sourceMappingURL=getIDColumn.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getIDColumn.d.ts","sourceRoot":"","sources":["../../src/schema/getIDColumn.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEzC,eAAO,MAAM,WAAW,yCAKrB;IACD,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,UAAU,EAAE,OAAO,CAAA;IACnB,IAAI,EAAE,MAAM,CAAA;CACb,QAuBA,CAAA"}
@@ -1,24 +0,0 @@
1
- import { integer, numeric, text } from 'drizzle-orm/sqlite-core';
2
- export const getIDColumn = ({ name, type, notNull, primaryKey })=>{
3
- let column;
4
- switch(type){
5
- case 'integer':
6
- column = integer(name);
7
- break;
8
- case 'numeric':
9
- column = numeric(name);
10
- break;
11
- case 'text':
12
- column = text(name);
13
- break;
14
- }
15
- if (notNull) {
16
- column.notNull();
17
- }
18
- if (primaryKey) {
19
- column.primaryKey();
20
- }
21
- return column;
22
- };
23
-
24
- //# sourceMappingURL=getIDColumn.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/getIDColumn.ts"],"sourcesContent":["import { integer, numeric, text } from 'drizzle-orm/sqlite-core'\n\nimport type { IDType } from '../types.js'\n\nexport const getIDColumn = ({\n name,\n type,\n notNull,\n primaryKey,\n}: {\n name: string\n notNull?: boolean\n primaryKey: boolean\n type: IDType\n}) => {\n let column\n switch (type) {\n case 'integer':\n column = integer(name)\n break\n case 'numeric':\n column = numeric(name)\n break\n case 'text':\n column = text(name)\n break\n }\n\n if (notNull) {\n column.notNull()\n }\n\n if (primaryKey) {\n column.primaryKey()\n }\n\n return column\n}\n"],"names":["integer","numeric","text","getIDColumn","name","type","notNull","primaryKey","column"],"mappings":"AAAA,SAASA,OAAO,EAAEC,OAAO,EAAEC,IAAI,QAAQ,0BAAyB;AAIhE,OAAO,MAAMC,cAAc,CAAC,EAC1BC,IAAI,EACJC,IAAI,EACJC,OAAO,EACPC,UAAU,EAMX;IACC,IAAIC;IACJ,OAAQH;QACN,KAAK;YACHG,SAASR,QAAQI;YACjB;QACF,KAAK;YACHI,SAASP,QAAQG;YACjB;QACF,KAAK;YACHI,SAASN,KAAKE;YACd;IACJ;IAEA,IAAIE,SAAS;QACXE,OAAOF,OAAO;IAChB;IAEA,IAAIC,YAAY;QACdC,OAAOD,UAAU;IACnB;IAEA,OAAOC;AACT,EAAC"}
@@ -1,3 +0,0 @@
1
- import type { FlattenedField } from 'payload';
2
- export declare const idToUUID: (fields: FlattenedField[]) => FlattenedField[];
3
- //# sourceMappingURL=idToUUID.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"idToUUID.d.ts","sourceRoot":"","sources":["../../src/schema/idToUUID.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAE7C,eAAO,MAAM,QAAQ,WAAY,cAAc,EAAE,KAAG,cAAc,EAU9D,CAAA"}
@@ -1,11 +0,0 @@
1
- export const idToUUID = (fields)=>fields.map((field)=>{
2
- if ('name' in field && field.name === 'id') {
3
- return {
4
- ...field,
5
- name: '_uuid'
6
- };
7
- }
8
- return field;
9
- });
10
-
11
- //# sourceMappingURL=idToUUID.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/idToUUID.ts"],"sourcesContent":["import type { FlattenedField } from 'payload'\n\nexport const idToUUID = (fields: FlattenedField[]): FlattenedField[] =>\n fields.map((field) => {\n if ('name' in field && field.name === 'id') {\n return {\n ...field,\n name: '_uuid',\n }\n }\n\n return field\n })\n"],"names":["idToUUID","fields","map","field","name"],"mappings":"AAEA,OAAO,MAAMA,WAAW,CAACC,SACvBA,OAAOC,GAAG,CAAC,CAACC;QACV,IAAI,UAAUA,SAASA,MAAMC,IAAI,KAAK,MAAM;YAC1C,OAAO;gBACL,GAAGD,KAAK;gBACRC,MAAM;YACR;QACF;QAEA,OAAOD;IACT,GAAE"}