"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var driver_exports = {}; __export(driver_exports, { AwsDataApiPgDatabase: () => AwsDataApiPgDatabase, AwsPgDialect: () => AwsPgDialect, drizzle: () => drizzle }); module.exports = __toCommonJS(driver_exports); var import_client_rds_data = require("@aws-sdk/client-rds-data"); var import_entity = require("../../entity.cjs"); var import_logger = require("../../logger.cjs"); var import_db = require("../../pg-core/db.cjs"); var import_dialect = require("../../pg-core/dialect.cjs"); var import_pg_core = require("../../pg-core/index.cjs"); var import_relations = require("../../relations.cjs"); var import_sql = require("../../sql/sql.cjs"); var import_table = require("../../table.cjs"); var import_session = require("./session.cjs"); class AwsDataApiPgDatabase extends import_db.PgDatabase { static [import_entity.entityKind] = "AwsDataApiPgDatabase"; execute(query) { return super.execute(query); } } class AwsPgDialect extends import_dialect.PgDialect { static [import_entity.entityKind] = "AwsPgDialect"; escapeParam(num) { return `:${num + 1}`; } buildInsertQuery({ table, values, onConflict, returning, select, withList }) { const columns = table[import_table.Table.Symbol.Columns]; if (!select) { for (const value of values) { for (const fieldName of Object.keys(columns)) { const colValue = value[fieldName]; if ((0, import_entity.is)(colValue, import_sql.Param) && colValue.value !== void 0 && (0, import_entity.is)(colValue.encoder, import_pg_core.PgArray) && Array.isArray(colValue.value)) { value[fieldName] = import_sql.sql`cast(${colValue} as ${import_sql.sql.raw(colValue.encoder.getSQLType())})`; } } } } return super.buildInsertQuery({ table, values, onConflict, returning, withList }); } buildUpdateSet(table, set) { const columns = table[import_table.Table.Symbol.Columns]; for (const [colName, colValue] of Object.entries(set)) { const currentColumn = columns[colName]; if (currentColumn && (0, import_entity.is)(colValue, import_sql.Param) && colValue.value !== void 0 && (0, import_entity.is)(colValue.encoder, import_pg_core.PgArray) && Array.isArray(colValue.value)) { set[colName] = import_sql.sql`cast(${colValue} as ${import_sql.sql.raw(colValue.encoder.getSQLType())})`; } } return super.buildUpdateSet(table, set); } } function construct(client, config) { const dialect = new AwsPgDialect({ casing: config.casing }); let logger; if (config.logger === true) { logger = new import_logger.DefaultLogger(); } else if (config.logger !== false) { logger = config.logger; } let schema; if (config.schema) { const tablesConfig = (0, import_relations.extractTablesRelationalConfig)( config.schema, import_relations.createTableRelationsHelpers ); schema = { fullSchema: config.schema, schema: tablesConfig.tables, tableNamesMap: tablesConfig.tableNamesMap }; } const session = new import_session.AwsDataApiSession(client, dialect, schema, { ...config, logger }, void 0); const db = new AwsDataApiPgDatabase(dialect, session, schema); db.$client = client; return db; } function drizzle(...params) { if (params[0] instanceof import_client_rds_data.RDSDataClient) { return construct(params[0], params[1]); } if (params[0].client) { const { client, ...drizzleConfig2 } = params[0]; return construct(client, drizzleConfig2); } const { connection, ...drizzleConfig } = params[0]; const { resourceArn, database, secretArn, ...rdsConfig } = connection; const instance = new import_client_rds_data.RDSDataClient(rdsConfig); return construct(instance, { resourceArn, database, secretArn, ...drizzleConfig }); } ((drizzle2) => { function mock(config) { return construct({}, config); } drizzle2.mock = mock; })(drizzle || (drizzle = {})); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { AwsDataApiPgDatabase, AwsPgDialect, drizzle }); //# sourceMappingURL=driver.cjs.map