drizzle-orm 0.44.1 → 0.44.2-512acc4
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.
- package/aws-data-api/pg/driver.cjs +14 -6
- package/aws-data-api/pg/driver.cjs.map +1 -1
- package/aws-data-api/pg/driver.d.cts +4 -3
- package/aws-data-api/pg/driver.d.ts +4 -3
- package/aws-data-api/pg/driver.js +14 -6
- package/aws-data-api/pg/driver.js.map +1 -1
- package/aws-data-api/pg/session.cjs +26 -9
- package/aws-data-api/pg/session.cjs.map +1 -1
- package/aws-data-api/pg/session.d.cts +5 -4
- package/aws-data-api/pg/session.d.ts +5 -4
- package/aws-data-api/pg/session.js +26 -9
- package/aws-data-api/pg/session.js.map +1 -1
- package/better-sqlite3/driver.cjs.map +1 -1
- package/better-sqlite3/driver.d.cts +4 -3
- package/better-sqlite3/driver.d.ts +4 -3
- package/better-sqlite3/driver.js.map +1 -1
- package/better-sqlite3/session.cjs +4 -4
- package/better-sqlite3/session.cjs.map +1 -1
- package/better-sqlite3/session.d.cts +4 -4
- package/better-sqlite3/session.d.ts +4 -4
- package/better-sqlite3/session.js +4 -4
- package/better-sqlite3/session.js.map +1 -1
- package/bun-sql/driver.cjs +3 -2
- package/bun-sql/driver.cjs.map +1 -1
- package/bun-sql/driver.d.cts +4 -3
- package/bun-sql/driver.d.ts +4 -3
- package/bun-sql/driver.js +3 -2
- package/bun-sql/driver.js.map +1 -1
- package/bun-sql/session.cjs +20 -11
- package/bun-sql/session.cjs.map +1 -1
- package/bun-sql/session.d.cts +6 -5
- package/bun-sql/session.d.ts +6 -5
- package/bun-sql/session.js +20 -11
- package/bun-sql/session.js.map +1 -1
- package/bun-sqlite/driver.cjs.map +1 -1
- package/bun-sqlite/driver.d.cts +4 -3
- package/bun-sqlite/driver.d.ts +4 -3
- package/bun-sqlite/driver.js.map +1 -1
- package/bun-sqlite/session.cjs +4 -4
- package/bun-sqlite/session.cjs.map +1 -1
- package/bun-sqlite/session.d.cts +4 -4
- package/bun-sqlite/session.d.ts +4 -4
- package/bun-sqlite/session.js +4 -4
- package/bun-sqlite/session.js.map +1 -1
- package/column-builder.cjs.map +1 -1
- package/column-builder.d.cts +7 -2
- package/column-builder.d.ts +7 -2
- package/column-builder.js.map +1 -1
- package/column.cjs +2 -0
- package/column.cjs.map +1 -1
- package/column.d.cts +6 -0
- package/column.d.ts +6 -0
- package/column.js +2 -0
- package/column.js.map +1 -1
- package/d1/driver.cjs +9 -2
- package/d1/driver.cjs.map +1 -1
- package/d1/driver.d.cts +2 -1
- package/d1/driver.d.ts +2 -1
- package/d1/driver.js +9 -2
- package/d1/driver.js.map +1 -1
- package/d1/session.cjs +20 -11
- package/d1/session.cjs.map +1 -1
- package/d1/session.d.cts +8 -7
- package/d1/session.d.ts +8 -7
- package/d1/session.js +20 -11
- package/d1/session.js.map +1 -1
- package/durable-sqlite/driver.cjs.map +1 -1
- package/durable-sqlite/driver.d.cts +2 -1
- package/durable-sqlite/driver.d.ts +2 -1
- package/durable-sqlite/driver.js.map +1 -1
- package/durable-sqlite/session.cjs +4 -4
- package/durable-sqlite/session.cjs.map +1 -1
- package/durable-sqlite/session.d.cts +4 -4
- package/durable-sqlite/session.d.ts +4 -4
- package/durable-sqlite/session.js +4 -4
- package/durable-sqlite/session.js.map +1 -1
- package/expo-sqlite/driver.cjs.map +1 -1
- package/expo-sqlite/driver.d.cts +2 -1
- package/expo-sqlite/driver.d.ts +2 -1
- package/expo-sqlite/driver.js.map +1 -1
- package/expo-sqlite/session.cjs +4 -4
- package/expo-sqlite/session.cjs.map +1 -1
- package/expo-sqlite/session.d.cts +4 -4
- package/expo-sqlite/session.d.ts +4 -4
- package/expo-sqlite/session.js +4 -4
- package/expo-sqlite/session.js.map +1 -1
- package/extension-core/gel/index.cjs +33 -0
- package/extension-core/gel/index.cjs.map +1 -0
- package/extension-core/gel/index.d.cts +67 -0
- package/extension-core/gel/index.d.ts +67 -0
- package/extension-core/gel/index.js +9 -0
- package/extension-core/gel/index.js.map +1 -0
- package/extension-core/index.cjs +42 -0
- package/extension-core/index.cjs.map +1 -0
- package/extension-core/index.d.cts +9 -0
- package/extension-core/index.d.ts +9 -0
- package/extension-core/index.js +15 -0
- package/extension-core/index.js.map +1 -0
- package/extension-core/mysql/index.cjs +33 -0
- package/extension-core/mysql/index.cjs.map +1 -0
- package/extension-core/mysql/index.d.cts +69 -0
- package/extension-core/mysql/index.d.ts +69 -0
- package/extension-core/mysql/index.js +9 -0
- package/extension-core/mysql/index.js.map +1 -0
- package/extension-core/pg/index.cjs +33 -0
- package/extension-core/pg/index.cjs.map +1 -0
- package/extension-core/pg/index.d.cts +67 -0
- package/extension-core/pg/index.d.ts +67 -0
- package/extension-core/pg/index.js +9 -0
- package/extension-core/pg/index.js.map +1 -0
- package/extension-core/singlestore/index.cjs +33 -0
- package/extension-core/singlestore/index.cjs.map +1 -0
- package/extension-core/singlestore/index.d.cts +67 -0
- package/extension-core/singlestore/index.d.ts +67 -0
- package/extension-core/singlestore/index.js +9 -0
- package/extension-core/singlestore/index.js.map +1 -0
- package/extension-core/sqlite/index.cjs +33 -0
- package/extension-core/sqlite/index.cjs.map +1 -0
- package/extension-core/sqlite/index.d.cts +68 -0
- package/extension-core/sqlite/index.d.ts +68 -0
- package/extension-core/sqlite/index.js +9 -0
- package/extension-core/sqlite/index.js.map +1 -0
- package/extensions/hook/gel/index.cjs +47 -0
- package/extensions/hook/gel/index.cjs.map +1 -0
- package/extensions/hook/gel/index.d.cts +11 -0
- package/extensions/hook/gel/index.d.ts +11 -0
- package/extensions/hook/gel/index.js +22 -0
- package/extensions/hook/gel/index.js.map +1 -0
- package/extensions/hook/mysql/index.cjs +47 -0
- package/extensions/hook/mysql/index.cjs.map +1 -0
- package/extensions/hook/mysql/index.d.cts +11 -0
- package/extensions/hook/mysql/index.d.ts +11 -0
- package/extensions/hook/mysql/index.js +22 -0
- package/extensions/hook/mysql/index.js.map +1 -0
- package/extensions/hook/pg/index.cjs +47 -0
- package/extensions/hook/pg/index.cjs.map +1 -0
- package/extensions/hook/pg/index.d.cts +11 -0
- package/extensions/hook/pg/index.d.ts +11 -0
- package/extensions/hook/pg/index.js +22 -0
- package/extensions/hook/pg/index.js.map +1 -0
- package/extensions/hook/singlestore/index.cjs +47 -0
- package/extensions/hook/singlestore/index.cjs.map +1 -0
- package/extensions/hook/singlestore/index.d.cts +11 -0
- package/extensions/hook/singlestore/index.d.ts +11 -0
- package/extensions/hook/singlestore/index.js +22 -0
- package/extensions/hook/singlestore/index.js.map +1 -0
- package/extensions/hook/sqlite/index.cjs +47 -0
- package/extensions/hook/sqlite/index.cjs.map +1 -0
- package/extensions/hook/sqlite/index.d.cts +11 -0
- package/extensions/hook/sqlite/index.d.ts +11 -0
- package/extensions/hook/sqlite/index.js +22 -0
- package/extensions/hook/sqlite/index.js.map +1 -0
- package/extensions/s3-file/common.cjs +313 -0
- package/extensions/s3-file/common.cjs.map +1 -0
- package/extensions/s3-file/common.d.cts +88 -0
- package/extensions/s3-file/common.d.ts +88 -0
- package/extensions/s3-file/common.js +280 -0
- package/extensions/s3-file/common.js.map +1 -0
- package/extensions/s3-file/gel/column.cjs +113 -0
- package/extensions/s3-file/gel/column.cjs.map +1 -0
- package/extensions/s3-file/gel/column.d.cts +105 -0
- package/extensions/s3-file/gel/column.d.ts +105 -0
- package/extensions/s3-file/gel/column.js +92 -0
- package/extensions/s3-file/gel/column.js.map +1 -0
- package/extensions/s3-file/gel/extension.cjs +262 -0
- package/extensions/s3-file/gel/extension.cjs.map +1 -0
- package/extensions/s3-file/gel/extension.d.cts +18 -0
- package/extensions/s3-file/gel/extension.d.ts +18 -0
- package/extensions/s3-file/gel/extension.js +248 -0
- package/extensions/s3-file/gel/extension.js.map +1 -0
- package/extensions/s3-file/gel/index.cjs +25 -0
- package/extensions/s3-file/gel/index.cjs.map +1 -0
- package/extensions/s3-file/gel/index.d.cts +2 -0
- package/extensions/s3-file/gel/index.d.ts +2 -0
- package/extensions/s3-file/gel/index.js +3 -0
- package/extensions/s3-file/gel/index.js.map +1 -0
- package/extensions/s3-file/index.cjs +23 -0
- package/extensions/s3-file/index.cjs.map +1 -0
- package/extensions/s3-file/index.d.cts +1 -0
- package/extensions/s3-file/index.d.ts +1 -0
- package/extensions/s3-file/index.js +2 -0
- package/extensions/s3-file/index.js.map +1 -0
- package/extensions/s3-file/mysql/column.cjs +110 -0
- package/extensions/s3-file/mysql/column.cjs.map +1 -0
- package/extensions/s3-file/mysql/column.d.cts +63 -0
- package/extensions/s3-file/mysql/column.d.ts +63 -0
- package/extensions/s3-file/mysql/column.js +86 -0
- package/extensions/s3-file/mysql/column.js.map +1 -0
- package/extensions/s3-file/mysql/extension.cjs +242 -0
- package/extensions/s3-file/mysql/extension.cjs.map +1 -0
- package/extensions/s3-file/mysql/extension.d.cts +18 -0
- package/extensions/s3-file/mysql/extension.d.ts +18 -0
- package/extensions/s3-file/mysql/extension.js +228 -0
- package/extensions/s3-file/mysql/extension.js.map +1 -0
- package/extensions/s3-file/mysql/index.cjs +25 -0
- package/extensions/s3-file/mysql/index.cjs.map +1 -0
- package/extensions/s3-file/mysql/index.d.cts +2 -0
- package/extensions/s3-file/mysql/index.d.ts +2 -0
- package/extensions/s3-file/mysql/index.js +3 -0
- package/extensions/s3-file/mysql/index.js.map +1 -0
- package/extensions/s3-file/pg/column.cjs +113 -0
- package/extensions/s3-file/pg/column.cjs.map +1 -0
- package/extensions/s3-file/pg/column.d.cts +105 -0
- package/extensions/s3-file/pg/column.d.ts +105 -0
- package/extensions/s3-file/pg/column.js +92 -0
- package/extensions/s3-file/pg/column.js.map +1 -0
- package/extensions/s3-file/pg/extension.cjs +264 -0
- package/extensions/s3-file/pg/extension.cjs.map +1 -0
- package/extensions/s3-file/pg/extension.d.cts +18 -0
- package/extensions/s3-file/pg/extension.d.ts +18 -0
- package/extensions/s3-file/pg/extension.js +250 -0
- package/extensions/s3-file/pg/extension.js.map +1 -0
- package/extensions/s3-file/pg/index.cjs +25 -0
- package/extensions/s3-file/pg/index.cjs.map +1 -0
- package/extensions/s3-file/pg/index.d.cts +2 -0
- package/extensions/s3-file/pg/index.d.ts +2 -0
- package/extensions/s3-file/pg/index.js +3 -0
- package/extensions/s3-file/pg/index.js.map +1 -0
- package/extensions/s3-file/singlestore/column.cjs +110 -0
- package/extensions/s3-file/singlestore/column.cjs.map +1 -0
- package/extensions/s3-file/singlestore/column.d.cts +63 -0
- package/extensions/s3-file/singlestore/column.d.ts +63 -0
- package/extensions/s3-file/singlestore/column.js +86 -0
- package/extensions/s3-file/singlestore/column.js.map +1 -0
- package/extensions/s3-file/singlestore/extension.cjs +239 -0
- package/extensions/s3-file/singlestore/extension.cjs.map +1 -0
- package/extensions/s3-file/singlestore/extension.d.cts +18 -0
- package/extensions/s3-file/singlestore/extension.d.ts +18 -0
- package/extensions/s3-file/singlestore/extension.js +225 -0
- package/extensions/s3-file/singlestore/extension.js.map +1 -0
- package/extensions/s3-file/singlestore/index.cjs +25 -0
- package/extensions/s3-file/singlestore/index.cjs.map +1 -0
- package/extensions/s3-file/singlestore/index.d.cts +2 -0
- package/extensions/s3-file/singlestore/index.d.ts +2 -0
- package/extensions/s3-file/singlestore/index.js +3 -0
- package/extensions/s3-file/singlestore/index.js.map +1 -0
- package/extensions/s3-file/sqlite/column.cjs +110 -0
- package/extensions/s3-file/sqlite/column.cjs.map +1 -0
- package/extensions/s3-file/sqlite/column.d.cts +63 -0
- package/extensions/s3-file/sqlite/column.d.ts +63 -0
- package/extensions/s3-file/sqlite/column.js +86 -0
- package/extensions/s3-file/sqlite/column.js.map +1 -0
- package/extensions/s3-file/sqlite/extension.cjs +242 -0
- package/extensions/s3-file/sqlite/extension.cjs.map +1 -0
- package/extensions/s3-file/sqlite/extension.d.cts +18 -0
- package/extensions/s3-file/sqlite/extension.d.ts +18 -0
- package/extensions/s3-file/sqlite/extension.js +228 -0
- package/extensions/s3-file/sqlite/extension.js.map +1 -0
- package/extensions/s3-file/sqlite/index.cjs +25 -0
- package/extensions/s3-file/sqlite/index.cjs.map +1 -0
- package/extensions/s3-file/sqlite/index.d.cts +2 -0
- package/extensions/s3-file/sqlite/index.d.ts +2 -0
- package/extensions/s3-file/sqlite/index.js +3 -0
- package/extensions/s3-file/sqlite/index.js.map +1 -0
- package/gel/driver.cjs +6 -4
- package/gel/driver.cjs.map +1 -1
- package/gel/driver.d.cts +6 -4
- package/gel/driver.d.ts +6 -4
- package/gel/driver.js +6 -4
- package/gel/driver.js.map +1 -1
- package/gel/session.cjs +12 -9
- package/gel/session.cjs.map +1 -1
- package/gel/session.d.cts +5 -4
- package/gel/session.d.ts +5 -4
- package/gel/session.js +12 -9
- package/gel/session.js.map +1 -1
- package/gel-core/columns/common.cjs +8 -0
- package/gel-core/columns/common.cjs.map +1 -1
- package/gel-core/columns/common.d.cts +2 -0
- package/gel-core/columns/common.d.ts +2 -0
- package/gel-core/columns/common.js +8 -0
- package/gel-core/columns/common.js.map +1 -1
- package/gel-core/db.cjs +5 -3
- package/gel-core/db.cjs.map +1 -1
- package/gel-core/db.d.cts +3 -1
- package/gel-core/db.d.ts +3 -1
- package/gel-core/db.js +5 -3
- package/gel-core/db.js.map +1 -1
- package/gel-core/dialect.cjs +24 -19
- package/gel-core/dialect.cjs.map +1 -1
- package/gel-core/dialect.d.cts +7 -6
- package/gel-core/dialect.d.ts +7 -6
- package/gel-core/dialect.js +25 -20
- package/gel-core/dialect.js.map +1 -1
- package/gel-core/query-builders/delete.cjs +19 -5
- package/gel-core/query-builders/delete.cjs.map +1 -1
- package/gel-core/query-builders/delete.js +19 -5
- package/gel-core/query-builders/delete.js.map +1 -1
- package/gel-core/query-builders/insert.cjs +44 -9
- package/gel-core/query-builders/insert.cjs.map +1 -1
- package/gel-core/query-builders/insert.js +46 -11
- package/gel-core/query-builders/insert.js.map +1 -1
- package/gel-core/query-builders/query.cjs +15 -2
- package/gel-core/query-builders/query.cjs.map +1 -1
- package/gel-core/query-builders/query.js +15 -2
- package/gel-core/query-builders/query.js.map +1 -1
- package/gel-core/query-builders/select.cjs +21 -5
- package/gel-core/query-builders/select.cjs.map +1 -1
- package/gel-core/query-builders/select.d.cts +9 -9
- package/gel-core/query-builders/select.d.ts +9 -9
- package/gel-core/query-builders/select.js +21 -5
- package/gel-core/query-builders/select.js.map +1 -1
- package/gel-core/query-builders/select.types.cjs.map +1 -1
- package/gel-core/query-builders/select.types.d.cts +2 -1
- package/gel-core/query-builders/select.types.d.ts +2 -1
- package/gel-core/query-builders/update.cjs +20 -6
- package/gel-core/query-builders/update.cjs.map +1 -1
- package/gel-core/query-builders/update.js +20 -6
- package/gel-core/query-builders/update.js.map +1 -1
- package/gel-core/session.cjs +47 -4
- package/gel-core/session.cjs.map +1 -1
- package/gel-core/session.d.cts +11 -5
- package/gel-core/session.d.ts +11 -5
- package/gel-core/session.js +47 -4
- package/gel-core/session.js.map +1 -1
- package/libsql/driver-core.cjs +3 -2
- package/libsql/driver-core.cjs.map +1 -1
- package/libsql/driver-core.js +3 -2
- package/libsql/driver-core.js.map +1 -1
- package/libsql/driver.cjs +4 -1
- package/libsql/driver.cjs.map +1 -1
- package/libsql/driver.d.cts +4 -3
- package/libsql/driver.d.ts +4 -3
- package/libsql/driver.js +4 -1
- package/libsql/driver.js.map +1 -1
- package/libsql/http/index.cjs +4 -1
- package/libsql/http/index.cjs.map +1 -1
- package/libsql/http/index.d.cts +4 -3
- package/libsql/http/index.d.ts +4 -3
- package/libsql/http/index.js +4 -1
- package/libsql/http/index.js.map +1 -1
- package/libsql/node/index.cjs +4 -1
- package/libsql/node/index.cjs.map +1 -1
- package/libsql/node/index.d.cts +4 -3
- package/libsql/node/index.d.ts +4 -3
- package/libsql/node/index.js +4 -1
- package/libsql/node/index.js.map +1 -1
- package/libsql/session.cjs +29 -12
- package/libsql/session.cjs.map +1 -1
- package/libsql/session.d.cts +8 -7
- package/libsql/session.d.ts +8 -7
- package/libsql/session.js +29 -12
- package/libsql/session.js.map +1 -1
- package/libsql/sqlite3/index.cjs +4 -1
- package/libsql/sqlite3/index.cjs.map +1 -1
- package/libsql/sqlite3/index.d.cts +4 -3
- package/libsql/sqlite3/index.d.ts +4 -3
- package/libsql/sqlite3/index.js +4 -1
- package/libsql/sqlite3/index.js.map +1 -1
- package/libsql/wasm/index.cjs +4 -1
- package/libsql/wasm/index.cjs.map +1 -1
- package/libsql/wasm/index.d.cts +4 -3
- package/libsql/wasm/index.d.ts +4 -3
- package/libsql/wasm/index.js +4 -1
- package/libsql/wasm/index.js.map +1 -1
- package/libsql/web/index.cjs +4 -1
- package/libsql/web/index.cjs.map +1 -1
- package/libsql/web/index.d.cts +4 -3
- package/libsql/web/index.d.ts +4 -3
- package/libsql/web/index.js +4 -1
- package/libsql/web/index.js.map +1 -1
- package/libsql/ws/index.cjs +4 -1
- package/libsql/ws/index.cjs.map +1 -1
- package/libsql/ws/index.d.cts +4 -3
- package/libsql/ws/index.d.ts +4 -3
- package/libsql/ws/index.js +4 -1
- package/libsql/ws/index.js.map +1 -1
- package/mysql-core/db.cjs +5 -3
- package/mysql-core/db.cjs.map +1 -1
- package/mysql-core/db.d.cts +3 -1
- package/mysql-core/db.d.ts +3 -1
- package/mysql-core/db.js +5 -3
- package/mysql-core/db.js.map +1 -1
- package/mysql-core/dialect.cjs +29 -23
- package/mysql-core/dialect.cjs.map +1 -1
- package/mysql-core/dialect.d.cts +8 -7
- package/mysql-core/dialect.d.ts +8 -7
- package/mysql-core/dialect.js +30 -24
- package/mysql-core/dialect.js.map +1 -1
- package/mysql-core/query-builders/delete.cjs +8 -1
- package/mysql-core/query-builders/delete.cjs.map +1 -1
- package/mysql-core/query-builders/delete.js +8 -1
- package/mysql-core/query-builders/delete.js.map +1 -1
- package/mysql-core/query-builders/insert.cjs +30 -6
- package/mysql-core/query-builders/insert.cjs.map +1 -1
- package/mysql-core/query-builders/insert.js +32 -8
- package/mysql-core/query-builders/insert.js.map +1 -1
- package/mysql-core/query-builders/query.cjs +19 -3
- package/mysql-core/query-builders/query.cjs.map +1 -1
- package/mysql-core/query-builders/query.js +19 -3
- package/mysql-core/query-builders/query.js.map +1 -1
- package/mysql-core/query-builders/select.cjs +23 -6
- package/mysql-core/query-builders/select.cjs.map +1 -1
- package/mysql-core/query-builders/select.d.cts +8 -8
- package/mysql-core/query-builders/select.d.ts +8 -8
- package/mysql-core/query-builders/select.js +23 -6
- package/mysql-core/query-builders/select.js.map +1 -1
- package/mysql-core/query-builders/select.types.cjs.map +1 -1
- package/mysql-core/query-builders/select.types.d.cts +2 -1
- package/mysql-core/query-builders/select.types.d.ts +2 -1
- package/mysql-core/query-builders/update.cjs +15 -3
- package/mysql-core/query-builders/update.cjs.map +1 -1
- package/mysql-core/query-builders/update.js +15 -3
- package/mysql-core/query-builders/update.js.map +1 -1
- package/mysql-core/session.cjs +43 -4
- package/mysql-core/session.cjs.map +1 -1
- package/mysql-core/session.d.cts +14 -7
- package/mysql-core/session.d.ts +14 -7
- package/mysql-core/session.js +43 -4
- package/mysql-core/session.js.map +1 -1
- package/mysql-proxy/driver.cjs +3 -2
- package/mysql-proxy/driver.cjs.map +1 -1
- package/mysql-proxy/driver.d.cts +2 -1
- package/mysql-proxy/driver.d.ts +2 -1
- package/mysql-proxy/driver.js +3 -2
- package/mysql-proxy/driver.js.map +1 -1
- package/mysql-proxy/session.cjs +8 -8
- package/mysql-proxy/session.cjs.map +1 -1
- package/mysql-proxy/session.d.cts +5 -6
- package/mysql-proxy/session.d.ts +5 -6
- package/mysql-proxy/session.js +8 -8
- package/mysql-proxy/session.js.map +1 -1
- package/mysql2/driver.cjs +11 -4
- package/mysql2/driver.cjs.map +1 -1
- package/mysql2/driver.d.cts +4 -2
- package/mysql2/driver.d.ts +4 -2
- package/mysql2/driver.js +11 -4
- package/mysql2/driver.js.map +1 -1
- package/mysql2/session.cjs +14 -10
- package/mysql2/session.cjs.map +1 -1
- package/mysql2/session.d.cts +5 -5
- package/mysql2/session.d.ts +5 -5
- package/mysql2/session.js +14 -10
- package/mysql2/session.js.map +1 -1
- package/neon-http/driver.cjs +5 -3
- package/neon-http/driver.cjs.map +1 -1
- package/neon-http/driver.d.cts +6 -4
- package/neon-http/driver.d.ts +6 -4
- package/neon-http/driver.js +5 -3
- package/neon-http/driver.js.map +1 -1
- package/neon-http/session.cjs +8 -6
- package/neon-http/session.cjs.map +1 -1
- package/neon-http/session.d.cts +5 -4
- package/neon-http/session.d.ts +5 -4
- package/neon-http/session.js +8 -6
- package/neon-http/session.js.map +1 -1
- package/neon-serverless/driver.cjs +6 -4
- package/neon-serverless/driver.cjs.map +1 -1
- package/neon-serverless/driver.d.cts +6 -4
- package/neon-serverless/driver.d.ts +6 -4
- package/neon-serverless/driver.js +6 -4
- package/neon-serverless/driver.js.map +1 -1
- package/neon-serverless/session.cjs +23 -9
- package/neon-serverless/session.cjs.map +1 -1
- package/neon-serverless/session.d.cts +5 -4
- package/neon-serverless/session.d.ts +5 -4
- package/neon-serverless/session.js +23 -9
- package/neon-serverless/session.js.map +1 -1
- package/node-postgres/driver.cjs +6 -4
- package/node-postgres/driver.cjs.map +1 -1
- package/node-postgres/driver.d.cts +6 -4
- package/node-postgres/driver.d.ts +6 -4
- package/node-postgres/driver.js +6 -4
- package/node-postgres/driver.js.map +1 -1
- package/node-postgres/session.cjs +18 -9
- package/node-postgres/session.cjs.map +1 -1
- package/node-postgres/session.d.cts +5 -4
- package/node-postgres/session.d.ts +5 -4
- package/node-postgres/session.js +18 -9
- package/node-postgres/session.js.map +1 -1
- package/op-sqlite/driver.cjs +3 -2
- package/op-sqlite/driver.cjs.map +1 -1
- package/op-sqlite/driver.d.cts +2 -1
- package/op-sqlite/driver.d.ts +2 -1
- package/op-sqlite/driver.js +3 -2
- package/op-sqlite/driver.js.map +1 -1
- package/op-sqlite/session.cjs +20 -11
- package/op-sqlite/session.cjs.map +1 -1
- package/op-sqlite/session.d.cts +8 -7
- package/op-sqlite/session.d.ts +8 -7
- package/op-sqlite/session.js +20 -11
- package/op-sqlite/session.js.map +1 -1
- package/package.json +351 -5
- package/pg-core/columns/common.cjs +2 -0
- package/pg-core/columns/common.cjs.map +1 -1
- package/pg-core/columns/common.js +2 -0
- package/pg-core/columns/common.js.map +1 -1
- package/pg-core/db.cjs +5 -3
- package/pg-core/db.cjs.map +1 -1
- package/pg-core/db.d.cts +3 -1
- package/pg-core/db.d.ts +3 -1
- package/pg-core/db.js +5 -3
- package/pg-core/db.js.map +1 -1
- package/pg-core/dialect.cjs +25 -19
- package/pg-core/dialect.cjs.map +1 -1
- package/pg-core/dialect.d.cts +7 -6
- package/pg-core/dialect.d.ts +7 -6
- package/pg-core/dialect.js +26 -20
- package/pg-core/dialect.js.map +1 -1
- package/pg-core/query-builders/delete.cjs +19 -5
- package/pg-core/query-builders/delete.cjs.map +1 -1
- package/pg-core/query-builders/delete.js +19 -5
- package/pg-core/query-builders/delete.js.map +1 -1
- package/pg-core/query-builders/insert.cjs +49 -9
- package/pg-core/query-builders/insert.cjs.map +1 -1
- package/pg-core/query-builders/insert.js +51 -11
- package/pg-core/query-builders/insert.js.map +1 -1
- package/pg-core/query-builders/query.cjs +15 -2
- package/pg-core/query-builders/query.cjs.map +1 -1
- package/pg-core/query-builders/query.js +15 -2
- package/pg-core/query-builders/query.js.map +1 -1
- package/pg-core/query-builders/select.cjs +23 -7
- package/pg-core/query-builders/select.cjs.map +1 -1
- package/pg-core/query-builders/select.d.cts +9 -9
- package/pg-core/query-builders/select.d.ts +9 -9
- package/pg-core/query-builders/select.js +23 -7
- package/pg-core/query-builders/select.js.map +1 -1
- package/pg-core/query-builders/select.types.cjs.map +1 -1
- package/pg-core/query-builders/select.types.d.cts +2 -1
- package/pg-core/query-builders/select.types.d.ts +2 -1
- package/pg-core/query-builders/update.cjs +20 -6
- package/pg-core/query-builders/update.cjs.map +1 -1
- package/pg-core/query-builders/update.js +20 -6
- package/pg-core/query-builders/update.js.map +1 -1
- package/pg-core/session.cjs +48 -4
- package/pg-core/session.cjs.map +1 -1
- package/pg-core/session.d.cts +11 -5
- package/pg-core/session.d.ts +11 -5
- package/pg-core/session.js +48 -4
- package/pg-core/session.js.map +1 -1
- package/pg-proxy/driver.cjs +3 -2
- package/pg-proxy/driver.cjs.map +1 -1
- package/pg-proxy/driver.d.cts +2 -1
- package/pg-proxy/driver.d.ts +2 -1
- package/pg-proxy/driver.js +3 -2
- package/pg-proxy/driver.js.map +1 -1
- package/pg-proxy/session.cjs +8 -6
- package/pg-proxy/session.cjs.map +1 -1
- package/pg-proxy/session.d.cts +5 -4
- package/pg-proxy/session.d.ts +5 -4
- package/pg-proxy/session.js +8 -6
- package/pg-proxy/session.js.map +1 -1
- package/pglite/driver.cjs +6 -4
- package/pglite/driver.cjs.map +1 -1
- package/pglite/driver.d.cts +6 -4
- package/pglite/driver.d.ts +6 -4
- package/pglite/driver.js +6 -4
- package/pglite/driver.js.map +1 -1
- package/pglite/session.cjs +19 -9
- package/pglite/session.cjs.map +1 -1
- package/pglite/session.d.cts +5 -4
- package/pglite/session.d.ts +5 -4
- package/pglite/session.js +19 -9
- package/pglite/session.js.map +1 -1
- package/planetscale-serverless/driver.cjs +10 -2
- package/planetscale-serverless/driver.cjs.map +1 -1
- package/planetscale-serverless/driver.d.cts +4 -3
- package/planetscale-serverless/driver.d.ts +4 -3
- package/planetscale-serverless/driver.js +10 -2
- package/planetscale-serverless/driver.js.map +1 -1
- package/planetscale-serverless/session.cjs +23 -13
- package/planetscale-serverless/session.cjs.map +1 -1
- package/planetscale-serverless/session.d.cts +6 -7
- package/planetscale-serverless/session.d.ts +6 -7
- package/planetscale-serverless/session.js +23 -13
- package/planetscale-serverless/session.js.map +1 -1
- package/postgres-js/driver.cjs +3 -2
- package/postgres-js/driver.cjs.map +1 -1
- package/postgres-js/driver.d.cts +4 -3
- package/postgres-js/driver.d.ts +4 -3
- package/postgres-js/driver.js +3 -2
- package/postgres-js/driver.js.map +1 -1
- package/postgres-js/session.cjs +27 -16
- package/postgres-js/session.cjs.map +1 -1
- package/postgres-js/session.d.cts +6 -5
- package/postgres-js/session.d.ts +6 -5
- package/postgres-js/session.js +27 -16
- package/postgres-js/session.js.map +1 -1
- package/prisma/mysql/driver.cjs +3 -3
- package/prisma/mysql/driver.cjs.map +1 -1
- package/prisma/mysql/driver.d.cts +3 -2
- package/prisma/mysql/driver.d.ts +3 -2
- package/prisma/mysql/driver.js +3 -3
- package/prisma/mysql/driver.js.map +1 -1
- package/prisma/mysql/session.cjs +10 -11
- package/prisma/mysql/session.cjs.map +1 -1
- package/prisma/mysql/session.d.cts +10 -5
- package/prisma/mysql/session.d.ts +10 -5
- package/prisma/mysql/session.js +10 -11
- package/prisma/mysql/session.js.map +1 -1
- package/prisma/pg/driver.cjs +3 -3
- package/prisma/pg/driver.cjs.map +1 -1
- package/prisma/pg/driver.d.cts +2 -1
- package/prisma/pg/driver.d.ts +2 -1
- package/prisma/pg/driver.js +3 -3
- package/prisma/pg/driver.js.map +1 -1
- package/prisma/pg/session.cjs +7 -7
- package/prisma/pg/session.cjs.map +1 -1
- package/prisma/pg/session.d.cts +10 -5
- package/prisma/pg/session.d.ts +10 -5
- package/prisma/pg/session.js +7 -7
- package/prisma/pg/session.js.map +1 -1
- package/prisma/sqlite/driver.cjs +7 -1
- package/prisma/sqlite/driver.cjs.map +1 -1
- package/prisma/sqlite/driver.d.cts +2 -1
- package/prisma/sqlite/driver.d.ts +2 -1
- package/prisma/sqlite/driver.js +7 -1
- package/prisma/sqlite/driver.js.map +1 -1
- package/prisma/sqlite/session.cjs +10 -10
- package/prisma/sqlite/session.cjs.map +1 -1
- package/prisma/sqlite/session.d.cts +12 -7
- package/prisma/sqlite/session.d.ts +12 -7
- package/prisma/sqlite/session.js +10 -10
- package/prisma/sqlite/session.js.map +1 -1
- package/singlestore/driver.cjs +34 -25
- package/singlestore/driver.cjs.map +1 -1
- package/singlestore/driver.d.cts +4 -2
- package/singlestore/driver.d.ts +4 -2
- package/singlestore/driver.js +34 -25
- package/singlestore/driver.js.map +1 -1
- package/singlestore/session.cjs +14 -10
- package/singlestore/session.cjs.map +1 -1
- package/singlestore/session.d.cts +5 -5
- package/singlestore/session.d.ts +5 -5
- package/singlestore/session.js +14 -10
- package/singlestore/session.js.map +1 -1
- package/singlestore-core/db.cjs +5 -3
- package/singlestore-core/db.cjs.map +1 -1
- package/singlestore-core/db.d.cts +3 -1
- package/singlestore-core/db.d.ts +3 -1
- package/singlestore-core/db.js +5 -3
- package/singlestore-core/db.js.map +1 -1
- package/singlestore-core/dialect.cjs +24 -18
- package/singlestore-core/dialect.cjs.map +1 -1
- package/singlestore-core/dialect.d.cts +7 -6
- package/singlestore-core/dialect.d.ts +7 -6
- package/singlestore-core/dialect.js +25 -19
- package/singlestore-core/dialect.js.map +1 -1
- package/singlestore-core/query-builders/delete.cjs +8 -1
- package/singlestore-core/query-builders/delete.cjs.map +1 -1
- package/singlestore-core/query-builders/delete.js +8 -1
- package/singlestore-core/query-builders/delete.js.map +1 -1
- package/singlestore-core/query-builders/insert.cjs +30 -5
- package/singlestore-core/query-builders/insert.cjs.map +1 -1
- package/singlestore-core/query-builders/insert.js +32 -7
- package/singlestore-core/query-builders/insert.js.map +1 -1
- package/singlestore-core/query-builders/query.cjs +17 -2
- package/singlestore-core/query-builders/query.cjs.map +1 -1
- package/singlestore-core/query-builders/query.js +17 -2
- package/singlestore-core/query-builders/query.js.map +1 -1
- package/singlestore-core/query-builders/select.cjs +24 -7
- package/singlestore-core/query-builders/select.cjs.map +1 -1
- package/singlestore-core/query-builders/select.d.cts +9 -9
- package/singlestore-core/query-builders/select.d.ts +9 -9
- package/singlestore-core/query-builders/select.js +24 -7
- package/singlestore-core/query-builders/select.js.map +1 -1
- package/singlestore-core/query-builders/select.types.cjs.map +1 -1
- package/singlestore-core/query-builders/select.types.d.cts +2 -1
- package/singlestore-core/query-builders/select.types.d.ts +2 -1
- package/singlestore-core/query-builders/update.cjs +9 -2
- package/singlestore-core/query-builders/update.cjs.map +1 -1
- package/singlestore-core/query-builders/update.js +9 -2
- package/singlestore-core/query-builders/update.js.map +1 -1
- package/singlestore-core/session.cjs +43 -4
- package/singlestore-core/session.cjs.map +1 -1
- package/singlestore-core/session.d.cts +14 -6
- package/singlestore-core/session.d.ts +14 -6
- package/singlestore-core/session.js +43 -4
- package/singlestore-core/session.js.map +1 -1
- package/singlestore-proxy/driver.cjs +3 -2
- package/singlestore-proxy/driver.cjs.map +1 -1
- package/singlestore-proxy/driver.d.cts +2 -1
- package/singlestore-proxy/driver.d.ts +2 -1
- package/singlestore-proxy/driver.js +3 -2
- package/singlestore-proxy/driver.js.map +1 -1
- package/singlestore-proxy/session.cjs +8 -8
- package/singlestore-proxy/session.cjs.map +1 -1
- package/singlestore-proxy/session.d.cts +9 -6
- package/singlestore-proxy/session.d.ts +9 -6
- package/singlestore-proxy/session.js +8 -8
- package/singlestore-proxy/session.js.map +1 -1
- package/sql/sql.cjs +24 -2
- package/sql/sql.cjs.map +1 -1
- package/sql/sql.d.cts +12 -0
- package/sql/sql.d.ts +12 -0
- package/sql/sql.js +23 -2
- package/sql/sql.js.map +1 -1
- package/sql-js/driver.cjs.map +1 -1
- package/sql-js/driver.d.cts +2 -1
- package/sql-js/driver.d.ts +2 -1
- package/sql-js/driver.js.map +1 -1
- package/sql-js/session.cjs +4 -4
- package/sql-js/session.cjs.map +1 -1
- package/sql-js/session.d.cts +4 -4
- package/sql-js/session.d.ts +4 -4
- package/sql-js/session.js +4 -4
- package/sql-js/session.js.map +1 -1
- package/sqlite-core/db.cjs +5 -3
- package/sqlite-core/db.cjs.map +1 -1
- package/sqlite-core/db.d.cts +3 -1
- package/sqlite-core/db.d.ts +3 -1
- package/sqlite-core/db.js +5 -3
- package/sqlite-core/db.js.map +1 -1
- package/sqlite-core/dialect.cjs +29 -19
- package/sqlite-core/dialect.cjs.map +1 -1
- package/sqlite-core/dialect.d.cts +7 -6
- package/sqlite-core/dialect.d.ts +7 -6
- package/sqlite-core/dialect.js +30 -20
- package/sqlite-core/dialect.js.map +1 -1
- package/sqlite-core/query-builders/delete.cjs +8 -1
- package/sqlite-core/query-builders/delete.cjs.map +1 -1
- package/sqlite-core/query-builders/delete.js +8 -1
- package/sqlite-core/query-builders/delete.js.map +1 -1
- package/sqlite-core/query-builders/insert.cjs +28 -4
- package/sqlite-core/query-builders/insert.cjs.map +1 -1
- package/sqlite-core/query-builders/insert.js +35 -6
- package/sqlite-core/query-builders/insert.js.map +1 -1
- package/sqlite-core/query-builders/query.cjs +15 -2
- package/sqlite-core/query-builders/query.cjs.map +1 -1
- package/sqlite-core/query-builders/query.js +15 -2
- package/sqlite-core/query-builders/query.js.map +1 -1
- package/sqlite-core/query-builders/select.cjs +15 -6
- package/sqlite-core/query-builders/select.cjs.map +1 -1
- package/sqlite-core/query-builders/select.d.cts +6 -6
- package/sqlite-core/query-builders/select.d.ts +6 -6
- package/sqlite-core/query-builders/select.js +15 -6
- package/sqlite-core/query-builders/select.js.map +1 -1
- package/sqlite-core/query-builders/select.types.cjs.map +1 -1
- package/sqlite-core/query-builders/select.types.d.cts +2 -1
- package/sqlite-core/query-builders/select.types.d.ts +2 -1
- package/sqlite-core/query-builders/update.cjs +9 -2
- package/sqlite-core/query-builders/update.cjs.map +1 -1
- package/sqlite-core/query-builders/update.js +9 -2
- package/sqlite-core/query-builders/update.js.map +1 -1
- package/sqlite-core/session.cjs +81 -6
- package/sqlite-core/session.cjs.map +1 -1
- package/sqlite-core/session.d.cts +19 -9
- package/sqlite-core/session.d.ts +19 -9
- package/sqlite-core/session.js +81 -6
- package/sqlite-core/session.js.map +1 -1
- package/sqlite-proxy/driver.cjs +4 -3
- package/sqlite-proxy/driver.cjs.map +1 -1
- package/sqlite-proxy/driver.d.cts +3 -2
- package/sqlite-proxy/driver.d.ts +3 -2
- package/sqlite-proxy/driver.js +4 -3
- package/sqlite-proxy/driver.js.map +1 -1
- package/sqlite-proxy/session.cjs +20 -11
- package/sqlite-proxy/session.cjs.map +1 -1
- package/sqlite-proxy/session.d.cts +8 -7
- package/sqlite-proxy/session.d.ts +8 -7
- package/sqlite-proxy/session.js +20 -11
- package/sqlite-proxy/session.js.map +1 -1
- package/tidb-serverless/driver.cjs +16 -2
- package/tidb-serverless/driver.cjs.map +1 -1
- package/tidb-serverless/driver.d.cts +4 -3
- package/tidb-serverless/driver.d.ts +4 -3
- package/tidb-serverless/driver.js +16 -2
- package/tidb-serverless/driver.js.map +1 -1
- package/tidb-serverless/session.cjs +23 -13
- package/tidb-serverless/session.cjs.map +1 -1
- package/tidb-serverless/session.d.cts +6 -7
- package/tidb-serverless/session.d.ts +6 -7
- package/tidb-serverless/session.js +23 -13
- package/tidb-serverless/session.js.map +1 -1
- package/tracing.cjs.map +1 -1
- package/tracing.js.map +1 -1
- package/utils.cjs +38 -2
- package/utils.cjs.map +1 -1
- package/utils.d.cts +6 -2
- package/utils.d.ts +6 -2
- package/utils.js +39 -4
- package/utils.js.map +1 -1
- package/vercel-postgres/driver.cjs +10 -5
- package/vercel-postgres/driver.cjs.map +1 -1
- package/vercel-postgres/driver.d.cts +6 -4
- package/vercel-postgres/driver.d.ts +6 -4
- package/vercel-postgres/driver.js +10 -5
- package/vercel-postgres/driver.js.map +1 -1
- package/vercel-postgres/session.cjs +18 -9
- package/vercel-postgres/session.cjs.map +1 -1
- package/vercel-postgres/session.d.cts +5 -4
- package/vercel-postgres/session.d.ts +5 -4
- package/vercel-postgres/session.js +18 -9
- package/vercel-postgres/session.js.map +1 -1
- package/version.cjs +1 -1
- package/version.d.cts +1 -1
- package/version.d.ts +1 -1
- package/version.js +1 -1
- package/xata-http/driver.cjs +7 -4
- package/xata-http/driver.cjs.map +1 -1
- package/xata-http/driver.d.cts +4 -2
- package/xata-http/driver.d.ts +4 -2
- package/xata-http/driver.js +7 -4
- package/xata-http/driver.js.map +1 -1
- package/xata-http/session.cjs +8 -6
- package/xata-http/session.cjs.map +1 -1
- package/xata-http/session.d.cts +5 -4
- package/xata-http/session.d.ts +5 -4
- package/xata-http/session.js +8 -6
- package/xata-http/session.js.map +1 -1
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { entityKind } from "../../../entity.js";
|
|
2
|
+
import { extensionColumnConfig, requiredExtension } from "../../../extension-core/index.js";
|
|
3
|
+
import {
|
|
4
|
+
GelColumn,
|
|
5
|
+
GelColumnBuilder
|
|
6
|
+
} from "../../../gel-core/index.js";
|
|
7
|
+
import { getColumnNameAndConfig } from "../../../utils.js";
|
|
8
|
+
import {
|
|
9
|
+
objectIdToText
|
|
10
|
+
} from "../common.js";
|
|
11
|
+
import { DrizzleGelS3Extension } from "./extension.js";
|
|
12
|
+
class GelS3FileBuilder extends GelColumnBuilder {
|
|
13
|
+
static [entityKind] = "GelS3FileBuilder";
|
|
14
|
+
[extensionColumnConfig];
|
|
15
|
+
constructor(name, config) {
|
|
16
|
+
super(name, "custom", "GelS3File");
|
|
17
|
+
this[extensionColumnConfig] = {
|
|
18
|
+
fileMode: config.mode,
|
|
19
|
+
fetchMode: "file"
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
array(size) {
|
|
23
|
+
return super.array(size);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Allows to set default to an existing file
|
|
27
|
+
*
|
|
28
|
+
* @example
|
|
29
|
+
* ```
|
|
30
|
+
* fileColumn: s3File().default(sql`${bucket}:${key}`)
|
|
31
|
+
* ```
|
|
32
|
+
*
|
|
33
|
+
* @returns
|
|
34
|
+
*/
|
|
35
|
+
default(value) {
|
|
36
|
+
return super.default(value);
|
|
37
|
+
}
|
|
38
|
+
generatedAlwaysAs(as) {
|
|
39
|
+
return super.generatedAlwaysAs(as);
|
|
40
|
+
}
|
|
41
|
+
/** @internal */
|
|
42
|
+
build(table) {
|
|
43
|
+
return new GelS3File(
|
|
44
|
+
table,
|
|
45
|
+
this.config,
|
|
46
|
+
this[extensionColumnConfig]
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
class GelS3File extends GelColumn {
|
|
51
|
+
static [entityKind] = "GelS3File";
|
|
52
|
+
[requiredExtension] = DrizzleGelS3Extension;
|
|
53
|
+
[extensionColumnConfig];
|
|
54
|
+
constructor(table, config, extensionConfig) {
|
|
55
|
+
super(table, config);
|
|
56
|
+
this[extensionColumnConfig] = extensionConfig ?? {
|
|
57
|
+
fileMode: "buffer",
|
|
58
|
+
fetchMode: "file"
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
mapToDriverValue(value) {
|
|
62
|
+
if (typeof value === "string") return value;
|
|
63
|
+
return objectIdToText(value);
|
|
64
|
+
}
|
|
65
|
+
data() {
|
|
66
|
+
return new GelS3File(
|
|
67
|
+
this.table,
|
|
68
|
+
this.config,
|
|
69
|
+
{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: "data" }
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
presigned(options) {
|
|
73
|
+
return new GelS3File(
|
|
74
|
+
this.table,
|
|
75
|
+
this.config,
|
|
76
|
+
{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: "presigned", options }
|
|
77
|
+
);
|
|
78
|
+
}
|
|
79
|
+
getSQLType() {
|
|
80
|
+
return "text";
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
function s3File(a, b) {
|
|
84
|
+
const { name, config } = getColumnNameAndConfig(a, b);
|
|
85
|
+
return new GelS3FileBuilder(name, config);
|
|
86
|
+
}
|
|
87
|
+
export {
|
|
88
|
+
GelS3File,
|
|
89
|
+
GelS3FileBuilder,
|
|
90
|
+
s3File
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=column.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/extensions/s3-file/gel/column.ts"],"sourcesContent":["import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnDataType,\n\tHasDefault,\n\tHasGenerated,\n\tMakeColumnConfig,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig, ColumnRuntimeConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport { extensionColumnConfig, requiredExtension } from '~/extension-core/index.ts';\nimport {\n\ttype GelArrayBuilder,\n\ttype GelArrayColumnBuilderBaseConfig,\n\tGelColumn,\n\tGelColumnBuilder,\n} from '~/gel-core/index.ts';\nimport type { AnyGelTable, GelTable } from '~/gel-core/table.ts';\nimport type { SQL } from '~/sql/index.ts';\nimport { type Assume, getColumnNameAndConfig } from '~/utils.ts';\nimport {\n\ttype DrizzleS3FetchMode,\n\ttype DrizzleS3FileMode,\n\ttype DrizzleS3FileModeToData,\n\ttype DrizzleS3ObjectFile,\n\ttype DrizzleS3ObjectIdentification,\n\tobjectIdToText,\n\ttype RequestPresigningArguments,\n} from '../common.ts';\nimport { DrizzleGelS3Extension } from './extension.ts';\n\nexport type GelS3FileBuilderInitial<TName extends string, TMode extends DrizzleS3FileMode> = GelS3FileBuilder<{\n\tname: TName;\n\tdataType: 'custom';\n\tcolumnType: 'GelS3File';\n\tdata: DrizzleS3ObjectFile<DrizzleS3FileModeToData[TMode]>;\n\tenumValues: undefined;\n\tdriverParam: string;\n}>;\n\nexport interface GelS3FileArrayBuilder<\n\tT extends GelArrayColumnBuilderBaseConfig,\n\tTBase extends ColumnBuilderBaseConfig<ColumnDataType, string> | GelArrayColumnBuilderBaseConfig,\n> extends GelArrayBuilder<T, TBase> {\n\tdefault(value: SQL<unknown>): HasDefault<this>;\n\tgeneratedAlwaysAs(as: SQL<unknown> | (() => SQL)): HasGenerated<this, { type: 'always' }>;\n\tarray<TSize extends number | undefined = undefined>(size?: TSize): GelS3FileArrayBuilder<\n\t\t& {\n\t\t\tname: T['name'];\n\t\t\tdataType: 'array';\n\t\t\tcolumnType: 'GelArray';\n\t\t\tdata: T['data'][];\n\t\t\tdriverParam: T['driverParam'][] | string;\n\t\t\tenumValues: T['enumValues'];\n\t\t\tsize: TSize;\n\t\t\tbaseBuilder: T;\n\t\t}\n\t\t& (T extends { notNull: true } ? { notNull: true } : {})\n\t\t& (T extends { hasDefault: true } ? { hasDefault: true } : {}),\n\t\tT\n\t>;\n}\n\nexport class GelS3FileBuilder<\n\tT extends ColumnBuilderBaseConfig<'custom', 'GelS3File'>,\n\tTRuntimeConfig extends object = {},\n\tTTypeConfig extends object = {},\n> extends GelColumnBuilder<T, TRuntimeConfig, TTypeConfig> {\n\tstatic override readonly [entityKind]: string = 'GelS3FileBuilder';\n\treadonly [extensionColumnConfig]: GelS3FileExtensionColumnConfig;\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tconfig: GelS3FileConfig,\n\t) {\n\t\tsuper(name, 'custom', 'GelS3File');\n\t\tthis[extensionColumnConfig] = {\n\t\t\tfileMode: config.mode,\n\t\t\tfetchMode: 'file',\n\t\t};\n\t}\n\n\toverride array<TSize extends number | undefined = undefined>(size?: TSize): GelS3FileArrayBuilder<\n\t\t& {\n\t\t\tname: T['name'];\n\t\t\tdataType: 'array';\n\t\t\tcolumnType: 'GelArray';\n\t\t\tdata: T['data'][];\n\t\t\tdriverParam: T['driverParam'][] | string;\n\t\t\tenumValues: T['enumValues'];\n\t\t\tsize: TSize;\n\t\t\tbaseBuilder: T;\n\t\t}\n\t\t& (T extends { notNull: true } ? { notNull: true } : {})\n\t\t& (T extends { hasDefault: true } ? { hasDefault: true } : {}),\n\t\tT\n\t> {\n\t\treturn super.array(size) as any;\n\t}\n\n\t/**\n\t * Allows to set default to an existing file\n\t *\n\t * @example\n\t * ```\n\t * fileColumn: s3File().default(sql`${bucket}:${key}`)\n\t * ```\n\t *\n\t * @returns\n\t */\n\toverride default(value: SQL<unknown>): HasDefault<this> {\n\t\treturn super.default(value);\n\t}\n\n\toverride generatedAlwaysAs(as: SQL<unknown> | (() => SQL)): HasGenerated<this, { type: 'always' }> {\n\t\treturn super.generatedAlwaysAs(as);\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyGelTable<{ name: TTableName }>,\n\t): GelS3File<MakeColumnConfig<T, TTableName>> {\n\t\treturn new GelS3File<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t\tthis[extensionColumnConfig],\n\t\t);\n\t}\n}\n\nexport type GelS3FileExtensionColumnConfig = {\n\tfetchMode: DrizzleS3FetchMode;\n\tfileMode: DrizzleS3FileMode;\n\toptions?: RequestPresigningArguments;\n};\n\nexport class GelS3File<T extends ColumnBaseConfig<'custom', 'GelS3File'> = ColumnBaseConfig<'custom', 'GelS3File'>>\n\textends GelColumn<T, { enumValues: T['enumValues'] }>\n{\n\tstatic override readonly [entityKind]: string = 'GelS3File';\n\toverride [requiredExtension] = DrizzleGelS3Extension;\n\t[extensionColumnConfig]: GelS3FileExtensionColumnConfig;\n\n\tconstructor(\n\t\ttable: GelTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data'], T>,\n\t\textensionConfig?: GelS3FileExtensionColumnConfig,\n\t) {\n\t\tsuper(table, config);\n\n\t\tthis[extensionColumnConfig] = extensionConfig ?? {\n\t\t\tfileMode: 'buffer',\n\t\t\tfetchMode: 'file',\n\t\t};\n\t}\n\n\toverride mapToDriverValue(value: unknown): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\treturn objectIdToText(value as DrizzleS3ObjectIdentification);\n\t}\n\n\tdata(): GelColumn<Omit<T, 'data'> & { data: Assume<T['data'], DrizzleS3ObjectFile>['data'] }> {\n\t\treturn new GelS3File(\n\t\t\tthis.table,\n\t\t\tthis.config as ColumnRuntimeConfig<\n\t\t\t\tDrizzleS3ObjectFile['data'],\n\t\t\t\tOmit<T, 'data'> & { data: Assume<T['data'], DrizzleS3ObjectFile>['data'] }\n\t\t\t>,\n\t\t\t{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'data' },\n\t\t);\n\t}\n\n\tpresigned(options?: RequestPresigningArguments): GelColumn<Omit<T, 'data'> & { data: string }> {\n\t\treturn new GelS3File(\n\t\t\tthis.table,\n\t\t\tthis.config as ColumnRuntimeConfig<\n\t\t\t\tstring,\n\t\t\t\tOmit<T, 'data'> & { data: string }\n\t\t\t>,\n\t\t\t{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'presigned', options },\n\t\t);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'text';\n\t}\n}\n\nexport interface GelS3FileConfig<\n\tTMode extends DrizzleS3FileMode = DrizzleS3FileMode,\n> {\n\tmode: TMode;\n}\n\nexport function s3File<TName extends string, TMode extends DrizzleS3FileMode>(\n\tconfig: GelS3FileConfig<TMode>,\n): GelS3FileBuilderInitial<TName, TMode>;\nexport function s3File<TName extends string, TMode extends DrizzleS3FileMode>(\n\tname: TName,\n\tconfig: GelS3FileConfig<TMode>,\n): GelS3FileBuilderInitial<TName, TMode>;\nexport function s3File(a: string | GelS3FileConfig, b?: GelS3FileConfig): any {\n\tconst { name, config } = getColumnNameAndConfig<GelS3FileConfig>(a, b);\n\treturn new GelS3FileBuilder(name, config);\n}\n"],"mappings":"AASA,SAAS,kBAAkB;AAC3B,SAAS,uBAAuB,yBAAyB;AACzD;AAAA,EAGC;AAAA,EACA;AAAA,OACM;AAGP,SAAsB,8BAA8B;AACpD;AAAA,EAMC;AAAA,OAEM;AACP,SAAS,6BAA6B;AAkC/B,MAAM,yBAIH,iBAAiD;AAAA,EAC1D,QAA0B,UAAU,IAAY;AAAA,EAChD,CAAU,qBAAqB;AAAA,EAE/B,YACC,MACA,QACC;AACD,UAAM,MAAM,UAAU,WAAW;AACjC,SAAK,qBAAqB,IAAI;AAAA,MAC7B,UAAU,OAAO;AAAA,MACjB,WAAW;AAAA,IACZ;AAAA,EACD;AAAA,EAES,MAAoD,MAc3D;AACD,WAAO,MAAM,MAAM,IAAI;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYS,QAAQ,OAAuC;AACvD,WAAO,MAAM,QAAQ,KAAK;AAAA,EAC3B;AAAA,EAES,kBAAkB,IAAwE;AAClG,WAAO,MAAM,kBAAkB,EAAE;AAAA,EAClC;AAAA;AAAA,EAGS,MACR,OAC6C;AAC7C,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,MACL,KAAK,qBAAqB;AAAA,IAC3B;AAAA,EACD;AACD;AAQO,MAAM,kBACJ,UACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAChD,CAAU,iBAAiB,IAAI;AAAA,EAC/B,CAAC,qBAAqB;AAAA,EAEtB,YACC,OACA,QACA,iBACC;AACD,UAAM,OAAO,MAAM;AAEnB,SAAK,qBAAqB,IAAI,mBAAmB;AAAA,MAChD,UAAU;AAAA,MACV,WAAW;AAAA,IACZ;AAAA,EACD;AAAA,EAES,iBAAiB,OAAwB;AACjD,QAAI,OAAO,UAAU,SAAU,QAAO;AAEtC,WAAO,eAAe,KAAsC;AAAA,EAC7D;AAAA,EAEA,OAA8F;AAC7F,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MAIL,EAAE,UAAU,KAAK,qBAAqB,EAAE,UAAU,WAAW,OAAO;AAAA,IACrE;AAAA,EACD;AAAA,EAEA,UAAU,SAAqF;AAC9F,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MAIL,EAAE,UAAU,KAAK,qBAAqB,EAAE,UAAU,WAAW,aAAa,QAAQ;AAAA,IACnF;AAAA,EACD;AAAA,EAEA,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAeO,SAAS,OAAO,GAA6B,GAA0B;AAC7E,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAwC,GAAG,CAAC;AACrE,SAAO,IAAI,iBAAiB,MAAM,MAAM;AACzC;","names":[]}
|
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var extension_exports = {};
|
|
20
|
+
__export(extension_exports, {
|
|
21
|
+
DrizzleGelS3Extension: () => DrizzleGelS3Extension,
|
|
22
|
+
s3FileExt: () => s3FileExt
|
|
23
|
+
});
|
|
24
|
+
module.exports = __toCommonJS(extension_exports);
|
|
25
|
+
var import_client_s3 = require("@aws-sdk/client-s3");
|
|
26
|
+
var import_entity = require("../../../entity.cjs");
|
|
27
|
+
var import_errors = require("../../../errors.cjs");
|
|
28
|
+
var import_gel = require("../../../extension-core/gel/index.cjs");
|
|
29
|
+
var import_extension_core = require("../../../extension-core/index.cjs");
|
|
30
|
+
var import_gel_core = require("../../../gel-core/index.cjs");
|
|
31
|
+
var import_relations = require("../../../relations.cjs");
|
|
32
|
+
var import_sql = require("../../../sql/index.cjs");
|
|
33
|
+
var import_utils = require("../../../utils.cjs");
|
|
34
|
+
var import_common = require("../common.cjs");
|
|
35
|
+
class DrizzleGelS3Extension extends import_gel.DrizzleGelExtension {
|
|
36
|
+
static [import_entity.entityKind] = "DrizzleGelS3Extension";
|
|
37
|
+
static [import_extension_core.extensionName] = "Drizzle Gel S3 Extension";
|
|
38
|
+
s3;
|
|
39
|
+
constructor(client) {
|
|
40
|
+
super();
|
|
41
|
+
this.s3 = typeof client === "object" && (client instanceof import_client_s3.S3Client || client.constructor.name !== "Object") ? client : new import_client_s3.S3Client(client);
|
|
42
|
+
}
|
|
43
|
+
buildOutputMappingInstructions(selection) {
|
|
44
|
+
const paths = [];
|
|
45
|
+
for (const f of selection) {
|
|
46
|
+
if (!(0, import_entity.is)(f.field, import_gel_core.GelColumn) || !f.field[import_extension_core.requiredExtension] || !(0, import_entity.is)(this, f.field[import_extension_core.requiredExtension])) continue;
|
|
47
|
+
let field = f.field;
|
|
48
|
+
let dimensions = 0;
|
|
49
|
+
while ((0, import_entity.is)(field, import_gel_core.GelArray)) {
|
|
50
|
+
field = field.baseColumn;
|
|
51
|
+
++dimensions;
|
|
52
|
+
}
|
|
53
|
+
const column = field;
|
|
54
|
+
const { fetchMode, fileMode, options } = column[import_extension_core.extensionColumnConfig];
|
|
55
|
+
paths.push({
|
|
56
|
+
path: f.path.map((p) => `[${JSON.stringify(p)}]`),
|
|
57
|
+
fetchMode,
|
|
58
|
+
fileMode,
|
|
59
|
+
options,
|
|
60
|
+
arrayDimensions: dimensions
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
return paths;
|
|
64
|
+
}
|
|
65
|
+
buildRqbOutputMappingInstructions(schema, table, selection, parent, prefix = []) {
|
|
66
|
+
const p = parent ?? {
|
|
67
|
+
path: [],
|
|
68
|
+
subinstructions: []
|
|
69
|
+
};
|
|
70
|
+
for (const s of selection) {
|
|
71
|
+
if ((0, import_entity.is)(s.field, import_gel_core.GelColumn)) {
|
|
72
|
+
if (!s.field[import_extension_core.requiredExtension] || !(0, import_entity.is)(this, s.field[import_extension_core.requiredExtension])) continue;
|
|
73
|
+
let column = s.field;
|
|
74
|
+
let dimensions = 0;
|
|
75
|
+
while ((0, import_entity.is)(column, import_gel_core.GelArray)) {
|
|
76
|
+
column = column.baseColumn;
|
|
77
|
+
++dimensions;
|
|
78
|
+
}
|
|
79
|
+
const extCol = column;
|
|
80
|
+
(p.subinstructions ??= []).push({
|
|
81
|
+
path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
|
|
82
|
+
arrayDimensions: dimensions,
|
|
83
|
+
fileMode: extCol[import_extension_core.extensionColumnConfig].fileMode,
|
|
84
|
+
fetchMode: extCol[import_extension_core.extensionColumnConfig].fetchMode,
|
|
85
|
+
options: extCol[import_extension_core.extensionColumnConfig].options
|
|
86
|
+
});
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
if (s.selection) {
|
|
90
|
+
const relation = schema[s.relationTableTsKey];
|
|
91
|
+
if ((0, import_entity.is)(table.relations[s.tsKey], import_relations.One)) {
|
|
92
|
+
this.buildRqbOutputMappingInstructions(schema, relation, s.selection, p, [
|
|
93
|
+
...prefix,
|
|
94
|
+
`[${JSON.stringify(s.tsKey)}]`
|
|
95
|
+
]);
|
|
96
|
+
continue;
|
|
97
|
+
}
|
|
98
|
+
const nestedSubs = this.buildRqbOutputMappingInstructions(schema, relation, s.selection);
|
|
99
|
+
if (!nestedSubs.length) continue;
|
|
100
|
+
(p.subinstructions ??= []).push({
|
|
101
|
+
path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
|
|
102
|
+
subinstructions: nestedSubs
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return p.subinstructions;
|
|
107
|
+
}
|
|
108
|
+
buildParamMappingInstructions(params) {
|
|
109
|
+
const indexes = [];
|
|
110
|
+
const placeholders = [];
|
|
111
|
+
let i = 0;
|
|
112
|
+
for (const item of params) {
|
|
113
|
+
if (!(0, import_entity.is)(item, import_sql.ExtensionParam) || !(0, import_entity.is)(this, item.extension)) {
|
|
114
|
+
++i;
|
|
115
|
+
continue;
|
|
116
|
+
}
|
|
117
|
+
let dimensions = 0;
|
|
118
|
+
let column = item.encoder;
|
|
119
|
+
while ((0, import_entity.is)(column, import_gel_core.GelArray)) {
|
|
120
|
+
column = column.baseColumn;
|
|
121
|
+
++dimensions;
|
|
122
|
+
}
|
|
123
|
+
if ((0, import_entity.is)(item.value, import_sql.Placeholder)) {
|
|
124
|
+
placeholders.push({
|
|
125
|
+
key: item.value.name,
|
|
126
|
+
mode: column[import_extension_core.extensionColumnConfig].fileMode,
|
|
127
|
+
arrayDimensions: dimensions
|
|
128
|
+
});
|
|
129
|
+
++i;
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
indexes.push({
|
|
133
|
+
index: i++,
|
|
134
|
+
mode: column[import_extension_core.extensionColumnConfig].fileMode,
|
|
135
|
+
arrayDimensions: dimensions
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
return {
|
|
139
|
+
placeholders,
|
|
140
|
+
indexes
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
async hookBefore(context) {
|
|
144
|
+
if (!context?.params?.length) return;
|
|
145
|
+
let indexes = [];
|
|
146
|
+
let placeholders = [];
|
|
147
|
+
const errors = [];
|
|
148
|
+
switch (context.query) {
|
|
149
|
+
case "select":
|
|
150
|
+
case "delete": {
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
case "update":
|
|
154
|
+
case "insert": {
|
|
155
|
+
if (context.config.select) break;
|
|
156
|
+
const instr = this.buildParamMappingInstructions(context.params);
|
|
157
|
+
indexes = instr.indexes;
|
|
158
|
+
placeholders = instr.placeholders;
|
|
159
|
+
break;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
await (0, import_common.mapParams)(this.s3, context.params, indexes, errors);
|
|
163
|
+
if (errors.length) {
|
|
164
|
+
throw new import_errors.DrizzleError({
|
|
165
|
+
message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
|
|
166
|
+
Log "(e as DrizzleError).cause" for details.`,
|
|
167
|
+
cause: errors
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
if (!context.metadata?.encoder) {
|
|
171
|
+
context.metadata = context.metadata ?? {};
|
|
172
|
+
context.metadata.encoder = (0, import_common.buildEncoder)(placeholders);
|
|
173
|
+
}
|
|
174
|
+
await context.metadata.encoder(this.s3, context.placeholders, errors, import_common.uploadFile, import_common.objectIdToText);
|
|
175
|
+
if (errors.length) {
|
|
176
|
+
throw new import_errors.DrizzleError({
|
|
177
|
+
message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
|
|
178
|
+
Log "(e as DrizzleError).cause" for details.`,
|
|
179
|
+
cause: errors
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
async hookAfter(context) {
|
|
185
|
+
const errors = [];
|
|
186
|
+
const data = context.data;
|
|
187
|
+
switch (context.query) {
|
|
188
|
+
case "select": {
|
|
189
|
+
if (!data.length) return;
|
|
190
|
+
if (!context.metadata?.decoder) {
|
|
191
|
+
const fields = context.fieldsOrdered ?? context.config.fieldsFlat ?? (0, import_utils.orderSelectedFields)(context.config.fields);
|
|
192
|
+
const instructions = this.buildOutputMappingInstructions(fields);
|
|
193
|
+
const decoder = (0, import_common.buildDecoder)(instructions);
|
|
194
|
+
context.metadata = context.metadata ?? {};
|
|
195
|
+
context.metadata.decoder = decoder;
|
|
196
|
+
}
|
|
197
|
+
break;
|
|
198
|
+
}
|
|
199
|
+
case "_query": {
|
|
200
|
+
if (context.mode === "first" && !data || context.mode === "many" && !data.length) return;
|
|
201
|
+
if (!context.metadata?.decoder) {
|
|
202
|
+
const instructions = this.buildRqbOutputMappingInstructions(
|
|
203
|
+
context.tablesConfig,
|
|
204
|
+
context.tableConfig,
|
|
205
|
+
context.config.selection
|
|
206
|
+
);
|
|
207
|
+
const decoder = (0, import_common.buildDecoder)(instructions, context.mode);
|
|
208
|
+
context.metadata = context.metadata ?? {};
|
|
209
|
+
context.metadata.decoder = decoder;
|
|
210
|
+
}
|
|
211
|
+
break;
|
|
212
|
+
}
|
|
213
|
+
case "update":
|
|
214
|
+
case "insert":
|
|
215
|
+
case "delete": {
|
|
216
|
+
if (!data.length) return;
|
|
217
|
+
if (!context.metadata?.decoder) {
|
|
218
|
+
if (!context.config.returning) {
|
|
219
|
+
const decoder2 = (0, import_common.buildDecoder)([]);
|
|
220
|
+
context.metadata = context.metadata ?? {};
|
|
221
|
+
context.metadata.decoder = decoder2;
|
|
222
|
+
break;
|
|
223
|
+
}
|
|
224
|
+
const fields = context.config.returning;
|
|
225
|
+
const instructions = this.buildOutputMappingInstructions(fields);
|
|
226
|
+
const decoder = (0, import_common.buildDecoder)(instructions);
|
|
227
|
+
context.metadata = context.metadata ?? {};
|
|
228
|
+
context.metadata.decoder = decoder;
|
|
229
|
+
}
|
|
230
|
+
break;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
await context.metadata.decoder(
|
|
234
|
+
this.s3,
|
|
235
|
+
data,
|
|
236
|
+
errors,
|
|
237
|
+
import_common.downloadFile,
|
|
238
|
+
import_common.presignDownload,
|
|
239
|
+
import_common.textToObjectId
|
|
240
|
+
);
|
|
241
|
+
if (errors.length) {
|
|
242
|
+
throw new import_errors.DrizzleError({
|
|
243
|
+
message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file download.
|
|
244
|
+
Log "(e as DrizzleError).cause" for details.`,
|
|
245
|
+
cause: errors
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
async hook(context) {
|
|
251
|
+
return context.stage === "before" ? await this.hookBefore(context) : await this.hookAfter(context);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
function s3FileExt(client) {
|
|
255
|
+
return new DrizzleGelS3Extension(client);
|
|
256
|
+
}
|
|
257
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
258
|
+
0 && (module.exports = {
|
|
259
|
+
DrizzleGelS3Extension,
|
|
260
|
+
s3FileExt
|
|
261
|
+
});
|
|
262
|
+
//# sourceMappingURL=extension.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/extensions/s3-file/gel/extension.ts"],"sourcesContent":["import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport { DrizzleGelExtension, type DrizzleGelHookContext } from '~/extension-core/gel/index.ts';\nimport { extensionColumnConfig, extensionName, requiredExtension } from '~/extension-core/index.ts';\nimport { GelArray, GelColumn, type GelInsertConfig } from '~/gel-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/operations.ts';\nimport {\n\ttype BuildRelationalQueryResult,\n\tOne,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { ExtensionParam, Placeholder } from '~/sql/index.ts';\nimport { orderSelectedFields } from '~/utils.ts';\nimport {\n\tbuildDecoder,\n\tbuildEncoder,\n\tdownloadFile,\n\tmapParams,\n\tobjectIdToText,\n\tpresignDownload,\n\ttextToObjectId,\n\tuploadFile,\n} from '../common.ts';\nimport type {\n\tDrizzleS3FileInputMappingInstruction,\n\tDrizzleS3FileOutputMappingInstruction,\n\tDrizzleS3FileOutputMappingInstructionIterableNode,\n\tDrizzleS3FilePlaceholderMappingInstruction,\n\tS3ExtMeta,\n} from '../common.ts';\nimport type { GelS3File } from './column.ts';\n\nexport class DrizzleGelS3Extension extends DrizzleGelExtension<S3ExtMeta> {\n\tstatic override readonly [entityKind]: string = 'DrizzleGelS3Extension';\n\n\tstatic override readonly [extensionName] = 'Drizzle Gel S3 Extension';\n\n\tprivate s3: S3Client;\n\n\tconstructor(client: S3Client | S3ClientConfig) {\n\t\tsuper();\n\n\t\t// eslint-disable-next-line no-instanceof/no-instanceof\n\t\tthis.s3 = typeof client === 'object' && (client instanceof S3Client || client.constructor.name !== 'Object')\n\t\t\t? client as S3Client\n\t\t\t: new S3Client(client);\n\t}\n\n\tprivate buildOutputMappingInstructions(selection: SelectedFieldsOrdered<GelColumn>) {\n\t\tconst paths: DrizzleS3FileOutputMappingInstruction[] = [];\n\n\t\tfor (const f of selection) {\n\t\t\tif (\n\t\t\t\t!is(f.field, GelColumn) || !(<GelColumn> f.field)[requiredExtension]\n\t\t\t\t|| !is(this, f.field[requiredExtension]!)\n\t\t\t) continue;\n\n\t\t\tlet field = f.field as GelColumn;\n\t\t\tlet dimensions = 0;\n\t\t\twhile (is(field, GelArray)) {\n\t\t\t\tfield = field.baseColumn;\n\t\t\t\t++dimensions;\n\t\t\t}\n\n\t\t\tconst column = field as GelS3File;\n\n\t\t\tconst { fetchMode, fileMode, options } = column[extensionColumnConfig];\n\n\t\t\tpaths.push({\n\t\t\t\tpath: f.path.map((p) => `[${JSON.stringify(p)}]`),\n\t\t\t\tfetchMode: fetchMode,\n\t\t\t\tfileMode: fileMode,\n\t\t\t\toptions: options,\n\t\t\t\tarrayDimensions: dimensions,\n\t\t\t});\n\t\t}\n\n\t\treturn paths;\n\t}\n\n\tprivate buildRqbOutputMappingInstructions(\n\t\tschema: TablesRelationalConfig,\n\t\ttable: TableRelationalConfig,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tparent?: DrizzleS3FileOutputMappingInstructionIterableNode,\n\t\tprefix: string[] = [],\n\t) {\n\t\tconst p: DrizzleS3FileOutputMappingInstructionIterableNode = parent ?? {\n\t\t\tpath: [],\n\t\t\tsubinstructions: [],\n\t\t};\n\n\t\tfor (const s of selection) {\n\t\t\tif (is(s.field, GelColumn)) {\n\t\t\t\tif (!s.field[requiredExtension] || !is(this, s.field[requiredExtension])) continue;\n\n\t\t\t\tlet column = s.field;\n\t\t\t\tlet dimensions = 0;\n\t\t\t\twhile (is(column, GelArray)) {\n\t\t\t\t\tcolumn = column.baseColumn;\n\t\t\t\t\t++dimensions;\n\t\t\t\t}\n\n\t\t\t\tconst extCol = column as GelS3File;\n\n\t\t\t\t(p.subinstructions ??= []).push({\n\t\t\t\t\tpath: [...prefix, `[${JSON.stringify(s.tsKey)}]`],\n\t\t\t\t\tarrayDimensions: dimensions,\n\t\t\t\t\tfileMode: extCol[extensionColumnConfig].fileMode,\n\t\t\t\t\tfetchMode: extCol[extensionColumnConfig].fetchMode,\n\t\t\t\t\toptions: extCol[extensionColumnConfig].options,\n\t\t\t\t});\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (s.selection) {\n\t\t\t\tconst relation = schema[s.relationTableTsKey!]!;\n\n\t\t\t\tif (is(table.relations[s.tsKey]!, One)) {\n\t\t\t\t\tthis.buildRqbOutputMappingInstructions(schema, relation, s.selection, p, [\n\t\t\t\t\t\t...prefix,\n\t\t\t\t\t\t`[${JSON.stringify(s.tsKey)}]`,\n\t\t\t\t\t]);\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst nestedSubs = this.buildRqbOutputMappingInstructions(schema, relation, s.selection);\n\t\t\t\tif (!nestedSubs.length) continue;\n\n\t\t\t\t(p.subinstructions ??= []).push({\n\t\t\t\t\tpath: [...prefix, `[${JSON.stringify(s.tsKey)}]`],\n\t\t\t\t\tsubinstructions: nestedSubs,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn p.subinstructions;\n\t}\n\n\tprivate buildParamMappingInstructions(params: unknown[]) {\n\t\tconst indexes: DrizzleS3FileInputMappingInstruction[] = [];\n\t\tconst placeholders: DrizzleS3FilePlaceholderMappingInstruction[] = [];\n\t\tlet i = 0;\n\t\tfor (const item of params) {\n\t\t\tif (!is(item, ExtensionParam) || !is(this, item.extension)) {\n\t\t\t\t++i;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet dimensions = 0;\n\t\t\tlet column = item.encoder;\n\t\t\twhile (is(column, GelArray)) {\n\t\t\t\tcolumn = column.baseColumn;\n\t\t\t\t++dimensions;\n\t\t\t}\n\n\t\t\tif (is(item.value, Placeholder)) {\n\t\t\t\tplaceholders.push({\n\t\t\t\t\tkey: item.value.name,\n\t\t\t\t\tmode: (column as GelS3File)[extensionColumnConfig].fileMode,\n\t\t\t\t\tarrayDimensions: dimensions,\n\t\t\t\t});\n\t\t\t\t++i;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tindexes.push({\n\t\t\t\tindex: i++,\n\t\t\t\tmode: (column as GelS3File)[extensionColumnConfig].fileMode,\n\t\t\t\tarrayDimensions: dimensions,\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\tplaceholders,\n\t\t\tindexes,\n\t\t};\n\t}\n\n\tprivate async hookBefore(context: DrizzleGelHookContext<S3ExtMeta> & { stage: 'before' }) {\n\t\tif (!context?.params?.length) return;\n\n\t\tlet indexes: DrizzleS3FileInputMappingInstruction[] = [];\n\t\tlet placeholders: DrizzleS3FilePlaceholderMappingInstruction[] = [];\n\t\tconst errors: unknown[] = [];\n\n\t\tswitch (context.query) {\n\t\t\tcase 'select':\n\t\t\tcase 'delete': {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'update':\n\t\t\tcase 'insert': {\n\t\t\t\tif ((context.config as GelInsertConfig).select) break;\n\n\t\t\t\tconst instr = this.buildParamMappingInstructions(context.params);\n\n\t\t\t\tindexes = instr.indexes;\n\t\t\t\tplaceholders = instr.placeholders;\n\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tawait mapParams(this.s3, context.params, indexes, errors);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file upload.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\tif (!context.metadata?.encoder) {\n\t\t\tcontext.metadata = context.metadata ?? {};\n\n\t\t\tcontext.metadata.encoder = buildEncoder(placeholders);\n\t\t}\n\n\t\tawait context.metadata.encoder(this.s3, context.placeholders, errors, uploadFile, objectIdToText);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file upload.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\treturn;\n\t}\n\n\tprivate async hookAfter(context: DrizzleGelHookContext<S3ExtMeta> & { stage: 'after' }) {\n\t\tconst errors: unknown[] = [];\n\t\tconst data = context.data as Record<string, unknown>[];\n\n\t\tswitch (context.query) {\n\t\t\tcase 'select': {\n\t\t\t\tif (!data.length) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tconst fields = context.fieldsOrdered ?? context.config.fieldsFlat\n\t\t\t\t\t\t?? orderSelectedFields<GelColumn>(context.config.fields);\n\n\t\t\t\t\tconst instructions = this.buildOutputMappingInstructions(fields);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase '_query': {\n\t\t\t\tif ((context.mode === 'first' && !data) || (context.mode === 'many' && !data.length)) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tconst instructions = this.buildRqbOutputMappingInstructions(\n\t\t\t\t\t\tcontext.tablesConfig,\n\t\t\t\t\t\tcontext.tableConfig,\n\t\t\t\t\t\tcontext.config.selection,\n\t\t\t\t\t);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions, context.mode);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'update':\n\t\t\tcase 'insert':\n\t\t\tcase 'delete': {\n\t\t\t\tif (!data.length) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tif (!(context.config.returning)) {\n\t\t\t\t\t\tconst decoder = buildDecoder([]);\n\n\t\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\t\tcontext.metadata.decoder = decoder;\n\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fields = context.config.returning;\n\n\t\t\t\t\tconst instructions = this.buildOutputMappingInstructions(fields);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tawait context.metadata.decoder(\n\t\t\tthis.s3,\n\t\t\tdata,\n\t\t\terrors,\n\t\t\tdownloadFile,\n\t\t\tpresignDownload,\n\t\t\ttextToObjectId,\n\t\t);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file download.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\treturn;\n\t}\n\n\toverride async hook(context: DrizzleGelHookContext<S3ExtMeta>) {\n\t\treturn context.stage === 'before' ? await this.hookBefore(context) : await this.hookAfter(context);\n\t}\n}\n\nexport function s3FileExt(client: S3Client | S3ClientConfig): DrizzleGelS3Extension {\n\treturn new DrizzleGelS3Extension(client);\n}\n"],"mappings":"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","names":["decoder"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';
|
|
2
|
+
import { entityKind } from "../../../entity.cjs";
|
|
3
|
+
import { DrizzleGelExtension, type DrizzleGelHookContext } from "../../../extension-core/gel/index.cjs";
|
|
4
|
+
import { extensionName } from "../../../extension-core/index.cjs";
|
|
5
|
+
import type { S3ExtMeta } from "../common.cjs";
|
|
6
|
+
export declare class DrizzleGelS3Extension extends DrizzleGelExtension<S3ExtMeta> {
|
|
7
|
+
static readonly [entityKind]: string;
|
|
8
|
+
static readonly [extensionName] = "Drizzle Gel S3 Extension";
|
|
9
|
+
private s3;
|
|
10
|
+
constructor(client: S3Client | S3ClientConfig);
|
|
11
|
+
private buildOutputMappingInstructions;
|
|
12
|
+
private buildRqbOutputMappingInstructions;
|
|
13
|
+
private buildParamMappingInstructions;
|
|
14
|
+
private hookBefore;
|
|
15
|
+
private hookAfter;
|
|
16
|
+
hook(context: DrizzleGelHookContext<S3ExtMeta>): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
export declare function s3FileExt(client: S3Client | S3ClientConfig): DrizzleGelS3Extension;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';
|
|
2
|
+
import { entityKind } from "../../../entity.js";
|
|
3
|
+
import { DrizzleGelExtension, type DrizzleGelHookContext } from "../../../extension-core/gel/index.js";
|
|
4
|
+
import { extensionName } from "../../../extension-core/index.js";
|
|
5
|
+
import type { S3ExtMeta } from "../common.js";
|
|
6
|
+
export declare class DrizzleGelS3Extension extends DrizzleGelExtension<S3ExtMeta> {
|
|
7
|
+
static readonly [entityKind]: string;
|
|
8
|
+
static readonly [extensionName] = "Drizzle Gel S3 Extension";
|
|
9
|
+
private s3;
|
|
10
|
+
constructor(client: S3Client | S3ClientConfig);
|
|
11
|
+
private buildOutputMappingInstructions;
|
|
12
|
+
private buildRqbOutputMappingInstructions;
|
|
13
|
+
private buildParamMappingInstructions;
|
|
14
|
+
private hookBefore;
|
|
15
|
+
private hookAfter;
|
|
16
|
+
hook(context: DrizzleGelHookContext<S3ExtMeta>): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
export declare function s3FileExt(client: S3Client | S3ClientConfig): DrizzleGelS3Extension;
|