Home / File/ driver.ts — drizzle-orm Source File

driver.ts — drizzle-orm Source File

Architecture documentation for driver.ts, a typescript file in the drizzle-orm codebase. 9 imports, 2 dependents.

File typescript DrizzleORM SQLDialects 9 imports 2 dependents 3 functions 1 classes

Entity Profile

Dependency Diagram

graph LR
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a["driver.ts"]
  78995e64_a0d0_1533_378c_3e7415ac2520["session.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 78995e64_a0d0_1533_378c_3e7415ac2520
  8547eb9d_d783_00ed_fafd_5d4e77e8be54["SQLiteRemoteSession"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 8547eb9d_d783_00ed_fafd_5d4e77e8be54
  4dc3ba08_25aa_13fd_82c6_8802d5991d05["batch.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 4dc3ba08_25aa_13fd_82c6_8802d5991d05
  27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 27705a9d_afe9_57dd_8c97_e52d8a67d426
  220c512d_350b_24bf_2142_53ec35a980ac["logger.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 220c512d_350b_24bf_2142_53ec35a980ac
  e4d6a0ab_9aa2_13a6_a2f1_58d94314c3f2["relations.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> e4d6a0ab_9aa2_13a6_a2f1_58d94314c3f2
  3a0d0431_7555_f390_0d6a_8a596d3416a8["db.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 3a0d0431_7555_f390_0d6a_8a596d3416a8
  3d205d67_2ef4_984a_3241_ff4981527231["dialect.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> 3d205d67_2ef4_984a_3241_ff4981527231
  ecce3253_1e75_a87f_27b3_ca87e81a3024["utils.ts"]
  5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a --> ecce3253_1e75_a87f_27b3_ca87e81a3024
  b4ea4a73_2f21_2ebc_d7d0_3e4301b07007["migrator.ts"]
  b4ea4a73_2f21_2ebc_d7d0_3e4301b07007 --> 5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a
  78995e64_a0d0_1533_378c_3e7415ac2520["session.ts"]
  78995e64_a0d0_1533_378c_3e7415ac2520 --> 5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a
  style 5eb41267_daaa_4ab2_fd1c_fe0fdff5c37a fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import type { BatchItem, BatchResponse } from '~/batch.ts';
import { entityKind } from '~/entity.ts';
import { DefaultLogger } from '~/logger.ts';
import { createTableRelationsHelpers, extractTablesRelationalConfig } from '~/relations.ts';
import type { ExtractTablesWithRelations, RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';
import { BaseSQLiteDatabase } from '~/sqlite-core/db.ts';
import { SQLiteAsyncDialect } from '~/sqlite-core/dialect.ts';
import type { DrizzleConfig } from '~/utils.ts';
import { SQLiteRemoteSession } from './session.ts';

export interface SqliteRemoteResult<T = unknown> {
	rows?: T[];
}

export class SqliteRemoteDatabase<
	TSchema extends Record<string, unknown> = Record<string, never>,
> extends BaseSQLiteDatabase<'async', SqliteRemoteResult, TSchema> {
	static override readonly [entityKind]: string = 'SqliteRemoteDatabase';

	/** @internal */
	declare readonly session: SQLiteRemoteSession<TSchema, ExtractTablesWithRelations<TSchema>>;

	async batch<U extends BatchItem<'sqlite'>, T extends Readonly<[U, ...U[]]>>(
		batch: T,
	): Promise<BatchResponse<T>> {
		return this.session.batch(batch) as Promise<BatchResponse<T>>;
	}
}

export type AsyncRemoteCallback = (
	sql: string,
	params: any[],
	method: 'run' | 'all' | 'values' | 'get',
) => Promise<{ rows: any[] }>;

export type AsyncBatchRemoteCallback = (batch: {
	sql: string;
	params: any[];
	method: 'run' | 'all' | 'values' | 'get';
}[]) => Promise<{ rows: any[] }[]>;

export type RemoteCallback = AsyncRemoteCallback;

export function drizzle<TSchema extends Record<string, unknown> = Record<string, never>>(
	callback: RemoteCallback,
	config?: DrizzleConfig<TSchema>,
): SqliteRemoteDatabase<TSchema>;
export function drizzle<TSchema extends Record<string, unknown> = Record<string, never>>(
	callback: RemoteCallback,
	batchCallback?: AsyncBatchRemoteCallback,
	config?: DrizzleConfig<TSchema>,
): SqliteRemoteDatabase<TSchema>;
export function drizzle<TSchema extends Record<string, unknown> = Record<string, never>>(
	callback: RemoteCallback,
	batchCallback?: AsyncBatchRemoteCallback | DrizzleConfig<TSchema>,
	config?: DrizzleConfig<TSchema>,
): SqliteRemoteDatabase<TSchema> {
	const dialect = new SQLiteAsyncDialect({ casing: config?.casing });
	let logger;
	let cache;
	let _batchCallback: AsyncBatchRemoteCallback | undefined;
	let _config: DrizzleConfig<TSchema> = {};

	if (batchCallback) {
		if (typeof batchCallback === 'function') {
			_batchCallback = batchCallback as AsyncBatchRemoteCallback;
			_config = config ?? {};
		} else {
			_batchCallback = undefined;
			_config = batchCallback as DrizzleConfig<TSchema>;
		}

		if (_config.logger === true) {
			logger = new DefaultLogger();
		} else if (_config.logger !== false) {
			logger = _config.logger;
			cache = _config.cache;
		}
	}

	let schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;
	if (_config.schema) {
		const tablesConfig = extractTablesRelationalConfig(
			_config.schema,
			createTableRelationsHelpers,
		);
		schema = {
			fullSchema: _config.schema,
			schema: tablesConfig.tables,
			tableNamesMap: tablesConfig.tableNamesMap,
		};
	}

	const session = new SQLiteRemoteSession(callback, dialect, schema, _batchCallback, { logger, cache });
	const db = new SqliteRemoteDatabase('async', dialect, session, schema) as SqliteRemoteDatabase<TSchema>;
	(<any> db).$cache = cache;
	if ((<any> db).$cache) {
		(<any> db).$cache['invalidate'] = cache?.onMutate;
	}
	return db;
}

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does driver.ts do?
driver.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, SQLDialects subdomain.
What functions are defined in driver.ts?
driver.ts defines 3 function(s): batch, drizzle, sql.
What does driver.ts depend on?
driver.ts imports 9 module(s): SQLiteRemoteSession, batch.ts, db.ts, dialect.ts, entity.ts, logger.ts, relations.ts, session.ts, and 1 more.
What files import driver.ts?
driver.ts is imported by 2 file(s): migrator.ts, session.ts.
Where is driver.ts in the architecture?
driver.ts is located at drizzle-orm/src/sqlite-proxy/driver.ts (domain: DrizzleORM, subdomain: SQLDialects, directory: drizzle-orm/src/sqlite-proxy).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free