@take-out/postgres 0.0.28

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 (186) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +242 -0
  3. package/cli.cjs +3 -0
  4. package/dist/cjs/build.cjs +26 -0
  5. package/dist/cjs/build.js +21 -0
  6. package/dist/cjs/build.js.map +6 -0
  7. package/dist/cjs/build.native.js +29 -0
  8. package/dist/cjs/build.native.js.map +1 -0
  9. package/dist/cjs/cli.cjs +156 -0
  10. package/dist/cjs/cli.js +128 -0
  11. package/dist/cjs/cli.js.map +6 -0
  12. package/dist/cjs/cli.native.js +164 -0
  13. package/dist/cjs/cli.native.js.map +1 -0
  14. package/dist/cjs/createServerHelpers.cjs +37 -0
  15. package/dist/cjs/createServerHelpers.js +28 -0
  16. package/dist/cjs/createServerHelpers.js.map +6 -0
  17. package/dist/cjs/createServerHelpers.native.js +43 -0
  18. package/dist/cjs/createServerHelpers.native.js.map +1 -0
  19. package/dist/cjs/helpers/chunkedQuery.cjs +60 -0
  20. package/dist/cjs/helpers/chunkedQuery.js +51 -0
  21. package/dist/cjs/helpers/chunkedQuery.js.map +6 -0
  22. package/dist/cjs/helpers/chunkedQuery.native.js +73 -0
  23. package/dist/cjs/helpers/chunkedQuery.native.js.map +1 -0
  24. package/dist/cjs/helpers/getDBClient.cjs +172 -0
  25. package/dist/cjs/helpers/getDBClient.js +179 -0
  26. package/dist/cjs/helpers/getDBClient.js.map +6 -0
  27. package/dist/cjs/helpers/getDBClient.native.js +189 -0
  28. package/dist/cjs/helpers/getDBClient.native.js.map +1 -0
  29. package/dist/cjs/index.cjs +59 -0
  30. package/dist/cjs/index.js +45 -0
  31. package/dist/cjs/index.js.map +6 -0
  32. package/dist/cjs/index.native.js +64 -0
  33. package/dist/cjs/index.native.js.map +1 -0
  34. package/dist/cjs/migrate.cjs +117 -0
  35. package/dist/cjs/migrate.js +106 -0
  36. package/dist/cjs/migrate.js.map +6 -0
  37. package/dist/cjs/migrate.native.js +185 -0
  38. package/dist/cjs/migrate.native.js.map +1 -0
  39. package/dist/cjs/scripts/build-migrations.cjs +81 -0
  40. package/dist/cjs/scripts/build-migrations.js +69 -0
  41. package/dist/cjs/scripts/build-migrations.js.map +6 -0
  42. package/dist/cjs/scripts/build-migrations.native.js +86 -0
  43. package/dist/cjs/scripts/build-migrations.native.js.map +1 -0
  44. package/dist/cjs/scripts/drizzle-migrations-sync.cjs +111 -0
  45. package/dist/cjs/scripts/drizzle-migrations-sync.js +101 -0
  46. package/dist/cjs/scripts/drizzle-migrations-sync.js.map +6 -0
  47. package/dist/cjs/scripts/drizzle-migrations-sync.native.js +209 -0
  48. package/dist/cjs/scripts/drizzle-migrations-sync.native.js.map +1 -0
  49. package/dist/cjs/scripts/migration-add.cjs +53 -0
  50. package/dist/cjs/scripts/migration-add.js +40 -0
  51. package/dist/cjs/scripts/migration-add.js.map +6 -0
  52. package/dist/cjs/scripts/migration-add.native.js +72 -0
  53. package/dist/cjs/scripts/migration-add.native.js.map +1 -0
  54. package/dist/cjs/scripts/pg_dump.cjs +49 -0
  55. package/dist/cjs/scripts/pg_dump.js +36 -0
  56. package/dist/cjs/scripts/pg_dump.js.map +6 -0
  57. package/dist/cjs/scripts/pg_dump.native.js +55 -0
  58. package/dist/cjs/scripts/pg_dump.native.js.map +1 -0
  59. package/dist/cjs/scripts/psql.cjs +50 -0
  60. package/dist/cjs/scripts/psql.js +37 -0
  61. package/dist/cjs/scripts/psql.js.map +6 -0
  62. package/dist/cjs/scripts/psql.native.js +56 -0
  63. package/dist/cjs/scripts/psql.native.js.map +1 -0
  64. package/dist/cjs/sql.cjs +40 -0
  65. package/dist/cjs/sql.js +35 -0
  66. package/dist/cjs/sql.js.map +6 -0
  67. package/dist/cjs/sql.native.js +49 -0
  68. package/dist/cjs/sql.native.js.map +1 -0
  69. package/dist/esm/build.js +5 -0
  70. package/dist/esm/build.js.map +6 -0
  71. package/dist/esm/build.mjs +3 -0
  72. package/dist/esm/build.mjs.map +1 -0
  73. package/dist/esm/build.native.js +3 -0
  74. package/dist/esm/build.native.js.map +1 -0
  75. package/dist/esm/cli.js +134 -0
  76. package/dist/esm/cli.js.map +6 -0
  77. package/dist/esm/cli.mjs +157 -0
  78. package/dist/esm/cli.mjs.map +1 -0
  79. package/dist/esm/cli.native.js +162 -0
  80. package/dist/esm/cli.native.js.map +1 -0
  81. package/dist/esm/createServerHelpers.js +13 -0
  82. package/dist/esm/createServerHelpers.js.map +6 -0
  83. package/dist/esm/createServerHelpers.mjs +14 -0
  84. package/dist/esm/createServerHelpers.mjs.map +1 -0
  85. package/dist/esm/createServerHelpers.native.js +17 -0
  86. package/dist/esm/createServerHelpers.native.js.map +1 -0
  87. package/dist/esm/helpers/chunkedQuery.js +35 -0
  88. package/dist/esm/helpers/chunkedQuery.js.map +6 -0
  89. package/dist/esm/helpers/chunkedQuery.mjs +36 -0
  90. package/dist/esm/helpers/chunkedQuery.mjs.map +1 -0
  91. package/dist/esm/helpers/chunkedQuery.native.js +46 -0
  92. package/dist/esm/helpers/chunkedQuery.native.js.map +1 -0
  93. package/dist/esm/helpers/getDBClient.js +155 -0
  94. package/dist/esm/helpers/getDBClient.js.map +6 -0
  95. package/dist/esm/helpers/getDBClient.mjs +136 -0
  96. package/dist/esm/helpers/getDBClient.mjs.map +1 -0
  97. package/dist/esm/helpers/getDBClient.native.js +150 -0
  98. package/dist/esm/helpers/getDBClient.native.js.map +1 -0
  99. package/dist/esm/index.js +29 -0
  100. package/dist/esm/index.js.map +6 -0
  101. package/dist/esm/index.mjs +18 -0
  102. package/dist/esm/index.mjs.map +1 -0
  103. package/dist/esm/index.native.js +20 -0
  104. package/dist/esm/index.native.js.map +1 -0
  105. package/dist/esm/migrate.js +91 -0
  106. package/dist/esm/migrate.js.map +6 -0
  107. package/dist/esm/migrate.mjs +94 -0
  108. package/dist/esm/migrate.mjs.map +1 -0
  109. package/dist/esm/migrate.native.js +159 -0
  110. package/dist/esm/migrate.native.js.map +1 -0
  111. package/dist/esm/scripts/build-migrations.js +46 -0
  112. package/dist/esm/scripts/build-migrations.js.map +6 -0
  113. package/dist/esm/scripts/build-migrations.mjs +47 -0
  114. package/dist/esm/scripts/build-migrations.mjs.map +1 -0
  115. package/dist/esm/scripts/build-migrations.native.js +49 -0
  116. package/dist/esm/scripts/build-migrations.native.js.map +1 -0
  117. package/dist/esm/scripts/drizzle-migrations-sync.js +87 -0
  118. package/dist/esm/scripts/drizzle-migrations-sync.js.map +6 -0
  119. package/dist/esm/scripts/drizzle-migrations-sync.mjs +88 -0
  120. package/dist/esm/scripts/drizzle-migrations-sync.mjs.map +1 -0
  121. package/dist/esm/scripts/drizzle-migrations-sync.native.js +183 -0
  122. package/dist/esm/scripts/drizzle-migrations-sync.native.js.map +1 -0
  123. package/dist/esm/scripts/migration-add.js +25 -0
  124. package/dist/esm/scripts/migration-add.js.map +6 -0
  125. package/dist/esm/scripts/migration-add.mjs +30 -0
  126. package/dist/esm/scripts/migration-add.mjs.map +1 -0
  127. package/dist/esm/scripts/migration-add.native.js +46 -0
  128. package/dist/esm/scripts/migration-add.native.js.map +1 -0
  129. package/dist/esm/scripts/pg_dump.js +20 -0
  130. package/dist/esm/scripts/pg_dump.js.map +6 -0
  131. package/dist/esm/scripts/pg_dump.mjs +26 -0
  132. package/dist/esm/scripts/pg_dump.mjs.map +1 -0
  133. package/dist/esm/scripts/pg_dump.native.js +29 -0
  134. package/dist/esm/scripts/pg_dump.native.js.map +1 -0
  135. package/dist/esm/scripts/psql.js +21 -0
  136. package/dist/esm/scripts/psql.js.map +6 -0
  137. package/dist/esm/scripts/psql.mjs +27 -0
  138. package/dist/esm/scripts/psql.mjs.map +1 -0
  139. package/dist/esm/scripts/psql.native.js +30 -0
  140. package/dist/esm/scripts/psql.native.js.map +1 -0
  141. package/dist/esm/sql.js +19 -0
  142. package/dist/esm/sql.js.map +6 -0
  143. package/dist/esm/sql.mjs +15 -0
  144. package/dist/esm/sql.mjs.map +1 -0
  145. package/dist/esm/sql.native.js +21 -0
  146. package/dist/esm/sql.native.js.map +1 -0
  147. package/package.json +67 -0
  148. package/src/build.ts +2 -0
  149. package/src/cli.ts +153 -0
  150. package/src/createServerHelpers.ts +20 -0
  151. package/src/helpers/chunkedQuery.ts +91 -0
  152. package/src/helpers/getDBClient.ts +264 -0
  153. package/src/index.ts +36 -0
  154. package/src/migrate.ts +192 -0
  155. package/src/scripts/build-migrations.ts +66 -0
  156. package/src/scripts/drizzle-migrations-sync.ts +179 -0
  157. package/src/scripts/migration-add.ts +54 -0
  158. package/src/scripts/pg_dump.ts +46 -0
  159. package/src/scripts/psql.ts +51 -0
  160. package/src/sql.ts +36 -0
  161. package/types/build.d.ts +2 -0
  162. package/types/build.d.ts.map +1 -0
  163. package/types/cli.d.ts +3 -0
  164. package/types/cli.d.ts.map +1 -0
  165. package/types/createServerHelpers.d.ts +9 -0
  166. package/types/createServerHelpers.d.ts.map +1 -0
  167. package/types/helpers/chunkedQuery.d.ts +17 -0
  168. package/types/helpers/chunkedQuery.d.ts.map +1 -0
  169. package/types/helpers/getDBClient.d.ts +11 -0
  170. package/types/helpers/getDBClient.d.ts.map +1 -0
  171. package/types/index.d.ts +10 -0
  172. package/types/index.d.ts.map +1 -0
  173. package/types/migrate.d.ts +25 -0
  174. package/types/migrate.d.ts.map +1 -0
  175. package/types/scripts/build-migrations.d.ts +8 -0
  176. package/types/scripts/build-migrations.d.ts.map +1 -0
  177. package/types/scripts/drizzle-migrations-sync.d.ts +11 -0
  178. package/types/scripts/drizzle-migrations-sync.d.ts.map +1 -0
  179. package/types/scripts/migration-add.d.ts +6 -0
  180. package/types/scripts/migration-add.d.ts.map +1 -0
  181. package/types/scripts/pg_dump.d.ts +11 -0
  182. package/types/scripts/pg_dump.d.ts.map +1 -0
  183. package/types/scripts/psql.d.ts +11 -0
  184. package/types/scripts/psql.d.ts.map +1 -0
  185. package/types/sql.d.ts +9 -0
  186. package/types/sql.d.ts.map +1 -0
