@payloadcms/db-postgres 3.0.0-beta.3 → 3.0.0-beta.31

Sign up to get free protection for your applications and to get access to all the features.
Files changed (125) hide show
  1. package/dist/connect.d.ts.map +1 -1
  2. package/dist/connect.js +12 -7
  3. package/dist/connect.js.map +1 -1
  4. package/dist/count.d.ts +3 -0
  5. package/dist/count.d.ts.map +1 -0
  6. package/dist/count.js +50 -0
  7. package/dist/count.js.map +1 -0
  8. package/dist/create.d.ts.map +1 -1
  9. package/dist/create.js +3 -5
  10. package/dist/create.js.map +1 -1
  11. package/dist/createGlobal.d.ts.map +1 -1
  12. package/dist/createGlobal.js +3 -5
  13. package/dist/createGlobal.js.map +1 -1
  14. package/dist/createGlobalVersion.d.ts +1 -1
  15. package/dist/createGlobalVersion.d.ts.map +1 -1
  16. package/dist/createGlobalVersion.js +2 -6
  17. package/dist/createGlobalVersion.js.map +1 -1
  18. package/dist/createVersion.d.ts.map +1 -1
  19. package/dist/createVersion.js +9 -13
  20. package/dist/createVersion.js.map +1 -1
  21. package/dist/deleteMany.d.ts.map +1 -1
  22. package/dist/deleteMany.js +2 -5
  23. package/dist/deleteMany.js.map +1 -1
  24. package/dist/deleteOne.d.ts.map +1 -1
  25. package/dist/deleteOne.js +2 -5
  26. package/dist/deleteOne.js.map +1 -1
  27. package/dist/deleteVersions.d.ts.map +1 -1
  28. package/dist/deleteVersions.js +2 -6
  29. package/dist/deleteVersions.js.map +1 -1
  30. package/dist/destroy.d.ts.map +1 -1
  31. package/dist/destroy.js +11 -7
  32. package/dist/destroy.js.map +1 -1
  33. package/dist/find/buildFindManyArgs.js +2 -2
  34. package/dist/find/buildFindManyArgs.js.map +1 -1
  35. package/dist/find/findMany.d.ts.map +1 -1
  36. package/dist/find/findMany.js +1 -1
  37. package/dist/find/findMany.js.map +1 -1
  38. package/dist/find/traverseFields.d.ts.map +1 -1
  39. package/dist/find/traverseFields.js +4 -20
  40. package/dist/find/traverseFields.js.map +1 -1
  41. package/dist/find.d.ts.map +1 -1
  42. package/dist/find.js +2 -5
  43. package/dist/find.js.map +1 -1
  44. package/dist/findGlobal.d.ts.map +1 -1
  45. package/dist/findGlobal.js +2 -5
  46. package/dist/findGlobal.js.map +1 -1
  47. package/dist/findGlobalVersions.d.ts.map +1 -1
  48. package/dist/findGlobalVersions.js +2 -6
  49. package/dist/findGlobalVersions.js.map +1 -1
  50. package/dist/findOne.d.ts.map +1 -1
  51. package/dist/findOne.js +2 -5
  52. package/dist/findOne.js.map +1 -1
  53. package/dist/findVersions.d.ts.map +1 -1
  54. package/dist/findVersions.js +2 -6
  55. package/dist/findVersions.js.map +1 -1
  56. package/dist/index.d.ts.map +1 -1
  57. package/dist/index.js +17 -8
  58. package/dist/index.js.map +1 -1
  59. package/dist/init.d.ts.map +1 -1
  60. package/dist/init.js +9 -7
  61. package/dist/init.js.map +1 -1
  62. package/dist/migrate.js.map +1 -1
  63. package/dist/migrateDown.js.map +1 -1
  64. package/dist/migrateFresh.js.map +1 -1
  65. package/dist/migrateRefresh.js.map +1 -1
  66. package/dist/migrateReset.js.map +1 -1
  67. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
  68. package/dist/queries/getTableColumnFromPath.js +95 -62
  69. package/dist/queries/getTableColumnFromPath.js.map +1 -1
  70. package/dist/queryDrafts.d.ts.map +1 -1
  71. package/dist/queryDrafts.js +2 -6
  72. package/dist/queryDrafts.js.map +1 -1
  73. package/dist/schema/build.d.ts +3 -2
  74. package/dist/schema/build.d.ts.map +1 -1
  75. package/dist/schema/build.js +80 -46
  76. package/dist/schema/build.js.map +1 -1
  77. package/dist/schema/{getTableName.d.ts → createTableName.d.ts} +5 -7
  78. package/dist/schema/createTableName.d.ts.map +1 -0
  79. package/dist/schema/createTableName.js +31 -0
  80. package/dist/schema/createTableName.js.map +1 -0
  81. package/dist/schema/traverseFields.d.ts.map +1 -1
  82. package/dist/schema/traverseFields.js +45 -24
  83. package/dist/schema/traverseFields.js.map +1 -1
  84. package/dist/schema/validateExistingBlockIsIdentical.d.ts +2 -1
  85. package/dist/schema/validateExistingBlockIsIdentical.d.ts.map +1 -1
  86. package/dist/schema/validateExistingBlockIsIdentical.js +13 -7
  87. package/dist/schema/validateExistingBlockIsIdentical.js.map +1 -1
  88. package/dist/transactions/beginTransaction.d.ts.map +1 -1
  89. package/dist/transactions/beginTransaction.js +4 -0
  90. package/dist/transactions/beginTransaction.js.map +1 -1
  91. package/dist/transform/write/array.d.ts.map +1 -1
  92. package/dist/transform/write/array.js.map +1 -1
  93. package/dist/transform/write/blocks.js +1 -1
  94. package/dist/transform/write/blocks.js.map +1 -1
  95. package/dist/transform/write/traverseFields.js +2 -2
  96. package/dist/transform/write/traverseFields.js.map +1 -1
  97. package/dist/types.d.ts +7 -7
  98. package/dist/types.d.ts.map +1 -1
  99. package/dist/types.js.map +1 -1
  100. package/dist/update.d.ts.map +1 -1
  101. package/dist/update.js +2 -5
  102. package/dist/update.js.map +1 -1
  103. package/dist/updateGlobal.d.ts.map +1 -1
  104. package/dist/updateGlobal.js +2 -5
  105. package/dist/updateGlobal.js.map +1 -1
  106. package/dist/updateGlobalVersion.d.ts.map +1 -1
  107. package/dist/updateGlobalVersion.js +2 -6
  108. package/dist/updateGlobalVersion.js.map +1 -1
  109. package/dist/updateVersion.d.ts.map +1 -1
  110. package/dist/updateVersion.js +2 -6
  111. package/dist/updateVersion.js.map +1 -1
  112. package/dist/upsertRow/index.d.ts.map +1 -1
  113. package/dist/upsertRow/index.js +6 -5
  114. package/dist/upsertRow/index.js.map +1 -1
  115. package/dist/upsertRow/insertArrays.d.ts.map +1 -1
  116. package/dist/upsertRow/insertArrays.js +3 -3
  117. package/dist/upsertRow/insertArrays.js.map +1 -1
  118. package/dist/upsertRow/types.d.ts +2 -2
  119. package/dist/upsertRow/types.d.ts.map +1 -1
  120. package/dist/upsertRow/types.js.map +1 -1
  121. package/package.json +20 -24
  122. package/dist/schema/getTableName.d.ts.map +0 -1
  123. package/dist/schema/getTableName.js +0 -31
  124. package/dist/schema/getTableName.js.map +0 -1
  125. package/src/index.ts +0 -156
