UNPKG

drizzle-orm

Version:

Drizzle ORM package for SQL databases

113 lines 4.38 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; 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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var driver_exports = {}; __export(driver_exports, { PostgresJsDatabase: () => PostgresJsDatabase, drizzle: () => drizzle }); module.exports = __toCommonJS(driver_exports); var import_postgres = __toESM(require("postgres"), 1); 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_relations = require("../relations.cjs"); var import_utils = require("../utils.cjs"); var import_session = require("./session.cjs"); class PostgresJsDatabase extends import_db.PgDatabase { static [import_entity.entityKind] = "PostgresJsDatabase"; } function construct(client, config = {}) { const transparentParser = (val) => val; for (const type of ["1184", "1082", "1083", "1114", "1182", "1185", "1115", "1231"]) { client.options.parsers[type] = transparentParser; client.options.serializers[type] = transparentParser; } client.options.serializers["114"] = transparentParser; client.options.serializers["3802"] = transparentParser; const dialect = new import_dialect.PgDialect({ 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.PostgresJsSession(client, dialect, schema, { logger }); const db = new PostgresJsDatabase(dialect, session, schema); db.$client = client; return db; } function drizzle(...params) { if (typeof params[0] === "string") { const instance = (0, import_postgres.default)(params[0]); return construct(instance, params[1]); } if ((0, import_utils.isConfig)(params[0])) { const { connection, client, ...drizzleConfig } = params[0]; if (client) return construct(client, drizzleConfig); if (typeof connection === "object" && connection.url !== void 0) { const { url, ...config } = connection; const instance2 = (0, import_postgres.default)(url, config); return construct(instance2, drizzleConfig); } const instance = (0, import_postgres.default)(connection); return construct(instance, drizzleConfig); } return construct(params[0], params[1]); } ((drizzle2) => { function mock(config) { return construct({ options: { parsers: {}, serializers: {} } }, config); } drizzle2.mock = mock; })(drizzle || (drizzle = {})); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { PostgresJsDatabase, drizzle }); //# sourceMappingURL=driver.cjs.map