@@ -0,0 +1,183 @@
1
+ #!/usr/bin/env bun
2
+ import { readdir, writeFile, stat, rename } from "fs/promises";
3
+ import { join, basename, extname } from "path";
4
+ import { existsSync } from "fs";
5
+ function getMigrationNumber(filename) {
6
+ var match = filename.match(/^(\d+)/);
7
+ return match && match[1] ? Number.parseInt(match[1], 10) : null;
8
+ }
9
+ async function getHighestMigrationNumber(dir) {
10
+ var files = await readdir(dir),
11
+ highest = -1,
12
+ _iteratorNormalCompletion = !0,
13
+ _didIteratorError = !1,
14
+ _iteratorError = void 0;
15
+ try {
16
+ for (var _iterator = files[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
17
+ var file = _step.value,
18
+ num = getMigrationNumber(file);
19
+ num !== null && num > highest && (highest = num);
20
+ }
21
+ } catch (err) {
22
+ _didIteratorError = !0, _iteratorError = err;
23
+ } finally {
24
+ try {
25
+ !_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
26
+ } finally {
27
+ if (_didIteratorError) throw _iteratorError;
28
+ }
29
+ }
30
+ return highest;
31
+ }
32
+ async function renameNewDrizzleMigrations(migrationsPath, sqlFiles) {
33
+ var drizzlePattern = /^(\d{4})_[a-z]+_[a-z_]+\.sql$/,
34
+ files = await readdir(migrationsPath),
35
+ highestNumber = await getHighestMigrationNumber(migrationsPath),
36
+ newDrizzleSqlFiles = sqlFiles.filter(function (file2) {
37
+ if (!drizzlePattern.test(file2)) return !1;
38
+ var tsFile = file2.replace(".sql", ".ts");
39
+ return !files.includes(tsFile);
40
+ });
41
+ if (newDrizzleSqlFiles.length === 0) return sqlFiles;
42
+ var migrationGroups = /* @__PURE__ */new Map(),
43
+ _iteratorNormalCompletion = !0,
44
+ _didIteratorError = !1,
45
+ _iteratorError = void 0;
46
+ try {
47
+ for (var _iterator = newDrizzleSqlFiles[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
48
+ var file = _step.value,
49
+ num = file.substring(0, 4);
50
+ migrationGroups.has(num) || migrationGroups.set(num, []), migrationGroups.get(num).push(file);
51
+ }
52
+ } catch (err) {
53
+ _didIteratorError = !0, _iteratorError = err;
54
+ } finally {
55
+ try {
56
+ !_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
57
+ } finally {
58
+ if (_didIteratorError) throw _iteratorError;
59
+ }
60
+ }
61
+ var nextNumber = highestNumber + 1,
62
+ renamedFiles = [],
63
+ _iteratorNormalCompletion1 = !0,
64
+ _didIteratorError1 = !1,
65
+ _iteratorError1 = void 0;
66
+ try {
67
+ for (var _iterator1 = migrationGroups[Symbol.iterator](), _step1; !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = !0) {
68
+ var [originalNum, groupFiles] = _step1.value,
69
+ drizzleNum = Number.parseInt(originalNum, 10);
70
+ if (drizzleNum <= highestNumber) {
71
+ var newNumStr = nextNumber.toString().padStart(4, "0");
72
+ console.info(`Renumbering new drizzle migration ${originalNum} to ${newNumStr}`);
73
+ var _iteratorNormalCompletion2 = !0,
74
+ _didIteratorError2 = !1,
75
+ _iteratorError2 = void 0;
76
+ try {
77
+ for (var _iterator2 = groupFiles[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = !0) {
78
+ var file1 = _step2.value,
79
+ newName = file1.replace(/^\d{4}/, newNumStr),
80
+ oldPath = join(migrationsPath, file1),
81
+ newPath = join(migrationsPath, newName);
82
+ await rename(oldPath, newPath), console.info(` Renamed ${file1} -> ${newName}`), renamedFiles.push(newName);
83
+ }
84
+ } catch (err) {
85
+ _didIteratorError2 = !0, _iteratorError2 = err;
86
+ } finally {
87
+ try {
88
+ !_iteratorNormalCompletion2 && _iterator2.return != null && _iterator2.return();
89
+ } finally {
90
+ if (_didIteratorError2) throw _iteratorError2;
91
+ }
92
+ }
93
+ var metaDir = join(migrationsPath, "meta");
94
+ if (existsSync(metaDir)) {
95
+ var metaFiles = await readdir(metaDir),
96
+ snapshotFile = `${originalNum}_snapshot.json`;
97
+ if (metaFiles.includes(snapshotFile)) {
98
+ var newSnapshotName = `${newNumStr}_snapshot.json`;
99
+ await rename(join(metaDir, snapshotFile), join(metaDir, newSnapshotName)), console.info(` Renamed meta/${snapshotFile} -> meta/${newSnapshotName}`);
100
+ }
101
+ }
102
+ nextNumber++;
103
+ } else renamedFiles.push(...groupFiles);
104
+ }
105
+ } catch (err) {
106
+ _didIteratorError1 = !0, _iteratorError1 = err;
107
+ } finally {
108
+ try {
109
+ !_iteratorNormalCompletion1 && _iterator1.return != null && _iterator1.return();
110
+ } finally {
111
+ if (_didIteratorError1) throw _iteratorError1;
112
+ }
113
+ }
114
+ return sqlFiles.map(function (file2) {
115
+ var idx = newDrizzleSqlFiles.indexOf(file2);
116
+ if (idx !== -1) {
117
+ var _iteratorNormalCompletion3 = !0,
118
+ _didIteratorError3 = !1,
119
+ _iteratorError3 = void 0;
120
+ try {
121
+ for (var _iterator3 = renamedFiles[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = !0) {
122
+ var renamed = _step3.value;
123
+ if (renamed.includes(file2.substring(5))) return renamed;
124
+ }
125
+ } catch (err) {
126
+ _didIteratorError3 = !0, _iteratorError3 = err;
127
+ } finally {
128
+ try {
129
+ !_iteratorNormalCompletion3 && _iterator3.return != null && _iterator3.return();
130
+ } finally {
131
+ if (_didIteratorError3) throw _iteratorError3;
132
+ }
133
+ }
134
+ }
135
+ return file2;
136
+ });
137
+ }
138
+ async function syncDrizzleMigrations(options) {
139
+ var {
140
+ migrationsDir
141
+ } = options,
142
+ files = await readdir(migrationsDir),
143
+ sqlFiles = files.filter(function (file) {
144
+ return extname(file) === ".sql";
145
+ });
146
+ console.info(`Found ${sqlFiles.length} SQL files to convert to migrations.`), sqlFiles = await renameNewDrizzleMigrations(migrationsDir, sqlFiles);
147
+ var _iteratorNormalCompletion = !0,
148
+ _didIteratorError = !1,
149
+ _iteratorError = void 0;
150
+ try {
151
+ for (var _iterator = sqlFiles[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
152
+ var sqlFile = _step.value,
153
+ baseName = basename(sqlFile, ".sql"),
154
+ tsFileName = `${baseName}.ts`,
155
+ tsFilePath = join(migrationsDir, tsFileName);
156
+ if (existsSync(tsFilePath)) {
157
+ var sqlStat = await stat(join(migrationsDir, sqlFile)),
158
+ tsStat = await stat(tsFilePath);
159
+ if (tsStat.mtimeMs > sqlStat.mtimeMs) continue;
160
+ console.info(`Updating ${tsFileName} as SQL file has been modified.`);
161
+ } else console.info(`Creating ${tsFileName}`);
162
+ var migrationContent = `import type { PoolClient } from 'pg'
163
+ import sql from './${sqlFile}?raw'
164
+
165
+ export async function up(client: PoolClient) {
166
+ await client.query(sql)
167
+ }
168
+ `;
169
+ await writeFile(tsFilePath, migrationContent), console.info(`Successfully created ${tsFileName}`);
170
+ }
171
+ } catch (err) {
172
+ _didIteratorError = !0, _iteratorError = err;
173
+ } finally {
174
+ try {
175
+ !_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
176
+ } finally {
177
+ if (_didIteratorError) throw _iteratorError;
178
+ }
179
+ }
180
+ console.info("Migration sync completed.");
181
+ }
182
+ export { syncDrizzleMigrations };
183
+ //# sourceMappingURL=drizzle-migrations-sync.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["readdir","writeFile","stat","rename","join","basename","extname","existsSync","getMigrationNumber","filename","match","Number","parseInt","getHighestMigrationNumber","dir","files","highest","_iteratorNormalCompletion","_didIteratorError","_iteratorError","_iterator","Symbol","iterator","_step","next","done","file","value","num","err","return","renameNewDrizzleMigrations","migrationsPath","sqlFiles","drizzlePattern","highestNumber","newDrizzleSqlFiles","filter","file2","test","tsFile","replace","includes","length","migrationGroups","Map","substring","has","set","get","push","nextNumber","renamedFiles","_iteratorNormalCompletion1","_didIteratorError1","_iteratorError1","_iterator1","_step1","originalNum","groupFiles","drizzleNum","newNumStr","toString","padStart","console","info","_iteratorNormalCompletion2","_didIteratorError2","_iteratorError2","_iterator2","_step2","file1","newName","oldPath","newPath","metaDir","metaFiles","snapshotFile","newSnapshotName"],"sources":["../../../src/scripts/drizzle-migrations-sync.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,25 @@
1
+ import { join } from "node:path";
2
+ import { readdirSync, writeFileSync } from "node:fs";
3
+ const commonWords = ["sapphire", "emerald", "ruby", "amber", "topaz", "onyx", "pearl"];
4
+ function addMigration(options) {
5
+ const { migrationsDir, name } = options, migrationName = name || commonWords[Math.floor(Math.random() * commonWords.length)], files = readdirSync(migrationsDir), migrationRegex = /^(\d+)[-_].*\.(ts|sql)$/;
6
+ let maxNumber = 0;
7
+ for (const file of files) {
8
+ const match = file.match(migrationRegex);
9
+ if (match?.[1]) {
10
+ const num = Number.parseInt(match[1], 10);
11
+ !Number.isNaN(num) && num > maxNumber && (maxNumber = num);
12
+ }
13
+ }
14
+ const newFilename = `${(maxNumber + 1).toString().padStart(4, "0")}-${migrationName}.ts`, newFilePath = join(migrationsDir, newFilename);
15
+ return writeFileSync(newFilePath, `import type { PoolClient } from 'pg'
16
+
17
+ export async function up(client: PoolClient) {
18
+ // implementation for applying this migration
19
+ }
20
+ `), console.info(`Created custom migration: ${newFilePath}`), console.info("For Drizzle schema migrations, run 'drizzle-kit generate' instead"), newFilePath;
21
+ }
22
+ export {
23
+ addMigration
24
+ };
25
+ //# sourceMappingURL=migration-add.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/scripts/migration-add.ts"],
4
+ "mappings": "AAAA,SAAS,YAAY;AACrB,SAAS,aAAa,qBAAqB;AAO3C,MAAM,cAAc,CAAC,YAAY,WAAW,QAAQ,SAAS,SAAS,QAAQ,OAAO;AAE9E,SAAS,aAAa,SAAsC;AACjE,QAAM,EAAE,eAAe,KAAK,IAAI,SAG1B,gBACJ,QAAQ,YAAY,KAAK,MAAM,KAAK,OAAO,IAAI,YAAY,MAAM,CAAC,GAG9D,QAAQ,YAAY,aAAa,GAGjC,iBAAiB;AACvB,MAAI,YAAY;AAChB,aAAW,QAAQ,OAAO;AACxB,UAAM,QAAQ,KAAK,MAAM,cAAc;AACvC,QAAI,QAAQ,CAAC,GAAG;AACd,YAAM,MAAM,OAAO,SAAS,MAAM,CAAC,GAAG,EAAE;AACxC,MAAI,CAAC,OAAO,MAAM,GAAG,KAAK,MAAM,cAC9B,YAAY;AAAA,IAEhB;AAAA,EACF;AAIA,QAAM,cAAc,IADA,YAAY,GAAG,SAAS,EAAE,SAAS,GAAG,GAAG,CAC5B,IAAI,aAAa,OAC5C,cAAc,KAAK,eAAe,WAAW;AAWnD,uBAAc,aARU;AAAA;AAAA;AAAA;AAAA;AAAA,CAQkB,GAE1C,QAAQ,KAAK,6BAA6B,WAAW,EAAE,GACvD,QAAQ,KAAK,mEAAmE,GAEzE;AACT;",
5
+ "names": []
6
+ }
@@ -0,0 +1,30 @@
1
+ import { join } from "node:path";
2
+ import { readdirSync, writeFileSync } from "node:fs";
3
+ const commonWords = ["sapphire", "emerald", "ruby", "amber", "topaz", "onyx", "pearl"];
4
+ function addMigration(options) {
5
+ const {
6
+ migrationsDir,
7
+ name
8
+ } = options,
9
+ migrationName = name || commonWords[Math.floor(Math.random() * commonWords.length)],
10
+ files = readdirSync(migrationsDir),
11
+ migrationRegex = /^(\d+)[-_].*\.(ts|sql)$/;
12
+ let maxNumber = 0;
13
+ for (const file of files) {
14
+ const match = file.match(migrationRegex);
15
+ if (match?.[1]) {
16
+ const num = Number.parseInt(match[1], 10);
17
+ !Number.isNaN(num) && num > maxNumber && (maxNumber = num);
18
+ }
19
+ }
20
+ const newFilename = `${(maxNumber + 1).toString().padStart(4, "0")}-${migrationName}.ts`,
21
+ newFilePath = join(migrationsDir, newFilename);
22
+ return writeFileSync(newFilePath, `import type { PoolClient } from 'pg'
23
+
24
+ export async function up(client: PoolClient) {
25
+ // implementation for applying this migration
26
+ }
27
+ `), console.info(`Created custom migration: ${newFilePath}`), console.info("For Drizzle schema migrations, run 'drizzle-kit generate' instead"), newFilePath;
28
+ }
29
+ export { addMigration };
30
+ //# sourceMappingURL=migration-add.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["join","readdirSync","writeFileSync","commonWords","addMigration","options","migrationsDir","name","migrationName","Math","floor","random","length","files","migrationRegex","maxNumber","file","match","num","Number","parseInt","isNaN","newFilename","toString","padStart","newFilePath","console","info"],"sources":["../../../src/scripts/migration-add.ts"],"sourcesContent":[null],"mappings":"AAAA,SAASA,IAAA,QAAY;AACrB,SAASC,WAAA,EAAaC,aAAA,QAAqB;AAO3C,MAAMC,WAAA,GAAc,CAAC,YAAY,WAAW,QAAQ,SAAS,SAAS,QAAQ,OAAO;AAE9E,SAASC,aAAaC,OAAA,EAAsC;EACjE,MAAM;MAAEC,aAAA;MAAeC;IAAK,IAAIF,OAAA;IAG1BG,aAAA,GACJD,IAAA,IAAQJ,WAAA,CAAYM,IAAA,CAAKC,KAAA,CAAMD,IAAA,CAAKE,MAAA,CAAO,IAAIR,WAAA,CAAYS,MAAM,CAAC;IAG9DC,KAAA,GAAQZ,WAAA,CAAYK,aAAa;IAGjCQ,cAAA,GAAiB;EACvB,IAAIC,SAAA,GAAY;EAChB,WAAWC,IAAA,IAAQH,KAAA,EAAO;IACxB,MAAMI,KAAA,GAAQD,IAAA,CAAKC,KAAA,CAAMH,cAAc;IACvC,IAAIG,KAAA,GAAQ,CAAC,GAAG;MACd,MAAMC,GAAA,GAAMC,MAAA,CAAOC,QAAA,CAASH,KAAA,CAAM,CAAC,GAAG,EAAE;MACpC,CAACE,MAAA,CAAOE,KAAA,CAAMH,GAAG,KAAKA,GAAA,GAAMH,SAAA,KAC9BA,SAAA,GAAYG,GAAA;IAEhB;EACF;EAIA,MAAMI,WAAA,GAAc,IADAP,SAAA,GAAY,GAAGQ,QAAA,CAAS,EAAEC,QAAA,CAAS,GAAG,GAAG,CAC5B,IAAIhB,aAAa;IAC5CiB,WAAA,GAAczB,IAAA,CAAKM,aAAA,EAAegB,WAAW;EAWnD,OAAApB,aAAA,CAAcuB,WAAA,EARU;AAAA;AAAA;AAAA;AAAA;AAAA,CAQkB,GAE1CC,OAAA,CAAQC,IAAA,CAAK,6BAA6BF,WAAW,EAAE,GACvDC,OAAA,CAAQC,IAAA,CAAK,mEAAmE,GAEzEF,WAAA;AACT","ignoreList":[]}
@@ -0,0 +1,46 @@
1
+ import { join } from "path";
2
+ import { readdirSync, writeFileSync } from "fs";
3
+ var commonWords = ["sapphire", "emerald", "ruby", "amber", "topaz", "onyx", "pearl"];
4
+ function addMigration(options) {
5
+ var {
6
+ migrationsDir,
7
+ name
8
+ } = options,
9
+ migrationName = name || commonWords[Math.floor(Math.random() * commonWords.length)],
10
+ files = readdirSync(migrationsDir),
11
+ migrationRegex = /^(\d+)[-_].*\.(ts|sql)$/,
12
+ maxNumber = 0,
13
+ _iteratorNormalCompletion = !0,
14
+ _didIteratorError = !1,
15
+ _iteratorError = void 0;
16
+ try {
17
+ for (var _iterator = files[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
18
+ var file = _step.value,
19
+ match = file.match(migrationRegex);
20
+ if (match?.[1]) {
21
+ var num = Number.parseInt(match[1], 10);
22
+ !Number.isNaN(num) && num > maxNumber && (maxNumber = num);
23
+ }
24
+ }
25
+ } catch (err) {
26
+ _didIteratorError = !0, _iteratorError = err;
27
+ } finally {
28
+ try {
29
+ !_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
30
+ } finally {
31
+ if (_didIteratorError) throw _iteratorError;
32
+ }
33
+ }
34
+ var nextNumber = (maxNumber + 1).toString().padStart(4, "0"),
35
+ newFilename = `${nextNumber}-${migrationName}.ts`,
36
+ newFilePath = join(migrationsDir, newFilename),
37
+ templateContent = `import type { PoolClient } from 'pg'
38
+
39
+ export async function up(client: PoolClient) {
40
+ // implementation for applying this migration
41
+ }
42
+ `;
43
+ return writeFileSync(newFilePath, templateContent), console.info(`Created custom migration: ${newFilePath}`), console.info("For Drizzle schema migrations, run 'drizzle-kit generate' instead"), newFilePath;
44
+ }
45
+ export { addMigration };
46
+ //# sourceMappingURL=migration-add.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["join","readdirSync","writeFileSync","commonWords","addMigration","options","migrationsDir","name","migrationName","Math","floor","random","length","files","migrationRegex","maxNumber","_iteratorNormalCompletion","_didIteratorError","_iteratorError","_iterator","Symbol","iterator","_step","next","done","file","value","match","num","Number","parseInt","isNaN"],"sources":["../../../src/scripts/migration-add.ts"],"sourcesContent":[null],"mappings":"AAAA,SAASA,IAAA,QAAY;AACrB,SAASC,WAAA,EAAaC,aAAA,QAAqB;AAO3C,IAAAC,WAAM,IAEC,UAAS,EACd,SAAQ,EAWR,MAAI,EACJ,SACE,SACA,MAAI,EACF,QACA;AACc,SAEhBC,aAAAC,OAAA;EACF;MAAAC,aAAA;MAAAC;IAAA,IAAAF,OAAA;IAAAG,aAAA,GAAAD,IAAA,IAAAJ,WAAA,CAAAM,IAAA,CAAAC,KAAA,CAAAD,IAAA,CAAAE,MAAA,KAAAR,WAAA,CAAAS,MAAA;IAAAC,KAAA,GAAAZ,WAAA,CAAAK,aAAA;IAAAQ,cAAA;IAAAC,SAAA;IAAAC,yBAAA;IAAAC,iBAAA;IAAAC,cAAA;EAIA;IAYA,SAAAC,SAAA,GAAcN,KAAA,CAAAO,MARU,CAAAC,QAAA,KAAAC,KAAA,IAAAN,yBAAA,IAAAM,KAAA,GAAAH,SAAA,CAAAI,IAAA,IAAAC,IAAA,GAAAR,yBAAA;MAAA,IAAAS,IAAA,GAAAH,KAAA,CAAAI,KAAA;QAAAC,KAAA,GAAAF,IAAA,CAAAE,KAAA,CAAAb,cAAA;MAAA,IAAAa,KAAA;QAAA,IAAAC,GAAA,GAAAC,MAAA,CAAAC,QAAA,CAAAH,KAAA;QAAA,CAAAE,MAAA,CAAAE,KAAA,CAAAH,GAAA,KAAAA,GAAA,GAAAb,SAAA,KAAAA,SAAA,GAAAa,GAAA;MAUxB;IAIF","ignoreList":[]}
@@ -0,0 +1,20 @@
1
+ function runPgDump(options = {}) {
2
+ const { connectionString, host, port, database, user, password, args = [] } = options, env = {
3
+ ...process.env
4
+ };
5
+ if (connectionString) {
6
+ const url = new URL(connectionString);
7
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
8
+ } else
9
+ host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
10
+ return console.info(`Running pg_dump on postgres ${env.PGHOST}/${env.PGDATABASE}`), Bun.spawnSync(["pg_dump", ...args], {
11
+ stdin: "ignore",
12
+ stdout: "inherit",
13
+ stderr: "inherit",
14
+ env
15
+ }).exitCode;
16
+ }
17
+ export {
18
+ runPgDump
19
+ };
20
+ //# sourceMappingURL=pg_dump.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/scripts/pg_dump.ts"],
4
+ "mappings": "AAUO,SAAS,UAAU,UAAyB,CAAC,GAAG;AACrD,QAAM,EAAE,kBAAkB,MAAM,MAAM,UAAU,MAAM,UAAU,OAAO,CAAC,EAAE,IAAI,SAExE,MAA8B;AAAA,IAClC,GAAG,QAAQ;AAAA,EACb;AAEA,MAAI,kBAAkB;AAEpB,UAAM,MAAM,IAAI,IAAI,gBAAgB;AACpC,QAAI,SAAS,IAAI,UACjB,IAAI,SAAS,IAAI,QAAQ,QACzB,IAAI,aAAa,IAAI,SAAS,MAAM,CAAC,GACrC,IAAI,SAAS,IAAI,UACb,IAAI,aACN,IAAI,aAAa,IAAI;AAAA,EAEzB;AACE,IAAI,SAAM,IAAI,SAAS,OACnB,SAAM,IAAI,SAAS,KAAK,SAAS,IACjC,aAAU,IAAI,aAAa,WAC3B,SAAM,IAAI,SAAS,OACnB,aAAU,IAAI,aAAa;AAGjC,iBAAQ,KAAK,+BAA+B,IAAI,MAAM,IAAI,IAAI,UAAU,EAAE,GAE3D,IAAI,UAAU,CAAC,WAAW,GAAG,IAAI,GAAG;AAAA,IACjD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR;AAAA,EACF,CAAC,EAEa;AAChB;",
5
+ "names": []
6
+ }
@@ -0,0 +1,26 @@
1
+ function runPgDump(options = {}) {
2
+ const {
3
+ connectionString,
4
+ host,
5
+ port,
6
+ database,
7
+ user,
8
+ password,
9
+ args = []
10
+ } = options,
11
+ env = {
12
+ ...process.env
13
+ };
14
+ if (connectionString) {
15
+ const url = new URL(connectionString);
16
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
17
+ } else host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
18
+ return console.info(`Running pg_dump on postgres ${env.PGHOST}/${env.PGDATABASE}`), Bun.spawnSync(["pg_dump", ...args], {
19
+ stdin: "ignore",
20
+ stdout: "inherit",
21
+ stderr: "inherit",
22
+ env
23
+ }).exitCode;
24
+ }
25
+ export { runPgDump };
26
+ //# sourceMappingURL=pg_dump.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["runPgDump","options","connectionString","host","port","database","user","password","args","env","process","url","URL","PGHOST","hostname","PGPORT","PGDATABASE","pathname","slice","PGUSER","username","PGPASSWORD","toString","console","info","Bun","spawnSync","stdin","stdout","stderr","exitCode"],"sources":["../../../src/scripts/pg_dump.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,UAAUC,OAAA,GAAyB,CAAC,GAAG;EACrD,MAAM;MAAEC,gBAAA;MAAkBC,IAAA;MAAMC,IAAA;MAAMC,QAAA;MAAUC,IAAA;MAAMC,QAAA;MAAUC,IAAA,GAAO;IAAG,IAAIP,OAAA;IAExEQ,GAAA,GAA8B;MAClC,GAAGC,OAAA,CAAQD;IACb;EAEA,IAAIP,gBAAA,EAAkB;IAEpB,MAAMS,GAAA,GAAM,IAAIC,GAAA,CAAIV,gBAAgB;IACpCO,GAAA,CAAII,MAAA,GAASF,GAAA,CAAIG,QAAA,EACjBL,GAAA,CAAIM,MAAA,GAASJ,GAAA,CAAIP,IAAA,IAAQ,QACzBK,GAAA,CAAIO,UAAA,GAAaL,GAAA,CAAIM,QAAA,CAASC,KAAA,CAAM,CAAC,GACrCT,GAAA,CAAIU,MAAA,GAASR,GAAA,CAAIS,QAAA,EACbT,GAAA,CAAIJ,QAAA,KACNE,GAAA,CAAIY,UAAA,GAAaV,GAAA,CAAIJ,QAAA;EAEzB,OACMJ,IAAA,KAAMM,GAAA,CAAII,MAAA,GAASV,IAAA,GACnBC,IAAA,KAAMK,GAAA,CAAIM,MAAA,GAASX,IAAA,CAAKkB,QAAA,CAAS,IACjCjB,QAAA,KAAUI,GAAA,CAAIO,UAAA,GAAaX,QAAA,GAC3BC,IAAA,KAAMG,GAAA,CAAIU,MAAA,GAASb,IAAA,GACnBC,QAAA,KAAUE,GAAA,CAAIY,UAAA,GAAad,QAAA;EAGjC,OAAAgB,OAAA,CAAQC,IAAA,CAAK,+BAA+Bf,GAAA,CAAII,MAAM,IAAIJ,GAAA,CAAIO,UAAU,EAAE,GAE3DS,GAAA,CAAIC,SAAA,CAAU,CAAC,WAAW,GAAGlB,IAAI,GAAG;IACjDmB,KAAA,EAAO;IACPC,MAAA,EAAQ;IACRC,MAAA,EAAQ;IACRpB;EACF,CAAC,EAEaqB,QAAA;AAChB","ignoreList":[]}
@@ -0,0 +1,29 @@
1
+ function runPgDump() {
2
+ var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {},
3
+ {
4
+ connectionString,
5
+ host,
6
+ port,
7
+ database,
8
+ user,
9
+ password,
10
+ args = []
11
+ } = options,
12
+ env = {
13
+ ...process.env
14
+ };
15
+ if (connectionString) {
16
+ var url = new URL(connectionString);
17
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
18
+ } else host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
19
+ console.info(`Running pg_dump on postgres ${env.PGHOST}/${env.PGDATABASE}`);
20
+ var result = Bun.spawnSync(["pg_dump", ...args], {
21
+ stdin: "ignore",
22
+ stdout: "inherit",
23
+ stderr: "inherit",
24
+ env
25
+ });
26
+ return result.exitCode;
27
+ }
28
+ export { runPgDump };
29
+ //# sourceMappingURL=pg_dump.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["runPgDump","options","arguments","length","connectionString","host","port","database","user","password","args","env","process","url","URL","PGHOST","hostname","PGPORT","PGDATABASE","pathname","slice","PGUSER","username","PGPASSWORD","toString","console","info","result","Bun","spawnSync","stdin","stdout"],"sources":["../../../src/scripts/pg_dump.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,UAAA,EAAU;EACxB,IAAAC,OAAQ,GAAAC,SAAA,CAAAC,MAAkB,GAAM,KAAMD,SAAA,CAAU,OAAM,SAAUA,SAAQ,CAAE,KAAI;IAAA;MAAAE,gBAE1C;MAAAC,IAAA;MAAAC,IAAA;MAAAC,QAAA;MAAAC,IAAA;MAAAC,QAAA;MAAAC,IAAA;IAAA,IAAAT,OAAA;IAAAU,GAAA;MAClC,GAAGC,OAAA,CAAQD;IACb;EAEA,IAAIP,gBAAA,EAAkB;IAEpB,IAAAS,GAAM,OAAMC,GAAI,CAAAV,gBAAI;IACpBO,GAAA,CAAII,MAAA,GAASF,GAAA,CAAIG,QAAA,EACjBL,GAAA,CAAIM,MAAA,GAASJ,GAAA,CAAIP,IAAA,IAAQ,QACzBK,GAAA,CAAIO,UAAA,GAAaL,GAAA,CAAIM,QAAA,CAASC,KAAA,CAAM,CAAC,GACrCT,GAAA,CAAIU,MAAA,GAASR,GAAA,CAAIS,QAAA,EACbT,GAAA,CAAIJ,QAAA,KACNE,GAAA,CAAIY,UAAA,GAAaV,GAAA,CAAIJ,QAAA;EAEzB,OACMJ,IAAA,KAAMM,GAAA,CAAII,MAAA,GAASV,IAAA,GACnBC,IAAA,KAAMK,GAAA,CAAIM,MAAA,GAASX,IAAA,CAAKkB,QAAA,CAAS,IACjCjB,QAAA,KAAUI,GAAA,CAAIO,UAAA,GAAaX,QAAA,GAC3BC,IAAA,KAAMG,GAAA,CAAIU,MAAA,GAASb,IAAA,GACnBC,QAAA,KAAUE,GAAA,CAAIY,UAAA,GAAad,QAAA;EAGjCgB,OAAA,CAAAC,IAAA,gCAAaf,GAAA,CAAAI,MAA+B,IAAIJ,GAAM,CAAAO,UAAQ;EAEX,IACjDS,MAAO,GAAAC,GAAA,CAAAC,SAAA,EACP,SAAQ,EACR,GAAAnB,IAAA,CAAQ,EACR;IACDoB,KAEa;IAChBC,MAAA","ignoreList":[]}
@@ -0,0 +1,21 @@
1
+ function runPsql(options = {}) {
2
+ const { connectionString, host, port, database, user, password, query } = options, env = {
3
+ ...process.env
4
+ };
5
+ if (connectionString) {
6
+ const url = new URL(connectionString);
7
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
8
+ } else
9
+ host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
10
+ const args = [];
11
+ return query && args.push("-c", query), console.info(`Connecting to postgres ${env.PGHOST}/${env.PGDATABASE}`), Bun.spawnSync(["psql", ...args], {
12
+ stdin: "ignore",
13
+ stdout: "inherit",
14
+ stderr: "inherit",
15
+ env
16
+ }).exitCode;
17
+ }
18
+ export {
19
+ runPsql
20
+ };
21
+ //# sourceMappingURL=psql.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/scripts/psql.ts"],
4
+ "mappings": "AAUO,SAAS,QAAQ,UAAuB,CAAC,GAAG;AACjD,QAAM,EAAE,kBAAkB,MAAM,MAAM,UAAU,MAAM,UAAU,MAAM,IAAI,SAEpE,MAA8B;AAAA,IAClC,GAAG,QAAQ;AAAA,EACb;AAEA,MAAI,kBAAkB;AAEpB,UAAM,MAAM,IAAI,IAAI,gBAAgB;AACpC,QAAI,SAAS,IAAI,UACjB,IAAI,SAAS,IAAI,QAAQ,QACzB,IAAI,aAAa,IAAI,SAAS,MAAM,CAAC,GACrC,IAAI,SAAS,IAAI,UACb,IAAI,aACN,IAAI,aAAa,IAAI;AAAA,EAEzB;AACE,IAAI,SAAM,IAAI,SAAS,OACnB,SAAM,IAAI,SAAS,KAAK,SAAS,IACjC,aAAU,IAAI,aAAa,WAC3B,SAAM,IAAI,SAAS,OACnB,aAAU,IAAI,aAAa;AAGjC,QAAM,OAAiB,CAAC;AACxB,SAAI,SACF,KAAK,KAAK,MAAM,KAAK,GAGvB,QAAQ,KAAK,0BAA0B,IAAI,MAAM,IAAI,IAAI,UAAU,EAAE,GAEtD,IAAI,UAAU,CAAC,QAAQ,GAAG,IAAI,GAAG;AAAA,IAC9C,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR;AAAA,EACF,CAAC,EAEa;AAChB;",
5
+ "names": []
6
+ }
@@ -0,0 +1,27 @@
1
+ function runPsql(options = {}) {
2
+ const {
3
+ connectionString,
4
+ host,
5
+ port,
6
+ database,
7
+ user,
8
+ password,
9
+ query
10
+ } = options,
11
+ env = {
12
+ ...process.env
13
+ };
14
+ if (connectionString) {
15
+ const url = new URL(connectionString);
16
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
17
+ } else host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
18
+ const args = [];
19
+ return query && args.push("-c", query), console.info(`Connecting to postgres ${env.PGHOST}/${env.PGDATABASE}`), Bun.spawnSync(["psql", ...args], {
20
+ stdin: "ignore",
21
+ stdout: "inherit",
22
+ stderr: "inherit",
23
+ env
24
+ }).exitCode;
25
+ }
26
+ export { runPsql };
27
+ //# sourceMappingURL=psql.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["runPsql","options","connectionString","host","port","database","user","password","query","env","process","url","URL","PGHOST","hostname","PGPORT","PGDATABASE","pathname","slice","PGUSER","username","PGPASSWORD","toString","args","push","console","info","Bun","spawnSync","stdin","stdout","stderr","exitCode"],"sources":["../../../src/scripts/psql.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,QAAQC,OAAA,GAAuB,CAAC,GAAG;EACjD,MAAM;MAAEC,gBAAA;MAAkBC,IAAA;MAAMC,IAAA;MAAMC,QAAA;MAAUC,IAAA;MAAMC,QAAA;MAAUC;IAAM,IAAIP,OAAA;IAEpEQ,GAAA,GAA8B;MAClC,GAAGC,OAAA,CAAQD;IACb;EAEA,IAAIP,gBAAA,EAAkB;IAEpB,MAAMS,GAAA,GAAM,IAAIC,GAAA,CAAIV,gBAAgB;IACpCO,GAAA,CAAII,MAAA,GAASF,GAAA,CAAIG,QAAA,EACjBL,GAAA,CAAIM,MAAA,GAASJ,GAAA,CAAIP,IAAA,IAAQ,QACzBK,GAAA,CAAIO,UAAA,GAAaL,GAAA,CAAIM,QAAA,CAASC,KAAA,CAAM,CAAC,GACrCT,GAAA,CAAIU,MAAA,GAASR,GAAA,CAAIS,QAAA,EACbT,GAAA,CAAIJ,QAAA,KACNE,GAAA,CAAIY,UAAA,GAAaV,GAAA,CAAIJ,QAAA;EAEzB,OACMJ,IAAA,KAAMM,GAAA,CAAII,MAAA,GAASV,IAAA,GACnBC,IAAA,KAAMK,GAAA,CAAIM,MAAA,GAASX,IAAA,CAAKkB,QAAA,CAAS,IACjCjB,QAAA,KAAUI,GAAA,CAAIO,UAAA,GAAaX,QAAA,GAC3BC,IAAA,KAAMG,GAAA,CAAIU,MAAA,GAASb,IAAA,GACnBC,QAAA,KAAUE,GAAA,CAAIY,UAAA,GAAad,QAAA;EAGjC,MAAMgB,IAAA,GAAiB,EAAC;EACxB,OAAIf,KAAA,IACFe,IAAA,CAAKC,IAAA,CAAK,MAAMhB,KAAK,GAGvBiB,OAAA,CAAQC,IAAA,CAAK,0BAA0BjB,GAAA,CAAII,MAAM,IAAIJ,GAAA,CAAIO,UAAU,EAAE,GAEtDW,GAAA,CAAIC,SAAA,CAAU,CAAC,QAAQ,GAAGL,IAAI,GAAG;IAC9CM,KAAA,EAAO;IACPC,MAAA,EAAQ;IACRC,MAAA,EAAQ;IACRtB;EACF,CAAC,EAEauB,QAAA;AAChB","ignoreList":[]}
@@ -0,0 +1,30 @@
1
+ function runPsql() {
2
+ var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {},
3
+ {
4
+ connectionString,
5
+ host,
6
+ port,
7
+ database,
8
+ user,
9
+ password,
10
+ query
11
+ } = options,
12
+ env = {
13
+ ...process.env
14
+ };
15
+ if (connectionString) {
16
+ var url = new URL(connectionString);
17
+ env.PGHOST = url.hostname, env.PGPORT = url.port || "5432", env.PGDATABASE = url.pathname.slice(1), env.PGUSER = url.username, url.password && (env.PGPASSWORD = url.password);
18
+ } else host && (env.PGHOST = host), port && (env.PGPORT = port.toString()), database && (env.PGDATABASE = database), user && (env.PGUSER = user), password && (env.PGPASSWORD = password);
19
+ var args = [];
20
+ query && args.push("-c", query), console.info(`Connecting to postgres ${env.PGHOST}/${env.PGDATABASE}`);
21
+ var result = Bun.spawnSync(["psql", ...args], {
22
+ stdin: "ignore",
23
+ stdout: "inherit",
24
+ stderr: "inherit",
25
+ env
26
+ });
27
+ return result.exitCode;
28
+ }
29
+ export { runPsql };
30
+ //# sourceMappingURL=psql.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["runPsql","options","arguments","length","connectionString","host","port","database","user","password","query","env","process","url","URL","PGHOST","hostname","PGPORT","PGDATABASE","pathname","slice","PGUSER","username","PGPASSWORD","toString","args","push","console","info","result","Bun","spawnSync","stdin","stdout"],"sources":["../../../src/scripts/psql.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,QAAA,EAAQ;EACtB,IAAAC,OAAQ,GAAAC,SAAA,CAAAC,MAAkB,GAAM,KAAMD,SAAA,CAAU,OAAM,SAAUA,SAAM,CAAI;IAEpE;MAAAE,gBAA8B;MAAAC,IAAA;MAAAC,IAAA;MAAAC,QAAA;MAAAC,IAAA;MAAAC,QAAA;MAAAC;IAAA,IAAAT,OAAA;IAAAU,GAAA;MAClC,GAAGC,OAAA,CAAQD;IACb;EAEA,IAAIP,gBAAA,EAAkB;IAEpB,IAAAS,GAAM,OAAMC,GAAI,CAAAV,gBAAI;IACpBO,GAAA,CAAII,MAAA,GAASF,GAAA,CAAIG,QAAA,EACjBL,GAAA,CAAIM,MAAA,GAASJ,GAAA,CAAIP,IAAA,IAAQ,QACzBK,GAAA,CAAIO,UAAA,GAAaL,GAAA,CAAIM,QAAA,CAASC,KAAA,CAAM,CAAC,GACrCT,GAAA,CAAIU,MAAA,GAASR,GAAA,CAAIS,QAAA,EACbT,GAAA,CAAIJ,QAAA,KACNE,GAAA,CAAIY,UAAA,GAAaV,GAAA,CAAIJ,QAAA;EAEzB,OACMJ,IAAA,KAAMM,GAAA,CAAII,MAAA,GAASV,IAAA,GACnBC,IAAA,KAAMK,GAAA,CAAIM,MAAA,GAASX,IAAA,CAAKkB,QAAA,CAAS,IACjCjB,QAAA,KAAUI,GAAA,CAAIO,UAAA,GAAaX,QAAA,GAC3BC,IAAA,KAAMG,GAAA,CAAIU,MAAA,GAASb,IAAA,GACnBC,QAAA,KAAUE,GAAA,CAAIY,UAAA,GAAad,QAAA;EAGjC,IAAAgB,IAAM,KAAiB;EACvBf,KAAA,IAAIe,IAAA,CAAAC,IACF,KAAK,EAAAhB,KAAK,GAAMiB,OAGlB,CAAAC,IAAA,2BAAajB,GAAA,CAAAI,MAA0B,IAAIJ,GAAM,CAAAO,UAAQ;EAET,IAC9CW,MAAO,GAAAC,GAAA,CAAAC,SAAA,EACP,QACA,GAAAN,IAAA,CAAQ,EACR;IACDO,KAEa;IAChBC,MAAA","ignoreList":[]}
@@ -0,0 +1,19 @@
1
+ import { ellipsis } from "@take-out/helpers";
2
+ const createSql = (pool) => (strings, ...values) => {
3
+ const text = strings.reduce((result, str, i) => result + str + (i < values.length ? `$${i + 1}` : ""), "");
4
+ return console.info(`sql: ${ellipsis(text, 80)}`), pool.query(text.trim(), values);
5
+ };
6
+ let defaultPool = null;
7
+ const setDefaultPool = (pool) => {
8
+ defaultPool = pool;
9
+ }, sql = (strings, ...values) => {
10
+ if (!defaultPool)
11
+ throw new Error("No default pool set. Call setDefaultPool() first or use createSql()");
12
+ return createSql(defaultPool)(strings, ...values);
13
+ };
14
+ export {
15
+ createSql,
16
+ setDefaultPool,
17
+ sql
18
+ };
19
+ //# sourceMappingURL=sql.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../src/sql.ts"],
4
+ "mappings": "AACA,SAAS,gBAAgB;AAOlB,MAAM,YAAY,CAAC,SACjB,CAAC,YAAkC,WAA6C;AACrF,QAAM,OAAO,QAAQ,OAAO,CAAC,QAAQ,KAAK,MACjC,SAAS,OAAO,IAAI,OAAO,SAAS,IAAI,IAAI,CAAC,KAAK,KACxD,EAAE;AAEL,iBAAQ,KAAK,QAAQ,SAAS,MAAM,EAAE,CAAC,EAAE,GAElC,KAAK,MAAM,KAAK,KAAK,GAAG,MAAM;AACvC;AAIF,IAAI,cAA2B;AAExB,MAAM,iBAAiB,CAAC,SAAe;AAC5C,gBAAc;AAChB,GAEa,MAAM,CACjB,YACG,WAC2B;AAC9B,MAAI,CAAC;AACH,UAAM,IAAI,MAAM,qEAAqE;AAEvF,SAAO,UAAU,WAAW,EAAE,SAAS,GAAG,MAAM;AAClD;",
5
+ "names": []
6
+ }
@@ -0,0 +1,15 @@
1
+ import { ellipsis } from "@take-out/helpers";
2
+ const createSql = pool => (strings, ...values) => {
3
+ const text = strings.reduce((result, str, i) => result + str + (i < values.length ? `$${i + 1}` : ""), "");
4
+ return console.info(`sql: ${ellipsis(text, 80)}`), pool.query(text.trim(), values);
5
+ };
6
+ let defaultPool = null;
7
+ const setDefaultPool = pool => {
8
+ defaultPool = pool;
9
+ },
10
+ sql = (strings, ...values) => {
11
+ if (!defaultPool) throw new Error("No default pool set. Call setDefaultPool() first or use createSql()");
12
+ return createSql(defaultPool)(strings, ...values);
13
+ };
14
+ export { createSql, setDefaultPool, sql };
15
+ //# sourceMappingURL=sql.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["ellipsis","createSql","pool","strings","values","text","reduce","result","str","i","length","console","info","query","trim","defaultPool","setDefaultPool","sql","Error"],"sources":["../../src/sql.ts"],"sourcesContent":[null],"mappings":"AACA,SAASA,QAAA,QAAgB;AAOlB,MAAMC,SAAA,GAAaC,IAAA,IACjB,CAACC,OAAA,KAAkCC,MAAA,KAA6C;EACrF,MAAMC,IAAA,GAAOF,OAAA,CAAQG,MAAA,CAAO,CAACC,MAAA,EAAQC,GAAA,EAAKC,CAAA,KACjCF,MAAA,GAASC,GAAA,IAAOC,CAAA,GAAIL,MAAA,CAAOM,MAAA,GAAS,IAAID,CAAA,GAAI,CAAC,KAAK,KACxD,EAAE;EAEL,OAAAE,OAAA,CAAQC,IAAA,CAAK,QAAQZ,QAAA,CAASK,IAAA,EAAM,EAAE,CAAC,EAAE,GAElCH,IAAA,CAAKW,KAAA,CAAMR,IAAA,CAAKS,IAAA,CAAK,GAAGV,MAAM;AACvC;AAIF,IAAIW,WAAA,GAA2B;AAExB,MAAMC,cAAA,GAAkBd,IAAA,IAAe;IAC5Ca,WAAA,GAAcb,IAAA;EAChB;EAEae,GAAA,GAAMA,CACjBd,OAAA,KACGC,MAAA,KAC2B;IAC9B,IAAI,CAACW,WAAA,EACH,MAAM,IAAIG,KAAA,CAAM,qEAAqE;IAEvF,OAAOjB,SAAA,CAAUc,WAAW,EAAEZ,OAAA,EAAS,GAAGC,MAAM;EAClD","ignoreList":[]}
@@ -0,0 +1,21 @@
1
+ import { ellipsis } from "@take-out/helpers";
2
+ var createSql = function (pool) {
3
+ return function (strings) {
4
+ for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) values[_key - 1] = arguments[_key];
5
+ var text = strings.reduce(function (result, str, i) {
6
+ return result + str + (i < values.length ? `$${i + 1}` : "");
7
+ }, "");
8
+ return console.info(`sql: ${ellipsis(text, 80)}`), pool.query(text.trim(), values);
9
+ };
10
+ },
11
+ defaultPool = null,
12
+ setDefaultPool = function (pool) {
13
+ defaultPool = pool;
14
+ },
15
+ sql = function (strings) {
16
+ for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) values[_key - 1] = arguments[_key];
17
+ if (!defaultPool) throw new Error("No default pool set. Call setDefaultPool() first or use createSql()");
18
+ return createSql(defaultPool)(strings, ...values);
19
+ };
20
+ export { createSql, setDefaultPool, sql };
21
+ //# sourceMappingURL=sql.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["ellipsis","createSql","pool","strings","_len","arguments","length","values","Array","_key","text","reduce","result","str","i","console","info","query","trim","defaultPool","setDefaultPool","sql"],"sources":["../../src/sql.ts"],"sourcesContent":[null],"mappings":"AACA,SAASA,QAAA,QAAgB;AAOlB,IAAAC,SAAM,YAAAA,CAAaC,IAChB;IACN,OAAM,UAAOC,OAAQ;MAIrB,SAAAC,IAAQ,GAAAC,SAAK,CAAQC,MAAA,EAAAC,MAAS,GAAQ,IAAGC,KAElC,CAAAJ,IAAK,GAAM,IAAAA,IAAK,GAAK,IAAG,IAAMK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA,IACvCF,MAAA,CAAAE,IAAA,QAAAJ,SAAA,CAAAI,IAAA;MAIE,IAAAC,IAAA,GAAAP,OAA2B,CAAAQ,MAAA,WAAAC,MAAA,EAAAC,GAAA,EAAAC,CAAA;QAElB,OAAAF,MAAA,GAAAC,GAAkB,IAAAC,CAAA,GAAeP,MAAA,CAAAD,MAAA,OAAAQ,CAAA;MAC5C;MAGW,OACXC,OAAA,CAAAC,IACG,SAAAhB,QAC2B,CAAAU,IAAA,UAAAR,IAAA,CAAAe,KAAA,CAAAP,IAAA,CAAAQ,IAAA,IAAAX,MAAA;IAC9B;EACE;EAAAY,WAAU,OAAM;EAAAC,cAAA,YAAAA,CAAAlB,IAAA;IAElBiB,WAAO,GAAAjB,IAAU;EACnB;EAAAmB,GAAA,YAAAA,CAAAlB,OAAA","ignoreList":[]}