package/package.json CHANGED
@@ -1,22 +1,34 @@
1
1
  {
2
2
  "name": "@payloadcms/db-postgres",
3
- "version": "3.0.0-beta.3",
3
+ "version": "3.0.0-beta.31",
4
4
  "description": "The officially supported Postgres database adapter for Payload",
5
+ "homepage": "https://payloadcms.com",
5
6
  "repository": {
6
7
  "type": "git",
7
8
  "url": "https://github.com/payloadcms/payload.git",
8
9
  "directory": "packages/db-postgres"
9
10
  },
10
11
  "license": "MIT",
11
- "homepage": "https://payloadcms.com",
12
+ "author": "Payload <dev@payloadcms.com> (https://payloadcms.com)",
12
13
  "type": "module",
13
- "author": {
14
- "email": "info@payloadcms.com",
15
- "name": "Payload",
16
- "url": "https://payloadcms.com"
14
+ "exports": {
15
+ ".": {
16
+ "import": "./dist/index.js",
17
+ "require": "./dist/index.js",
18
+ "types": "./dist/index.d.ts"
19
+ },
20
+ "./types": {
21
+ "import": "./dist/types.js",
22
+ "require": "./dist/types.js",
23
+ "types": "./dist/types.d.ts"
24
+ }
17
25
  },
18
26
  "main": "./dist/index.js",
19
27
  "types": "./dist/index.d.ts",
28
+ "files": [
29
+ "dist",
30
+ "mock.js"
31
+ ],
20
32
  "dependencies": {
21
33
  "@libsql/client": "^0.5.2",
22
34
  "console-table-printer": "2.11.2",
@@ -31,27 +43,11 @@
31
43
  "@types/pg": "8.10.2",
32
44
  "@types/to-snake-case": "1.0.0",
33
45
  "@payloadcms/eslint-config": "1.1.1",
34
- "payload": "3.0.0-beta.3"
46
+ "payload": "3.0.0-beta.31"
35
47
  },
36
48
  "peerDependencies": {
37
- "payload": "3.0.0-beta.3"
49
+ "payload": "3.0.0-beta.31"
38
50
  },
39
- "exports": {
40
- ".": {
41
- "import": "./dist/index.js",
42
- "require": "./dist/index.js",
43
- "types": "./dist/index.d.ts"
44
- },
45
- "./types": {
46
- "import": "./dist/types.js",
47
- "require": "./dist/types.js",
48
- "types": "./dist/types.d.ts"
49
- }
50
- },
51
- "files": [
52
- "dist",
53
- "mock.js"
54
- ],
55
51
  "scripts": {
56
52
  "build": "pnpm build:swc && pnpm build:types",
57
53
  "build:swc": "swc ./src -d ./dist --config-file .swcrc",
@@ -1 +0,0 @@
1
- {"version":3,"file":"getTableName.d.ts","sourceRoot":"","sources":["../../src/schema/getTableName.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAKxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAElD,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,8CAA8C;IAC9C,MAAM,EAAE;QACN,MAAM,CAAC,EAAE,gBAAgB,CAAA;QACzB,QAAQ,CAAC,EAAE,gBAAgB,CAAA;QAC3B,IAAI,CAAC,EAAE,MAAM,CAAA;QACb,IAAI,CAAC,EAAE,MAAM,CAAA;KACd,CAAA;IACD,2DAA2D;IAC3D,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,mGAAmG;IACnG,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,mFAAmF;IACnF,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,oCAAoC;IACpC,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,uHAAuH;IACvH,MAAM,CAAC,EAAE,QAAQ,GAAG,UAAU,CAAA;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,kGAAkG;IAClG,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,YAAY,0IAWtB,IAAI,KAAG,MA4BT,CAAA"}
@@ -1,31 +0,0 @@
1
- import { APIError } from 'payload/errors';
2
- import toSnakeCase from 'to-snake-case';
3
- /**
4
- * Used to name database enums and tables
5
- * Returns the table or enum name for a given entity
6
- */ export const getTableName = ({ adapter, config: { name, slug }, config, locales = false, parentTableName, prefix = '', relationships = false, target = 'dbName', throwValidationError = false, versions = false })=>{
7
- let result;
8
- let custom = config[target];
9
- if (!custom && target === 'enumName') {
10
- custom = config['dbName'];
11
- }
12
- if (custom) {
13
- result = typeof custom === 'function' ? custom({
14
- tableName: parentTableName
15
- }) : custom;
16
- } else {
17
- result = `${prefix}${toSnakeCase(name ?? slug)}`;
18
- }
19
- if (locales) result = `${result}${adapter.localesSuffix}`;
20
- if (versions) result = `_${result}${adapter.versionsSuffix}`;
21
- if (relationships) result = `${result}${adapter.relationshipsSuffix}`;
22
- if (!throwValidationError) {
23
- return result;
24
- }
25
- if (result.length > 63) {
26
- throw new APIError(`Exceeded max identifier length for table or enum name of 63 characters. Invalid name: ${result}`);
27
- }
28
- return result;
29
- };
30
-
31
- //# sourceMappingURL=getTableName.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/schema/getTableName.ts"],"sourcesContent":["import type { DBIdentifierName } from 'payload/database'\n\nimport { APIError } from 'payload/errors'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../types.js'\n\ntype Args = {\n adapter: PostgresAdapter\n /** The collection, global or field config **/\n config: {\n dbName?: DBIdentifierName\n enumName?: DBIdentifierName\n name?: string\n slug?: string\n }\n /** Localized tables need to be given the locales suffix */\n locales?: boolean\n /** For nested tables passed for the user custom dbName functions to handle their own iterations */\n parentTableName?: string\n /** For sub tables (array for example) this needs to include the parentTableName */\n prefix?: string\n /** Adds the relationships suffix */\n relationships?: boolean\n /** For tables based on fields that could have both enumName and dbName (ie: select with hasMany), default: 'dbName' */\n target?: 'dbName' | 'enumName'\n throwValidationError?: boolean\n /** Adds the versions suffix, should only be used on the base collection to duplicate suffixing */\n versions?: boolean\n}\n\n/**\n * Used to name database enums and tables\n * Returns the table or enum name for a given entity\n */\nexport const getTableName = ({\n adapter,\n config: { name, slug },\n config,\n locales = false,\n parentTableName,\n prefix = '',\n relationships = false,\n target = 'dbName',\n throwValidationError = false,\n versions = false,\n}: Args): string => {\n let result: string\n let custom = config[target]\n\n if (!custom && target === 'enumName') {\n custom = config['dbName']\n }\n\n if (custom) {\n result = typeof custom === 'function' ? custom({ tableName: parentTableName }) : custom\n } else {\n result = `${prefix}${toSnakeCase(name ?? slug)}`\n }\n\n if (locales) result = `${result}${adapter.localesSuffix}`\n if (versions) result = `_${result}${adapter.versionsSuffix}`\n if (relationships) result = `${result}${adapter.relationshipsSuffix}`\n\n if (!throwValidationError) {\n return result\n }\n\n if (result.length > 63) {\n throw new APIError(\n `Exceeded max identifier length for table or enum name of 63 characters. Invalid name: ${result}`,\n )\n }\n return result\n}\n"],"names":["APIError","toSnakeCase","getTableName","adapter","config","name","slug","locales","parentTableName","prefix","relationships","target","throwValidationError","versions","result","custom","tableName","localesSuffix","versionsSuffix","relationshipsSuffix","length"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAEA,SAASA,QAAQ,QAAQ,iBAAgB;AACzC,OAAOC,iBAAiB,gBAAe;AA4BvC;;;CAGC,GACD,OAAO,MAAMC,eAAe,CAAC,EAC3BC,OAAO,EACPC,QAAQ,EAAEC,IAAI,EAAEC,IAAI,EAAE,EACtBF,MAAM,EACNG,UAAU,KAAK,EACfC,eAAe,EACfC,SAAS,EAAE,EACXC,gBAAgB,KAAK,EACrBC,SAAS,QAAQ,EACjBC,uBAAuB,KAAK,EAC5BC,WAAW,KAAK,EACX;IACL,IAAIC;IACJ,IAAIC,SAASX,MAAM,CAACO,OAAO;IAE3B,IAAI,CAACI,UAAUJ,WAAW,YAAY;QACpCI,SAASX,MAAM,CAAC,SAAS;IAC3B;IAEA,IAAIW,QAAQ;QACVD,SAAS,OAAOC,WAAW,aAAaA,OAAO;YAAEC,WAAWR;QAAgB,KAAKO;IACnF,OAAO;QACLD,SAAS,CAAC,EAAEL,OAAO,EAAER,YAAYI,QAAQC,MAAM,CAAC;IAClD;IAEA,IAAIC,SAASO,SAAS,CAAC,EAAEA,OAAO,EAAEX,QAAQc,aAAa,CAAC,CAAC;IACzD,IAAIJ,UAAUC,SAAS,CAAC,CAAC,EAAEA,OAAO,EAAEX,QAAQe,cAAc,CAAC,CAAC;IAC5D,IAAIR,eAAeI,SAAS,CAAC,EAAEA,OAAO,EAAEX,QAAQgB,mBAAmB,CAAC,CAAC;IAErE,IAAI,CAACP,sBAAsB;QACzB,OAAOE;IACT;IAEA,IAAIA,OAAOM,MAAM,GAAG,IAAI;QACtB,MAAM,IAAIpB,SACR,CAAC,sFAAsF,EAAEc,OAAO,CAAC;IAErG;IACA,OAAOA;AACT,EAAC"}
package/src/index.ts DELETED
@@ -1,156 +0,0 @@
1
- import type { Payload } from 'payload'
2
- import type { DatabaseAdapterObj } from 'payload/database'
3
-
4
- import fs from 'fs'
5
- import path from 'path'
6
- import { createDatabaseAdapter } from 'payload/database'
7
-
8
- import type { Args, PostgresAdapter } from './types.js'
9
-
10
- import { connect } from './connect.js'
11
- import { create } from './create.js'
12
- import { createGlobal } from './createGlobal.js'
13
- import { createGlobalVersion } from './createGlobalVersion.js'
14
- import { createMigration } from './createMigration.js'
15
- import { createVersion } from './createVersion.js'
16
- import { deleteMany } from './deleteMany.js'
17
- import { deleteOne } from './deleteOne.js'
18
- import { deleteVersions } from './deleteVersions.js'
19
- import { destroy } from './destroy.js'
20
- import { find } from './find.js'
21
- import { findGlobal } from './findGlobal.js'
22
- import { findGlobalVersions } from './findGlobalVersions.js'
23
- import { findOne } from './findOne.js'
24
- import { findVersions } from './findVersions.js'
25
- import { init } from './init.js'
26
- import { migrate } from './migrate.js'
27
- import { migrateDown } from './migrateDown.js'
28
- import { migrateFresh } from './migrateFresh.js'
29
- import { migrateRefresh } from './migrateRefresh.js'
30
- import { migrateReset } from './migrateReset.js'
31
- import { migrateStatus } from './migrateStatus.js'
32
- import { queryDrafts } from './queryDrafts.js'
33
- import { beginTransaction } from './transactions/beginTransaction.js'
34
- import { commitTransaction } from './transactions/commitTransaction.js'
35
- import { rollbackTransaction } from './transactions/rollbackTransaction.js'
36
- import { updateOne } from './update.js'
37
- import { updateGlobal } from './updateGlobal.js'
38
- import { updateGlobalVersion } from './updateGlobalVersion.js'
39
- import { updateVersion } from './updateVersion.js'
40
-
41
- export type { MigrateDownArgs, MigrateUpArgs } from './types.js'
42
-
43
- export { sql } from 'drizzle-orm'
44
-
45
- export function postgresAdapter(args: Args): DatabaseAdapterObj<PostgresAdapter> {
46
- function adapter({ payload }: { payload: Payload }) {
47
- const migrationDir = findMigrationDir(args.migrationDir)
48
- const idType = args.idType || 'serial'
49
-
50
- return createDatabaseAdapter<PostgresAdapter>({
51
- name: 'postgres',
52
-
53
- // Postgres-specific
54
- blockTableNames: {},
55
- drizzle: undefined,
56
- enums: {},
57
- fieldConstraints: {},
58
- idType,
59
- localesSuffix: args.localesSuffix || '_locales',
60
- logger: args.logger,
61
- pgSchema: undefined,
62
- pool: undefined,
63
- poolOptions: args.pool,
64
- push: args.push,
65
- relations: {},
66
- relationshipsSuffix: args.relationshipsSuffix || '_rels',
67
- schema: {},
68
- schemaName: args.schemaName,
69
- sessions: {},
70
- tables: {},
71
- versionsSuffix: args.versionsSuffix || '_v',
72
-
73
- // DatabaseAdapter
74
- beginTransaction,
75
- commitTransaction,
76
- connect,
77
- create,
78
- createGlobal,
79
- createGlobalVersion,
80
- createMigration,
81
- createVersion,
82
- /**
83
- * This represents how a default ID is treated in Payload as were a field type
84
- */
85
- defaultIDType: idType === 'serial' ? 'number' : 'text',
86
- deleteMany,
87
- deleteOne,
88
- deleteVersions,
89
- destroy,
90
- find,
91
- findGlobal,
92
- findGlobalVersions,
93
- findOne,
94
- findVersions,
95
- init,
96
- migrate,
97
- migrateDown,
98
- migrateFresh,
99
- migrateRefresh,
100
- migrateReset,
101
- migrateStatus,
102
- migrationDir,
103
- payload,
104
- queryDrafts,
105
- rollbackTransaction,
106
- updateGlobal,
107
- updateGlobalVersion,
108
- updateOne,
109
- updateVersion,
110
- })
111
- }
112
-
113
- return {
114
- defaultIDType: 'number',
115
- init: adapter,
116
- }
117
- }
118
-
119
- /**
120
- * Attempt to find migrations directory.
121
- *
122
- * Checks for the following directories in order:
123
- * - `migrationDir` argument from Payload config
124
- * - `src/migrations`
125
- * - `dist/migrations`
126
- * - `migrations`
127
- *
128
- * Defaults to `src/migrations`
129
- *
130
- * @param migrationDir
131
- * @returns
132
- */
133
- function findMigrationDir(migrationDir?: string): string {
134
- const cwd = process.cwd()
135
- const srcDir = path.resolve(cwd, 'src/migrations')
136
- const distDir = path.resolve(cwd, 'dist/migrations')
137
- const relativeMigrations = path.resolve(cwd, 'migrations')
138
-
139
- // Use arg if provided
140
- if (migrationDir) return migrationDir
141
-
142
- // Check other common locations
143
- if (fs.existsSync(srcDir)) {
144
- return srcDir
145
- }
146
-
147
- if (fs.existsSync(distDir)) {
148
- return distDir
149
- }
150
-
151
- if (fs.existsSync(relativeMigrations)) {
152
- return relativeMigrations
153
- }
154
-
155
- return srcDir
156
- }