UNPKG

drizzle-orm

Version:

Drizzle ORM package for SQL databases

58 lines 1.76 kB
import pg from "pg"; import { entityKind } from "../entity.js"; import { DefaultLogger } from "../logger.js"; import { PgDatabase } from "../pg-core/db.js"; import { PgDialect } from "../pg-core/dialect.js"; import { createTableRelationsHelpers, extractTablesRelationalConfig } from "../relations.js"; import { NodePgSession } from "./session.js"; const { types } = pg; class NodePgDriver { constructor(client, dialect, options = {}) { this.client = client; this.dialect = dialect; this.options = options; this.initMappers(); } static [entityKind] = "NodePgDriver"; createSession(schema) { return new NodePgSession(this.client, this.dialect, schema, { logger: this.options.logger }); } initMappers() { types.setTypeParser(types.builtins.TIMESTAMPTZ, (val) => val); types.setTypeParser(types.builtins.TIMESTAMP, (val) => val); types.setTypeParser(types.builtins.DATE, (val) => val); types.setTypeParser(types.builtins.INTERVAL, (val) => val); } } function drizzle(client, config = {}) { const dialect = new PgDialect(); let logger; if (config.logger === true) { logger = new DefaultLogger(); } else if (config.logger !== false) { logger = config.logger; } let schema; if (config.schema) { const tablesConfig = extractTablesRelationalConfig( config.schema, createTableRelationsHelpers ); schema = { fullSchema: config.schema, schema: tablesConfig.tables, tableNamesMap: tablesConfig.tableNamesMap }; } const driver = new NodePgDriver(client, dialect, { logger }); const session = driver.createSession(schema); return new PgDatabase(dialect, session, schema); } export { NodePgDriver, drizzle }; //# sourceMappingURL=driver.js.map