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

jsonb.ts — drizzle-orm Source File

Architecture documentation for jsonb.ts, a typescript file in the drizzle-orm codebase. 6 imports, 1 dependents.

File typescript DrizzleORM DatabaseDrivers 6 imports 1 dependents 1 functions 2 classes

Entity Profile

Dependency Diagram

graph LR
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918["jsonb.ts"]
  f4f42b4c_8610_03dd_fe01_232098668127["common.ts"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> f4f42b4c_8610_03dd_fe01_232098668127
  099d7c6d_2fc4_7b20_40e3_1b8af4138fe6["PgColumn"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> 099d7c6d_2fc4_7b20_40e3_1b8af4138fe6
  2dc784c6_95e9_4e28_ec81_7caf4acbd426["column-builder.ts"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> 2dc784c6_95e9_4e28_ec81_7caf4acbd426
  05f0a280_d0c9_693a_a4bf_83cc671012d2["column.ts"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> 05f0a280_d0c9_693a_a4bf_83cc671012d2
  27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> 27705a9d_afe9_57dd_8c97_e52d8a67d426
  17418917_ff81_c4e5_90f4_f37d557e5d51["table.ts"]
  2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 --> 17418917_ff81_c4e5_90f4_f37d557e5d51
  b38cf654_48d6_41dc_6c0f_203697984d98["all.ts"]
  b38cf654_48d6_41dc_6c0f_203697984d98 --> 2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918
  style 2fd2f2ae_d4e2_8ce0_f746_356ae2a2a918 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';
import type { ColumnBaseConfig } from '~/column.ts';
import { entityKind } from '~/entity.ts';
import type { AnyPgTable } from '~/pg-core/table.ts';
import { PgColumn, PgColumnBuilder } from './common.ts';

export type PgJsonbBuilderInitial<TName extends string> = PgJsonbBuilder<{
	name: TName;
	dataType: 'json';
	columnType: 'PgJsonb';
	data: unknown;
	driverParam: unknown;
	enumValues: undefined;
}>;

export class PgJsonbBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgJsonb'>> extends PgColumnBuilder<T> {
	static override readonly [entityKind]: string = 'PgJsonbBuilder';

	constructor(name: T['name']) {
		super(name, 'json', 'PgJsonb');
	}

	/** @internal */
	override build<TTableName extends string>(
		table: AnyPgTable<{ name: TTableName }>,
	): PgJsonb<MakeColumnConfig<T, TTableName>> {
		return new PgJsonb<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);
	}
}

export class PgJsonb<T extends ColumnBaseConfig<'json', 'PgJsonb'>> extends PgColumn<T> {
	static override readonly [entityKind]: string = 'PgJsonb';

	constructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgJsonbBuilder<T>['config']) {
		super(table, config);
	}

	getSQLType(): string {
		return 'jsonb';
	}

	override mapToDriverValue(value: T['data']): string {
		return JSON.stringify(value);
	}

	override mapFromDriverValue(value: T['data'] | string): T['data'] {
		if (typeof value === 'string') {
			try {
				return JSON.parse(value);
			} catch {
				return value as T['data'];
			}
		}
		return value;
	}
}

export function jsonb(): PgJsonbBuilderInitial<''>;
export function jsonb<TName extends string>(name: TName): PgJsonbBuilderInitial<TName>;
export function jsonb(name?: string) {
	return new PgJsonbBuilder(name ?? '');
}

Domain

Subdomains

Functions

Dependencies

Frequently Asked Questions

What does jsonb.ts do?
jsonb.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, DatabaseDrivers subdomain.
What functions are defined in jsonb.ts?
jsonb.ts defines 1 function(s): jsonb.
What does jsonb.ts depend on?
jsonb.ts imports 6 module(s): PgColumn, column-builder.ts, column.ts, common.ts, entity.ts, table.ts.
What files import jsonb.ts?
jsonb.ts is imported by 1 file(s): all.ts.
Where is jsonb.ts in the architecture?
jsonb.ts is located at drizzle-orm/src/pg-core/columns/jsonb.ts (domain: DrizzleORM, subdomain: DatabaseDrivers, directory: drizzle-orm/src/pg-core/columns).

Analyze Your Own Codebase

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

Try Supermodel Free