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

utils.ts — drizzle-orm Source File

Architecture documentation for utils.ts, a typescript file in the drizzle-orm codebase. 4 imports, 4 dependents.

File typescript ValidationAdapters TypeMapping 4 imports 4 dependents 3 functions

Entity Profile

Dependency Diagram

graph LR
  0dcff89a_a60f_bf80_037e_d24dd39456e3["utils.ts"]
  56015c82_287b_9f6e_abba_3d7f471c1e5c["column.ts"]
  0dcff89a_a60f_bf80_037e_d24dd39456e3 --> 56015c82_287b_9f6e_abba_3d7f471c1e5c
  26760edf_9a0c_0204_77e6_f8bffa96e354["typebox"]
  0dcff89a_a60f_bf80_037e_d24dd39456e3 --> 26760edf_9a0c_0204_77e6_f8bffa96e354
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  0dcff89a_a60f_bf80_037e_d24dd39456e3 --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  53497908_16e7_977d_e97d_7414884a88a6["pg-core"]
  0dcff89a_a60f_bf80_037e_d24dd39456e3 --> 53497908_16e7_977d_e97d_7414884a88a6
  56015c82_287b_9f6e_abba_3d7f471c1e5c["column.ts"]
  56015c82_287b_9f6e_abba_3d7f471c1e5c --> 0dcff89a_a60f_bf80_037e_d24dd39456e3
  b348fe74_e713_8049_1ace_8787b971fb49["column.types.ts"]
  b348fe74_e713_8049_1ace_8787b971fb49 --> 0dcff89a_a60f_bf80_037e_d24dd39456e3
  8dacc372_d6d5_e273_f9e6_3a10af9bc4a7["schema.ts"]
  8dacc372_d6d5_e273_f9e6_3a10af9bc4a7 --> 0dcff89a_a60f_bf80_037e_d24dd39456e3
  224d090d_0385_ea0a_7fbe_57b37e55038e["schema.types.internal.ts"]
  224d090d_0385_ea0a_7fbe_57b37e55038e --> 0dcff89a_a60f_bf80_037e_d24dd39456e3
  style 0dcff89a_a60f_bf80_037e_d24dd39456e3 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import type { Kind, Static, TSchema } from '@sinclair/typebox';
import type { Column, SelectedFieldsFlat, Table, View } from 'drizzle-orm';
import type { PgEnum } from 'drizzle-orm/pg-core';
import type { literalSchema } from './column.ts';

export function isColumnType<T extends Column>(column: Column, columnTypes: string[]): column is T {
	return columnTypes.includes(column.columnType);
}

export function isWithEnum(column: Column): column is typeof column & { enumValues: [string, ...string[]] } {
	return 'enumValues' in column && Array.isArray(column.enumValues) && column.enumValues.length > 0;
}

export const isPgEnum: (entity: any) => entity is PgEnum<[string, ...string[]]> = isWithEnum as any;

type Literal = Static<typeof literalSchema>;
export type Json = Literal | { [key: string]: any } | any[];
export interface JsonSchema extends TSchema {
	[Kind]: 'Union';
	static: Json;
	anyOf: Json;
}
export interface BufferSchema extends TSchema {
	[Kind]: 'Buffer';
	static: Buffer;
	type: 'buffer';
}

export type IsNever<T> = [T] extends [never] ? true : false;

export type IsEnumDefined<TEnum extends string[] | undefined> = [string, ...string[]] extends TEnum ? false
	: undefined extends TEnum ? false
	: true;

export type ColumnIsGeneratedAlwaysAs<TColumn> = TColumn extends Column
	? TColumn['_']['identity'] extends 'always' ? true
	: TColumn['_']['generated'] extends { type: 'byDefault' } | undefined ? false
	: true
	: false;

export type GetSelection<T extends SelectedFieldsFlat<Column> | Table | View> = T extends Table ? T['_']['columns']
	: T extends View ? T['_']['selectedFields']
	: T;

Subdomains

Dependencies

Frequently Asked Questions

What does utils.ts do?
utils.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the ValidationAdapters domain, TypeMapping subdomain.
What functions are defined in utils.ts?
utils.ts defines 3 function(s): entity, isColumnType, isWithEnum.
What does utils.ts depend on?
utils.ts imports 4 module(s): column.ts, drizzle-orm, pg-core, typebox.
What files import utils.ts?
utils.ts is imported by 4 file(s): column.ts, column.types.ts, schema.ts, schema.types.internal.ts.
Where is utils.ts in the architecture?
utils.ts is located at drizzle-typebox/src/utils.ts (domain: ValidationAdapters, subdomain: TypeMapping, directory: drizzle-typebox/src).

Analyze Your Own Codebase

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

Try Supermodel Free