@mrnafisia/type-query 1.0.48 → 1.0.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/U.d.ts +2 -2
- package/dist/U.d.ts.map +1 -1
- package/dist/U.js +28 -27
- package/dist/U.js.map +1 -1
- package/dist/context.d.ts +987 -987
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +84 -85
- package/dist/context.js.map +1 -1
- package/dist/dictionary.d.ts +12 -12
- package/dist/dictionary.d.ts.map +1 -1
- package/dist/dictionary.js +179 -179
- package/dist/dictionary.js.map +1 -1
- package/dist/entity.d.ts +3585 -3585
- package/dist/entity.d.ts.map +1 -1
- package/dist/entity.js +1053 -1007
- package/dist/entity.js.map +1 -1
- package/dist/error.d.ts +4 -4
- package/dist/error.d.ts.map +1 -1
- package/dist/error.js +7 -6
- package/dist/error.js.map +1 -1
- package/dist/index.d.ts +18 -36
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +56 -60
- package/dist/index.js.map +1 -1
- package/dist/model.d.ts +1005 -1005
- package/dist/model.d.ts.map +1 -1
- package/dist/model.js +282 -282
- package/dist/model.js.map +1 -1
- package/dist/parser.d.ts +11 -11
- package/dist/parser.d.ts.map +1 -1
- package/dist/parser.js +120 -120
- package/dist/parser.js.map +1 -1
- package/dist/pool.d.ts +5 -5
- package/dist/pool.d.ts.map +1 -1
- package/dist/pool.js +122 -121
- package/dist/pool.js.map +1 -1
- package/dist/schema.d.ts +25 -25
- package/dist/schema.d.ts.map +1 -1
- package/dist/schema.js +405 -395
- package/dist/schema.js.map +1 -1
- package/dist/testUtil.d.ts +4 -4
- package/dist/testUtil.d.ts.map +1 -1
- package/dist/testUtil.js +343 -333
- package/dist/testUtil.js.map +1 -1
- package/dist/types/context.d.ts +51 -55
- package/dist/types/context.d.ts.map +1 -1
- package/dist/types/context.js +2 -2
- package/dist/types/entity.d.ts +70 -70
- package/dist/types/entity.d.ts.map +1 -1
- package/dist/types/entity.js +2 -2
- package/dist/types/json.d.ts +8 -8
- package/dist/types/json.d.ts.map +1 -1
- package/dist/types/json.js +2 -2
- package/dist/types/model.d.ts +23 -23
- package/dist/types/model.d.ts.map +1 -1
- package/dist/types/model.js +2 -2
- package/dist/types/pool.d.ts +18 -18
- package/dist/types/pool.d.ts.map +1 -1
- package/dist/types/pool.js +2 -2
- package/dist/types/postgres.d.ts +9 -9
- package/dist/types/postgres.d.ts.map +1 -1
- package/dist/types/postgres.js +2 -2
- package/dist/types/table.d.ts +233 -234
- package/dist/types/table.d.ts.map +1 -1
- package/dist/types/table.js +2 -2
- package/dist/types/testUtil.d.ts +26 -26
- package/dist/types/testUtil.d.ts.map +1 -1
- package/dist/types/testUtil.js +2 -2
- package/dist/utils.d.ts +67 -67
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +220 -220
- package/dist/utils.js.map +1 -1
- package/package.json +40 -39
package/dist/testUtil.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testUtil.js","sourceRoot":"","sources":["../src/testUtil.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"testUtil.js","sourceRoot":"","sources":["../src/testUtil.ts"],"names":[],"mappings":"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"}
|
package/dist/types/context.d.ts
CHANGED
|
@@ -1,56 +1,52 @@
|
|
|
1
|
-
import Decimal from 'decimal.js';
|
|
2
|
-
import type
|
|
3
|
-
import type {
|
|
4
|
-
import type { ColumnTypeByColumns } from './postgres';
|
|
5
|
-
import type { Expression, ValueExpression } from './entity';
|
|
6
|
-
type Context<Columns extends Table['columns']> = {
|
|
7
|
-
col: <columnKey extends keyof Columns & string>(column: columnKey, alias?: string) => ValueExpression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
8
|
-
colNull: <columnKey extends keyof Columns & string>(column: columnKey, op: null extends ColumnTypeByColumns<Columns, columnKey> ? NullOperator : never, alias?: string) => ValueExpression<boolean>;
|
|
9
|
-
colBool: <columnKey extends keyof Columns & string>(column: columnKey, op: boolean extends ColumnTypeByColumns<Columns, columnKey> ? BooleanOperator : never, alias?: string) => ValueExpression<boolean>;
|
|
10
|
-
colCmp: <columnKey extends keyof Columns & string>(column: columnKey, op: CompareOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, CompareOperator, never>, v: Expression<ColumnTypeByColumns<Columns, columnKey>>, alias?: string) => ValueExpression<boolean>;
|
|
11
|
-
colList: <columnKey extends keyof Columns & string>(column: columnKey, op: ListOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, ListOperator, never>, v: readonly Expression<ColumnTypeByColumns<Columns, columnKey>>[] | undefined, alias?: string) => ValueExpression<boolean>;
|
|
12
|
-
colLike: <columnKey extends keyof Columns & string, Op extends
|
|
13
|
-
colJson: <columnKey extends keyof Columns & string, Op extends
|
|
14
|
-
colsAnd: ContextScope<Columns>;
|
|
15
|
-
colsOr: ContextScope<Columns>;
|
|
16
|
-
};
|
|
17
|
-
type ContextScope<Columns extends Table['columns']> = (rules: {
|
|
18
|
-
[columnKey in keyof Columns]?: [
|
|
19
|
-
op:
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
type
|
|
46
|
-
type
|
|
47
|
-
type
|
|
48
|
-
type
|
|
49
|
-
type
|
|
50
|
-
type
|
|
51
|
-
type
|
|
52
|
-
type LikeOperator = 'like' | 'like all' | 'like some';
|
|
53
|
-
type JsonOperator = '?' | '@>' | '<@' | '?|' | '?&';
|
|
54
|
-
export type { Context, CompareOperatorCompatible, ListOperatorCompatible, ContextScope };
|
|
55
|
-
export type { ArithmeticOperator, NullOperator, BooleanOperator, CompareOperator, ListOperator, LikeOperator, JsonOperator };
|
|
1
|
+
import Decimal from 'decimal.js';
|
|
2
|
+
import type { JSON } from './json';
|
|
3
|
+
import type { Table } from './table';
|
|
4
|
+
import type { ColumnTypeByColumns } from './postgres';
|
|
5
|
+
import type { Expression, ValueExpression } from './entity';
|
|
6
|
+
type Context<Columns extends Table['columns']> = {
|
|
7
|
+
col: <columnKey extends keyof Columns & string>(column: columnKey, alias?: string) => ValueExpression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
8
|
+
colNull: <columnKey extends keyof Columns & string>(column: columnKey, op: null extends ColumnTypeByColumns<Columns, columnKey> ? NullOperator : never, alias?: string) => ValueExpression<boolean>;
|
|
9
|
+
colBool: <columnKey extends keyof Columns & string>(column: columnKey, op: boolean extends ColumnTypeByColumns<Columns, columnKey> ? BooleanOperator : never, alias?: string) => ValueExpression<boolean>;
|
|
10
|
+
colCmp: <columnKey extends keyof Columns & string>(column: columnKey, op: CompareOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, CompareOperator, never>, v: Expression<ColumnTypeByColumns<Columns, columnKey>>, alias?: string) => ValueExpression<boolean>;
|
|
11
|
+
colList: <columnKey extends keyof Columns & string>(column: columnKey, op: ListOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, ListOperator, never>, v: readonly Expression<ColumnTypeByColumns<Columns, columnKey>>[] | undefined, alias?: string) => ValueExpression<boolean>;
|
|
12
|
+
colLike: <columnKey extends keyof Columns & string, Op extends string extends ColumnTypeByColumns<Columns, columnKey> ? LikeOperator : never>(column: columnKey, op: Op, v: Op extends 'like' ? Expression<ColumnTypeByColumns<Columns, columnKey>> : readonly Expression<ColumnTypeByColumns<Columns, columnKey>>[] | undefined, alias?: string) => ValueExpression<boolean>;
|
|
13
|
+
colJson: <columnKey extends keyof Columns & string, Op extends JSON extends ColumnTypeByColumns<Columns, columnKey> ? JsonOperator : never>(column: columnKey, op: Op, v: Op extends '@>' | '<@' ? Expression<ColumnTypeByColumns<Columns, columnKey>> : Op extends '?' ? Expression<string> : Op extends '?&' | '?|' ? readonly Expression<string>[] | undefined : never, alias?: string) => ValueExpression<boolean>;
|
|
14
|
+
colsAnd: ContextScope<Columns>;
|
|
15
|
+
colsOr: ContextScope<Columns>;
|
|
16
|
+
};
|
|
17
|
+
type ContextScope<Columns extends Table['columns']> = (rules: {
|
|
18
|
+
[columnKey in keyof Columns]?: [op: null extends ColumnTypeByColumns<Columns, columnKey> ? NullOperator : never] | [op: ColumnTypeByColumns<Columns, columnKey> extends boolean ? BooleanOperator : never] | [
|
|
19
|
+
op: CompareOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, CompareOperator, never>,
|
|
20
|
+
v: Expression<ColumnTypeByColumns<Columns, columnKey>>
|
|
21
|
+
] | [
|
|
22
|
+
op: ListOperatorCompatible<ColumnTypeByColumns<Columns, columnKey>, ListOperator, never>,
|
|
23
|
+
v: readonly Expression<ColumnTypeByColumns<Columns, columnKey>>[] | undefined
|
|
24
|
+
] | [
|
|
25
|
+
op: Extract<LikeOperator, 'like'>,
|
|
26
|
+
v: ColumnTypeByColumns<Columns, columnKey> extends string ? Expression<ColumnTypeByColumns<Columns, columnKey>> : never
|
|
27
|
+
] | [
|
|
28
|
+
op: Extract<LikeOperator, 'like some' | 'like all'>,
|
|
29
|
+
v: ColumnTypeByColumns<Columns, columnKey> extends string ? readonly Expression<ColumnTypeByColumns<Columns, columnKey>>[] | undefined : never
|
|
30
|
+
] | [
|
|
31
|
+
op: Extract<JsonOperator, '@>' | '<@'>,
|
|
32
|
+
v: ColumnTypeByColumns<Columns, columnKey> extends JSON ? Expression<ColumnTypeByColumns<Columns, columnKey>> : never
|
|
33
|
+
] | [
|
|
34
|
+
op: Extract<JsonOperator, '?'>,
|
|
35
|
+
v: ColumnTypeByColumns<Columns, columnKey> extends JSON ? Expression<string> : never
|
|
36
|
+
] | [
|
|
37
|
+
op: Extract<JsonOperator, '?&' | '?|'>,
|
|
38
|
+
v: ColumnTypeByColumns<Columns, columnKey> extends JSON ? readonly Expression<string>[] | undefined : never
|
|
39
|
+
];
|
|
40
|
+
}, alias?: string) => ValueExpression<boolean>;
|
|
41
|
+
type CompareOperatorCompatible<T, True, False> = number extends T ? True : bigint extends T ? True : Decimal extends T ? True : string extends T ? True : Date extends T ? True : False;
|
|
42
|
+
type ListOperatorCompatible<T, True, False> = number extends T ? True : bigint extends T ? True : Decimal extends T ? True : string extends T ? True : Date extends T ? True : False;
|
|
43
|
+
type ArithmeticOperator = '+' | '-' | '*' | '/' | '**';
|
|
44
|
+
type NullOperator = '= null' | '!= null';
|
|
45
|
+
type BooleanOperator = '= true' | '= false';
|
|
46
|
+
type CompareOperator = '=' | '!=' | '>' | '>=' | '<' | '<=';
|
|
47
|
+
type ListOperator = 'in' | 'not in';
|
|
48
|
+
type LikeOperator = 'like' | 'like all' | 'like some';
|
|
49
|
+
type JsonOperator = '?' | '@>' | '<@' | '?|' | '?&';
|
|
50
|
+
export type { Context, CompareOperatorCompatible, ListOperatorCompatible, ContextScope };
|
|
51
|
+
export type { ArithmeticOperator, NullOperator, BooleanOperator, CompareOperator, ListOperator, LikeOperator, JsonOperator };
|
|
56
52
|
//# sourceMappingURL=context.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/types/context.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AACjC,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/types/context.ts"],"names":[],"mappings":"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"}
|
package/dist/types/context.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=context.js.map
|
package/dist/types/entity.d.ts
CHANGED
|
@@ -1,71 +1,71 @@
|
|
|
1
|
-
import { JSON } from './json';
|
|
2
|
-
import Decimal from 'decimal.js';
|
|
3
|
-
import type Table from './table';
|
|
4
|
-
import { Context } from './context';
|
|
5
|
-
import type { ClientBase } from 'pg';
|
|
6
|
-
import type { Result } from 'never-catch';
|
|
7
|
-
import type { ColumnTypeByColumns } from './postgres';
|
|
8
|
-
type JoinType = 'inner' | 'left' | 'right' | 'full';
|
|
9
|
-
type Param = number | bigint | string;
|
|
10
|
-
type QueryData = {
|
|
11
|
-
sql: string;
|
|
12
|
-
params: Param[];
|
|
13
|
-
};
|
|
14
|
-
type TableWithAlias = {
|
|
15
|
-
table: Table;
|
|
16
|
-
alias: string;
|
|
17
|
-
};
|
|
18
|
-
type JoinData = {
|
|
19
|
-
joinType: JoinType;
|
|
20
|
-
on: Expression<boolean> | ((contexts: {
|
|
21
|
-
[k: string]: Context<Table['columns']>;
|
|
22
|
-
}) => Expression<boolean>);
|
|
23
|
-
};
|
|
24
|
-
type Mode = [] | ['count', number] | ['get', 'one' | number];
|
|
25
|
-
type CustomColumn<Exp extends Expression<ExpressionTypes>, As extends string> = {
|
|
26
|
-
exp: Exp;
|
|
27
|
-
as: As;
|
|
28
|
-
};
|
|
29
|
-
type NullableAndDefaultColumns<Columns extends Table['columns']> = {
|
|
30
|
-
[columnKey in keyof Columns as true extends Columns[columnKey]['nullable'] ? columnKey : false extends Columns[columnKey]['default'] ? never : columnKey]: true extends Columns[columnKey]['nullable'] ? Columns[columnKey] : false extends Columns[columnKey]['default'] ? never : Columns[columnKey];
|
|
31
|
-
};
|
|
32
|
-
type AliasedColumns<Columns extends Table['columns'], Alias extends string> = {
|
|
33
|
-
[key in keyof Columns as `${Alias}_${key & string}`]: Columns[key];
|
|
34
|
-
};
|
|
35
|
-
type TablesColumnsKeys<Tables extends {
|
|
36
|
-
[key: string]: Table;
|
|
37
|
-
}> = {
|
|
38
|
-
[tableKey in keyof Tables & string]: `${tableKey}_${keyof Tables[tableKey]['columns'] & string}`;
|
|
39
|
-
}[keyof {
|
|
40
|
-
[tableKey in keyof Tables & string]: undefined;
|
|
41
|
-
}];
|
|
42
|
-
type ExpressionTypes = null | boolean | number | bigint | Decimal | string | Date | JSON;
|
|
43
|
-
type Expression<ExpType extends ExpressionTypes> = ExpType | undefined | ValueExpression<ExpType> | QueryExpression<ExpType>;
|
|
44
|
-
type ValueExpression<ExpType extends ExpressionTypes> = ['val', ExpType | undefined];
|
|
45
|
-
type QueryExpression<ExpType extends ExpressionTypes> = ['qry', ExpType];
|
|
46
|
-
type InsertValue<Columns extends Table['columns'], NullableAndDefaultCols extends readonly (keyof NullableAndDefaultColumns<Columns>)[]> = {
|
|
47
|
-
[columnKey in Exclude<keyof Columns, keyof NullableAndDefaultColumns<Columns>>]: Expression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
48
|
-
} & {
|
|
49
|
-
[columnKey in Exclude<keyof NullableAndDefaultCols, keyof unknown[]> as NullableAndDefaultCols[columnKey] & string]?: Expression<ColumnTypeByColumns<Columns, NullableAndDefaultCols[columnKey] & string>>;
|
|
50
|
-
};
|
|
51
|
-
type UpdateSets<Columns extends Table['columns']> = {
|
|
52
|
-
[columnKey in keyof Columns & string]?: Expression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
53
|
-
};
|
|
54
|
-
type Query<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[]> = {
|
|
55
|
-
getData: (params?: Param[]) => Result<QueryData, string>;
|
|
56
|
-
exec: <M extends Mode>(client: ClientBase, mode: M, params?: Param[]) => Promise<Result<QueryResult<Columns, Returning, M>, unknown>>;
|
|
57
|
-
};
|
|
58
|
-
type QueryResult<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[], M extends Mode> = M extends ['get', 'one'] ? QueryResultRow<Columns, Returning> : M extends ['get', number] | [] ? QueryResultRow<Columns, Returning>[] : M extends ['count', number] ? undefined : never;
|
|
59
|
-
type QueryResultRow<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[]> = {
|
|
60
|
-
[key in Exclude<keyof Returning, keyof unknown[]> as Returning[key] extends CustomColumn<Expression<ExpressionTypes>, infer As> ? As : Returning[key] & string]: Returning[key] extends CustomColumn<infer Exp, string> ? Exp extends Expression<infer ExpType> ? ExpType : Exp : ColumnTypeByColumns<Columns, Returning[key] & keyof Columns>;
|
|
61
|
-
};
|
|
62
|
-
type PartialQuery = {
|
|
63
|
-
text: string;
|
|
64
|
-
params: Param[];
|
|
65
|
-
};
|
|
66
|
-
export type { JoinType, Param, QueryData, TableWithAlias, JoinData, Mode };
|
|
67
|
-
export type { CustomColumn, NullableAndDefaultColumns, AliasedColumns, TablesColumnsKeys };
|
|
68
|
-
export type { ExpressionTypes, Expression, ValueExpression, QueryExpression };
|
|
69
|
-
export type { InsertValue, UpdateSets };
|
|
70
|
-
export type { Query, QueryResult, QueryResultRow, PartialQuery };
|
|
1
|
+
import { JSON } from './json';
|
|
2
|
+
import Decimal from 'decimal.js';
|
|
3
|
+
import type { Table } from './table';
|
|
4
|
+
import { Context } from './context';
|
|
5
|
+
import type { ClientBase } from 'pg';
|
|
6
|
+
import type { Result } from 'never-catch';
|
|
7
|
+
import type { ColumnTypeByColumns } from './postgres';
|
|
8
|
+
type JoinType = 'inner' | 'left' | 'right' | 'full';
|
|
9
|
+
type Param = number | bigint | string;
|
|
10
|
+
type QueryData = {
|
|
11
|
+
sql: string;
|
|
12
|
+
params: Param[];
|
|
13
|
+
};
|
|
14
|
+
type TableWithAlias = {
|
|
15
|
+
table: Table;
|
|
16
|
+
alias: string;
|
|
17
|
+
};
|
|
18
|
+
type JoinData = {
|
|
19
|
+
joinType: JoinType;
|
|
20
|
+
on: Expression<boolean> | ((contexts: {
|
|
21
|
+
[k: string]: Context<Table['columns']>;
|
|
22
|
+
}) => Expression<boolean>);
|
|
23
|
+
};
|
|
24
|
+
type Mode = [] | ['count', number] | ['get', 'one' | number];
|
|
25
|
+
type CustomColumn<Exp extends Expression<ExpressionTypes>, As extends string> = {
|
|
26
|
+
exp: Exp;
|
|
27
|
+
as: As;
|
|
28
|
+
};
|
|
29
|
+
type NullableAndDefaultColumns<Columns extends Table['columns']> = {
|
|
30
|
+
[columnKey in keyof Columns as true extends Columns[columnKey]['nullable'] ? columnKey : false extends Columns[columnKey]['default'] ? never : columnKey]: true extends Columns[columnKey]['nullable'] ? Columns[columnKey] : false extends Columns[columnKey]['default'] ? never : Columns[columnKey];
|
|
31
|
+
};
|
|
32
|
+
type AliasedColumns<Columns extends Table['columns'], Alias extends string> = {
|
|
33
|
+
[key in keyof Columns as `${Alias}_${key & string}`]: Columns[key];
|
|
34
|
+
};
|
|
35
|
+
type TablesColumnsKeys<Tables extends {
|
|
36
|
+
[key: string]: Table;
|
|
37
|
+
}> = {
|
|
38
|
+
[tableKey in keyof Tables & string]: `${tableKey}_${keyof Tables[tableKey]['columns'] & string}`;
|
|
39
|
+
}[keyof {
|
|
40
|
+
[tableKey in keyof Tables & string]: undefined;
|
|
41
|
+
}];
|
|
42
|
+
type ExpressionTypes = null | boolean | number | bigint | Decimal | string | Date | JSON;
|
|
43
|
+
type Expression<ExpType extends ExpressionTypes> = ExpType | undefined | ValueExpression<ExpType> | QueryExpression<ExpType>;
|
|
44
|
+
type ValueExpression<ExpType extends ExpressionTypes> = ['val', ExpType | undefined];
|
|
45
|
+
type QueryExpression<ExpType extends ExpressionTypes> = ['qry', ExpType];
|
|
46
|
+
type InsertValue<Columns extends Table['columns'], NullableAndDefaultCols extends readonly (keyof NullableAndDefaultColumns<Columns>)[]> = {
|
|
47
|
+
[columnKey in Exclude<keyof Columns, keyof NullableAndDefaultColumns<Columns>>]: Expression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
48
|
+
} & {
|
|
49
|
+
[columnKey in Exclude<keyof NullableAndDefaultCols, keyof unknown[]> as NullableAndDefaultCols[columnKey] & string]?: Expression<ColumnTypeByColumns<Columns, NullableAndDefaultCols[columnKey] & string>>;
|
|
50
|
+
};
|
|
51
|
+
type UpdateSets<Columns extends Table['columns']> = {
|
|
52
|
+
[columnKey in keyof Columns & string]?: Expression<ColumnTypeByColumns<Columns, columnKey>>;
|
|
53
|
+
};
|
|
54
|
+
type Query<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[]> = {
|
|
55
|
+
getData: (params?: Param[]) => Result<QueryData, string>;
|
|
56
|
+
exec: <M extends Mode>(client: ClientBase, mode: M, params?: Param[]) => Promise<Result<QueryResult<Columns, Returning, M>, unknown>>;
|
|
57
|
+
};
|
|
58
|
+
type QueryResult<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[], M extends Mode> = M extends ['get', 'one'] ? QueryResultRow<Columns, Returning> : M extends ['get', number] | [] ? QueryResultRow<Columns, Returning>[] : M extends ['count', number] ? undefined : never;
|
|
59
|
+
type QueryResultRow<Columns extends Table['columns'], Returning extends readonly (keyof Columns | CustomColumn<Expression<ExpressionTypes>, string>)[]> = {
|
|
60
|
+
[key in Exclude<keyof Returning, keyof unknown[]> as Returning[key] extends CustomColumn<Expression<ExpressionTypes>, infer As> ? As : Returning[key] & string]: Returning[key] extends CustomColumn<infer Exp, string> ? Exp extends Expression<infer ExpType> ? ExpType : Exp : ColumnTypeByColumns<Columns, Returning[key] & keyof Columns>;
|
|
61
|
+
};
|
|
62
|
+
type PartialQuery = {
|
|
63
|
+
text: string;
|
|
64
|
+
params: Param[];
|
|
65
|
+
};
|
|
66
|
+
export type { JoinType, Param, QueryData, TableWithAlias, JoinData, Mode };
|
|
67
|
+
export type { CustomColumn, NullableAndDefaultColumns, AliasedColumns, TablesColumnsKeys };
|
|
68
|
+
export type { ExpressionTypes, Expression, ValueExpression, QueryExpression };
|
|
69
|
+
export type { InsertValue, UpdateSets };
|
|
70
|
+
export type { Query, QueryResult, QueryResultRow, PartialQuery };
|
|
71
71
|
//# sourceMappingURL=entity.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../src/types/entity.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../src/types/entity.ts"],"names":[],"mappings":"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"}
|
package/dist/types/entity.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=entity.js.map
|
package/dist/types/json.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import Decimal from 'decimal.js';
|
|
2
|
-
type JSON = JsonObject | JsonArray;
|
|
3
|
-
type JsonObject = {
|
|
4
|
-
[key: string]: BaseJsonValue;
|
|
5
|
-
};
|
|
6
|
-
type JsonArray = BaseJsonValue[];
|
|
7
|
-
type BaseJsonValue = null | boolean | number | bigint | Decimal | string | Date | JsonObject | JsonArray;
|
|
8
|
-
export type { JSON, JsonObject, JsonArray, BaseJsonValue };
|
|
1
|
+
import Decimal from 'decimal.js';
|
|
2
|
+
type JSON = JsonObject | JsonArray;
|
|
3
|
+
type JsonObject = {
|
|
4
|
+
[key: string]: BaseJsonValue;
|
|
5
|
+
};
|
|
6
|
+
type JsonArray = BaseJsonValue[];
|
|
7
|
+
type BaseJsonValue = null | boolean | number | bigint | Decimal | string | Date | JsonObject | JsonArray;
|
|
8
|
+
export type { JSON, JsonObject, JsonArray, BaseJsonValue };
|
|
9
9
|
//# sourceMappingURL=json.d.ts.map
|
package/dist/types/json.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../src/types/json.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AAEjC,KAAK,IAAI,GAAG,UAAU,GAAG,SAAS,CAAC;AACnC,KAAK,UAAU,GAAG;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa,CAAA;CAAE,CAAC;AACnD,KAAK,SAAS,GAAG,aAAa,EAAE,CAAC;AACjC,KAAK,aAAa,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../src/types/json.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AAEjC,KAAK,IAAI,GAAG,UAAU,GAAG,SAAS,CAAC;AACnC,KAAK,UAAU,GAAG;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa,CAAA;CAAE,CAAC;AACnD,KAAK,SAAS,GAAG,aAAa,EAAE,CAAC;AACjC,KAAK,aAAa,GAAG,IAAI,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,IAAI,GAAG,UAAU,GAAG,SAAS,CAAC;AAEzG,YAAY,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC"}
|
package/dist/types/json.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=json.js.map
|
package/dist/types/model.d.ts
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import type Table from './table';
|
|
2
|
-
import type { ColumnTypeByColumns } from './postgres';
|
|
3
|
-
import { Result } from
|
|
4
|
-
type SimpleModel<Columns extends Table['columns']> = {
|
|
5
|
-
[col in keyof Columns & string]: ColumnTypeByColumns<Columns, col>;
|
|
6
|
-
};
|
|
7
|
-
type Model<Columns extends Table['columns'], Requires extends readonly (keyof Columns)[], Optionals extends readonly (keyof Columns)[]> = {
|
|
8
|
-
[key in Exclude<keyof Requires, keyof unknown[]> as Requires[key] & string]: ColumnTypeByColumns<Columns, Requires[key] & keyof Columns>;
|
|
9
|
-
} & {
|
|
10
|
-
[key in Exclude<keyof Optionals, keyof unknown[]> as Optionals[key] & string]?: ColumnTypeByColumns<Columns, Optionals[key] & keyof Columns>;
|
|
11
|
-
};
|
|
12
|
-
type ModelUtils<Columns extends Table['columns']> = {
|
|
13
|
-
Parse: <Requires extends readonly (keyof Columns)[], Optionals extends readonly (keyof Columns)[]>(data: {
|
|
14
|
-
[key: string]: unknown;
|
|
15
|
-
}, requires: Requires, optional: Optionals, validate?: boolean) => Result<Model<Columns, Requires, Optionals>, Requires[Exclude<keyof Requires, keyof unknown[]>] | Optionals[Exclude<keyof Optionals, keyof unknown[]>]>;
|
|
16
|
-
Validate: <D extends Partial<SimpleModel<Columns>>>(data: D) => Result<undefined, keyof D>;
|
|
17
|
-
} & {
|
|
18
|
-
[key in keyof Columns]: {
|
|
19
|
-
Parse: (v: unknown, validate?: boolean) => ColumnTypeByColumns<Columns, key> | undefined;
|
|
20
|
-
Validate: (v: ColumnTypeByColumns<Columns, key>) => boolean;
|
|
21
|
-
};
|
|
22
|
-
};
|
|
23
|
-
export type { SimpleModel, Model, ModelUtils };
|
|
1
|
+
import type { Table } from './table';
|
|
2
|
+
import type { ColumnTypeByColumns } from './postgres';
|
|
3
|
+
import { Result } from 'never-catch';
|
|
4
|
+
type SimpleModel<Columns extends Table['columns']> = {
|
|
5
|
+
[col in keyof Columns & string]: ColumnTypeByColumns<Columns, col>;
|
|
6
|
+
};
|
|
7
|
+
type Model<Columns extends Table['columns'], Requires extends readonly (keyof Columns)[], Optionals extends readonly (keyof Columns)[]> = {
|
|
8
|
+
[key in Exclude<keyof Requires, keyof unknown[]> as Requires[key] & string]: ColumnTypeByColumns<Columns, Requires[key] & keyof Columns>;
|
|
9
|
+
} & {
|
|
10
|
+
[key in Exclude<keyof Optionals, keyof unknown[]> as Optionals[key] & string]?: ColumnTypeByColumns<Columns, Optionals[key] & keyof Columns>;
|
|
11
|
+
};
|
|
12
|
+
type ModelUtils<Columns extends Table['columns']> = {
|
|
13
|
+
Parse: <Requires extends readonly (keyof Columns)[], Optionals extends readonly (keyof Columns)[]>(data: {
|
|
14
|
+
[key: string]: unknown;
|
|
15
|
+
}, requires: Requires, optional: Optionals, validate?: boolean) => Result<Model<Columns, Requires, Optionals>, Requires[Exclude<keyof Requires, keyof unknown[]>] | Optionals[Exclude<keyof Optionals, keyof unknown[]>]>;
|
|
16
|
+
Validate: <D extends Partial<SimpleModel<Columns>>>(data: D) => Result<undefined, keyof D>;
|
|
17
|
+
} & {
|
|
18
|
+
[key in keyof Columns]: {
|
|
19
|
+
Parse: (v: unknown, validate?: boolean) => ColumnTypeByColumns<Columns, key> | undefined;
|
|
20
|
+
Validate: (v: ColumnTypeByColumns<Columns, key>) => boolean;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
export type { SimpleModel, Model, ModelUtils };
|
|
24
24
|
//# sourceMappingURL=model.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../src/types/model.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../src/types/model.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,KAAK,WAAW,CAAC,OAAO,SAAS,KAAK,CAAC,SAAS,CAAC,IAAI;KAChD,GAAG,IAAI,MAAM,OAAO,GAAG,MAAM,GAAG,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC;CACrE,CAAC;AAEF,KAAK,KAAK,CACN,OAAO,SAAS,KAAK,CAAC,SAAS,CAAC,EAChC,QAAQ,SAAS,SAAS,CAAC,MAAM,OAAO,CAAC,EAAE,EAC3C,SAAS,SAAS,SAAS,CAAC,MAAM,OAAO,CAAC,EAAE,IAC5C;KACC,GAAG,IAAI,OAAO,CAAC,MAAM,QAAQ,EAAE,MAAM,OAAO,EAAE,CAAC,IAAI,QAAQ,CAAC,GAAG,CAAC,GAAG,MAAM,GAAG,mBAAmB,CAC5F,OAAO,EACP,QAAQ,CAAC,GAAG,CAAC,GAAG,MAAM,OAAO,CAChC;CACJ,GAAG;KACC,GAAG,IAAI,OAAO,CAAC,MAAM,SAAS,EAAE,MAAM,OAAO,EAAE,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,mBAAmB,CAC/F,OAAO,EACP,SAAS,CAAC,GAAG,CAAC,GAAG,MAAM,OAAO,CACjC;CACJ,CAAC;AAEF,KAAK,UAAU,CAAC,OAAO,SAAS,KAAK,CAAC,SAAS,CAAC,IAAI;IAChD,KAAK,EAAE,CAAC,QAAQ,SAAS,SAAS,CAAC,MAAM,OAAO,CAAC,EAAE,EAAE,SAAS,SAAS,SAAS,CAAC,MAAM,OAAO,CAAC,EAAE,EAC7F,IAAI,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,EAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,SAAS,EACnB,QAAQ,CAAC,EAAE,OAAO,KACjB,MAAM,CACP,KAAK,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC,EACnC,QAAQ,CAAC,OAAO,CAAC,MAAM,QAAQ,EAAE,MAAM,OAAO,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,SAAS,EAAE,MAAM,OAAO,EAAE,CAAC,CAAC,CAC5G,CAAC;IACF,QAAQ,EAAE,CAAC,CAAC,SAAS,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;CAC9F,GAAG;KACC,GAAG,IAAI,MAAM,OAAO,GAAG;QACpB,KAAK,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,OAAO,KAAK,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC;QACzF,QAAQ,EAAE,CAAC,CAAC,EAAE,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC,KAAK,OAAO,CAAC;KAC/D;CACJ,CAAC;AAEF,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC"}
|
package/dist/types/model.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=model.js.map
|
package/dist/types/pool.d.ts
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { Param } from './entity';
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
type TransactionIsolationLevel = 'read-uncommitted' | 'read-committed' | 'repeatable-read' | 'serializable';
|
|
5
|
-
type Pool = {
|
|
6
|
-
$: PgPool;
|
|
7
|
-
transaction: <R extends Result<unknown, unknown>>(callback: (client: PoolClient) => Promise<R>, isolationLevel?: TransactionIsolationLevel, readOnly?: boolean) => Promise<R>;
|
|
8
|
-
};
|
|
9
|
-
type OnSendQueryHook = (query: string, params: Param[]) => void;
|
|
10
|
-
type AddHook = (hookAndEvent: {
|
|
11
|
-
event: 'on-send-query';
|
|
12
|
-
hook: OnSendQueryHook;
|
|
13
|
-
}) => void;
|
|
14
|
-
type RemoveHook = (hookAndEvent: {
|
|
15
|
-
event: 'on-send-query';
|
|
16
|
-
hook: OnSendQueryHook;
|
|
17
|
-
}) => void;
|
|
18
|
-
export type { TransactionIsolationLevel, Pool, OnSendQueryHook, AddHook, RemoveHook };
|
|
1
|
+
import { Param } from './entity';
|
|
2
|
+
import { Result } from 'never-catch';
|
|
3
|
+
import type { Pool as PgPool, PoolClient } from 'pg';
|
|
4
|
+
type TransactionIsolationLevel = 'read-uncommitted' | 'read-committed' | 'repeatable-read' | 'serializable';
|
|
5
|
+
type Pool = {
|
|
6
|
+
$: PgPool;
|
|
7
|
+
transaction: <R extends Result<unknown, unknown>>(callback: (client: PoolClient) => Promise<R>, isolationLevel?: TransactionIsolationLevel, readOnly?: boolean) => Promise<R>;
|
|
8
|
+
};
|
|
9
|
+
type OnSendQueryHook = (query: string, params: Param[]) => void;
|
|
10
|
+
type AddHook = (hookAndEvent: {
|
|
11
|
+
event: 'on-send-query';
|
|
12
|
+
hook: OnSendQueryHook;
|
|
13
|
+
}) => void;
|
|
14
|
+
type RemoveHook = (hookAndEvent: {
|
|
15
|
+
event: 'on-send-query';
|
|
16
|
+
hook: OnSendQueryHook;
|
|
17
|
+
}) => void;
|
|
18
|
+
export type { TransactionIsolationLevel, Pool, OnSendQueryHook, AddHook, RemoveHook };
|
|
19
19
|
//# sourceMappingURL=pool.d.ts.map
|
package/dist/types/pool.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pool.d.ts","sourceRoot":"","sources":["../../src/types/pool.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"pool.d.ts","sourceRoot":"","sources":["../../src/types/pool.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,KAAK,EAAE,IAAI,IAAI,MAAM,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAErD,KAAK,yBAAyB,GAAG,kBAAkB,GAAG,gBAAgB,GAAG,iBAAiB,GAAG,cAAc,CAAC;AAE5G,KAAK,IAAI,GAAG;IACR,CAAC,EAAE,MAAM,CAAC;IACV,WAAW,EAAE,CAAC,CAAC,SAAS,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,EAC5C,QAAQ,EAAE,CAAC,MAAM,EAAE,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,EAC5C,cAAc,CAAC,EAAE,yBAAyB,EAC1C,QAAQ,CAAC,EAAE,OAAO,KACjB,OAAO,CAAC,CAAC,CAAC,CAAC;CACnB,CAAC;AAEF,KAAK,eAAe,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,IAAI,CAAC;AAChE,KAAK,OAAO,GAAG,CAAC,YAAY,EAAE;IAAE,KAAK,EAAE,eAAe,CAAC;IAAC,IAAI,EAAE,eAAe,CAAA;CAAE,KAAK,IAAI,CAAC;AACzF,KAAK,UAAU,GAAG,CAAC,YAAY,EAAE;IAAE,KAAK,EAAE,eAAe,CAAC;IAAC,IAAI,EAAE,eAAe,CAAA;CAAE,KAAK,IAAI,CAAC;AAE5F,YAAY,EAAE,yBAAyB,EAAE,IAAI,EAAE,eAAe,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
package/dist/types/pool.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=pool.js.map
|
package/dist/types/postgres.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import Decimal from 'decimal.js';
|
|
2
|
-
import type Table from './table';
|
|
3
|
-
import type { JSON } from './json';
|
|
4
|
-
type OrderDirection = 'asc' | 'desc';
|
|
5
|
-
type PostgresType = 'boolean' | 'smallint' | 'integer' | 'bigint' | 'real' | 'double precision' | 'numeric' | 'character' | 'character varying' | 'text' | 'uuid' | 'date' | 'timestamp without time zone' | 'timestamp with time zone' | 'json' | 'jsonb';
|
|
6
|
-
type PostgresTypeMapper<Type extends PostgresType, Nullable extends boolean> = Type extends 'boolean' ? (true extends Nullable ? null : never) | boolean : Type extends
|
|
7
|
-
type ColumnTypeByColumns<Columns extends Table['columns'], columnKey extends keyof Columns> = PostgresTypeMapper<Columns[columnKey]['type'], Columns[columnKey]['nullable']>;
|
|
8
|
-
type ColumnTypeByTable<T extends Table, columnKey extends keyof T['columns']> = PostgresTypeMapper<T['columns'][columnKey]['type'], T['columns'][columnKey]['nullable']>;
|
|
9
|
-
export type { OrderDirection, PostgresType, PostgresTypeMapper, ColumnTypeByColumns, ColumnTypeByTable };
|
|
1
|
+
import Decimal from 'decimal.js';
|
|
2
|
+
import type { Table } from './table';
|
|
3
|
+
import type { JSON } from './json';
|
|
4
|
+
type OrderDirection = 'asc' | 'desc';
|
|
5
|
+
type PostgresType = 'boolean' | 'smallint' | 'integer' | 'bigint' | 'real' | 'double precision' | 'numeric' | 'character' | 'character varying' | 'text' | 'uuid' | 'date' | 'timestamp without time zone' | 'timestamp with time zone' | 'json' | 'jsonb';
|
|
6
|
+
type PostgresTypeMapper<Type extends PostgresType, Nullable extends boolean> = Type extends 'boolean' ? (true extends Nullable ? null : never) | boolean : Type extends 'smallint' | 'integer' | 'real' | 'double precision' ? (true extends Nullable ? null : never) | number : Type extends 'bigint' ? (true extends Nullable ? null : never) | bigint : Type extends 'numeric' ? (true extends Nullable ? null : never) | Decimal : Type extends 'character' | 'character varying' | 'text' | 'uuid' ? (true extends Nullable ? null : never) | string : Type extends 'date' | 'timestamp without time zone' | 'timestamp with time zone' ? (true extends Nullable ? null : never) | Date : Type extends 'json' | 'jsonb' ? (true extends Nullable ? null : never) | JSON : never;
|
|
7
|
+
type ColumnTypeByColumns<Columns extends Table['columns'], columnKey extends keyof Columns> = PostgresTypeMapper<Columns[columnKey]['type'], Columns[columnKey]['nullable']>;
|
|
8
|
+
type ColumnTypeByTable<T extends Table, columnKey extends keyof T['columns']> = PostgresTypeMapper<T['columns'][columnKey]['type'], T['columns'][columnKey]['nullable']>;
|
|
9
|
+
export type { OrderDirection, PostgresType, PostgresTypeMapper, ColumnTypeByColumns, ColumnTypeByTable };
|
|
10
10
|
//# sourceMappingURL=postgres.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../src/types/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AACjC,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../src/types/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AACjC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnC,KAAK,cAAc,GAAG,KAAK,GAAG,MAAM,CAAC;AAErC,KAAK,YAAY,GACX,SAAS,GAET,UAAU,GACV,SAAS,GACT,QAAQ,GACR,MAAM,GACN,kBAAkB,GAClB,SAAS,GAET,WAAW,GACX,mBAAmB,GACnB,MAAM,GACN,MAAM,GAEN,MAAM,GACN,6BAA6B,GAC7B,0BAA0B,GAE1B,MAAM,GACN,OAAO,CAAC;AAEd,KAAK,kBAAkB,CAAC,IAAI,SAAS,YAAY,EAAE,QAAQ,SAAS,OAAO,IAAI,IAAI,SAAS,SAAS,GAC/F,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,OAAO,GAChD,IAAI,SAAS,UAAU,GAAG,SAAS,GAAG,MAAM,GAAG,kBAAkB,GACjE,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,MAAM,GAC/C,IAAI,SAAS,QAAQ,GACrB,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,MAAM,GAC/C,IAAI,SAAS,SAAS,GACtB,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,OAAO,GAChD,IAAI,SAAS,WAAW,GAAG,mBAAmB,GAAG,MAAM,GAAG,MAAM,GAChE,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,MAAM,GAC/C,IAAI,SAAS,MAAM,GAAG,6BAA6B,GAAG,0BAA0B,GAChF,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,IAAI,GAC7C,IAAI,SAAS,MAAM,GAAG,OAAO,GAC7B,CAAC,IAAI,SAAS,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC,GAAG,IAAI,GAC7C,KAAK,CAAC;AAEZ,KAAK,mBAAmB,CAAC,OAAO,SAAS,KAAK,CAAC,SAAS,CAAC,EAAE,SAAS,SAAS,MAAM,OAAO,IAAI,kBAAkB,CAC5G,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,EAC1B,OAAO,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,CACjC,CAAC;AACF,KAAK,iBAAiB,CAAC,CAAC,SAAS,KAAK,EAAE,SAAS,SAAS,MAAM,CAAC,CAAC,SAAS,CAAC,IAAI,kBAAkB,CAC9F,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,EAC/B,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,CACtC,CAAC;AAEF,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,CAAC"}
|
package/dist/types/postgres.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
//# sourceMappingURL=postgres.js.map
|