@mrnafisia/type-query 1.2.10 → 2.0.0
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/dist/prd.tsconfig.tsbuildinfo +1 -0
- package/dist/src/Table.d.ts +82 -0
- package/dist/src/Table.d.ts.map +1 -0
- package/dist/{types/pool.js → src/Table.js} +3 -3
- package/dist/{types → src}/Table.js.map +1 -1
- package/dist/src/context.d.ts +76 -0
- package/dist/src/context.d.ts.map +1 -0
- package/dist/src/context.js +70 -0
- package/dist/src/context.js.map +1 -0
- package/dist/src/createModelParser.d.ts +33 -0
- package/dist/src/createModelParser.d.ts.map +1 -0
- package/dist/src/createModelParser.js +178 -0
- package/dist/src/createModelParser.js.map +1 -0
- package/dist/src/ddl.d.ts +11 -0
- package/dist/src/ddl.d.ts.map +1 -0
- package/dist/src/ddl.js +83 -0
- package/dist/src/ddl.js.map +1 -0
- package/dist/src/entity.d.ts +100 -0
- package/dist/src/entity.d.ts.map +1 -0
- package/dist/src/entity.js +425 -0
- package/dist/src/entity.js.map +1 -0
- package/dist/src/index.d.ts +10 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +54 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/keywords.d.ts +143 -0
- package/dist/src/keywords.d.ts.map +1 -0
- package/dist/src/keywords.js +169 -0
- package/dist/src/keywords.js.map +1 -0
- package/dist/src/resolve.d.ts +15 -0
- package/dist/src/resolve.d.ts.map +1 -0
- package/dist/src/resolve.js +535 -0
- package/dist/src/resolve.js.map +1 -0
- package/dist/src/testTransaction.d.ts +19 -0
- package/dist/src/testTransaction.d.ts.map +1 -0
- package/dist/src/testTransaction.js +85 -0
- package/dist/src/testTransaction.js.map +1 -0
- package/dist/src/transaction.d.ts +6 -0
- package/dist/src/transaction.d.ts.map +1 -0
- package/dist/src/transaction.js +28 -0
- package/dist/src/transaction.js.map +1 -0
- package/dist/src/utils.d.ts +70 -0
- package/dist/src/utils.d.ts.map +1 -0
- package/dist/src/utils.js +229 -0
- package/dist/src/utils.js.map +1 -0
- package/package.json +29 -25
- package/dist/U.d.ts +0 -3
- package/dist/U.d.ts.map +0 -1
- package/dist/U.js +0 -29
- package/dist/U.js.map +0 -1
- package/dist/cast.d.ts +0 -15
- package/dist/cast.d.ts.map +0 -1
- package/dist/cast.js +0 -151
- package/dist/cast.js.map +0 -1
- package/dist/context.d.ts +0 -949
- package/dist/context.d.ts.map +0 -1
- package/dist/context.js +0 -85
- package/dist/context.js.map +0 -1
- package/dist/dictionary.d.ts +0 -13
- package/dist/dictionary.d.ts.map +0 -1
- package/dist/dictionary.js +0 -180
- package/dist/dictionary.js.map +0 -1
- package/dist/entity.d.ts +0 -3469
- package/dist/entity.d.ts.map +0 -1
- package/dist/entity.js +0 -1067
- package/dist/entity.js.map +0 -1
- package/dist/error.d.ts +0 -5
- package/dist/error.d.ts.map +0 -1
- package/dist/error.js +0 -8
- package/dist/error.js.map +0 -1
- package/dist/index.d.ts +0 -19
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -35
- package/dist/index.js.map +0 -1
- package/dist/model.d.ts +0 -967
- package/dist/model.d.ts.map +0 -1
- package/dist/model.js +0 -244
- package/dist/model.js.map +0 -1
- package/dist/pool.d.ts +0 -7
- package/dist/pool.d.ts.map +0 -1
- package/dist/pool.js +0 -123
- package/dist/pool.js.map +0 -1
- package/dist/schema.d.ts +0 -26
- package/dist/schema.d.ts.map +0 -1
- package/dist/schema.js +0 -406
- package/dist/schema.js.map +0 -1
- package/dist/testUtil.d.ts +0 -5
- package/dist/testUtil.d.ts.map +0 -1
- package/dist/testUtil.js +0 -338
- package/dist/testUtil.js.map +0 -1
- package/dist/types/Context.d.ts +0 -52
- package/dist/types/Context.d.ts.map +0 -1
- package/dist/types/Context.js +0 -3
- package/dist/types/Context.js.map +0 -1
- package/dist/types/Entity.d.ts +0 -71
- package/dist/types/Entity.d.ts.map +0 -1
- package/dist/types/Entity.js +0 -3
- package/dist/types/Entity.js.map +0 -1
- package/dist/types/Json.d.ts +0 -9
- package/dist/types/Json.d.ts.map +0 -1
- package/dist/types/Json.js +0 -3
- package/dist/types/Json.js.map +0 -1
- package/dist/types/Model.d.ts +0 -22
- package/dist/types/Model.d.ts.map +0 -1
- package/dist/types/Model.js +0 -3
- package/dist/types/Model.js.map +0 -1
- package/dist/types/Table.d.ts +0 -234
- package/dist/types/Table.d.ts.map +0 -1
- package/dist/types/Table.js +0 -3
- package/dist/types/pool.d.ts +0 -19
- package/dist/types/pool.d.ts.map +0 -1
- package/dist/types/pool.js.map +0 -1
- package/dist/types/postgres.d.ts +0 -10
- package/dist/types/postgres.d.ts.map +0 -1
- package/dist/types/postgres.js +0 -3
- package/dist/types/postgres.js.map +0 -1
- package/dist/types/testUtil.d.ts +0 -27
- package/dist/types/testUtil.d.ts.map +0 -1
- package/dist/types/testUtil.js +0 -3
- package/dist/types/testUtil.js.map +0 -1
- package/dist/utils.d.ts +0 -68
- package/dist/utils.d.ts.map +0 -1
- package/dist/utils.js +0 -221
- package/dist/utils.js.map +0 -1
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.testTransaction = exports.isEqual = void 0;
|
|
4
|
+
const never_catch_1 = require("never-catch");
|
|
5
|
+
const entity_1 = require("./entity");
|
|
6
|
+
const transaction_1 = require("./transaction");
|
|
7
|
+
const ddl_1 = require("./ddl");
|
|
8
|
+
const isEqual = (a, b) => {
|
|
9
|
+
if (a === b) {
|
|
10
|
+
return true;
|
|
11
|
+
}
|
|
12
|
+
if (typeof a === 'object' &&
|
|
13
|
+
a !== null &&
|
|
14
|
+
typeof b === 'object' &&
|
|
15
|
+
b !== null) {
|
|
16
|
+
return (Array.isArray(a) === Array.isArray(b) &&
|
|
17
|
+
Object.entries(a).every(([key, value]) => isEqual(value, b[key])) &&
|
|
18
|
+
Object.entries(b).every(([key, value]) => isEqual(value, a[key])));
|
|
19
|
+
}
|
|
20
|
+
return false;
|
|
21
|
+
};
|
|
22
|
+
exports.isEqual = isEqual;
|
|
23
|
+
const testTransaction = async (tablesWithData, callback, pool, isolationLevel = 'read-committed', rollback = true) => (0, transaction_1.transaction)(pool, async (client) => {
|
|
24
|
+
await client.query(tablesWithData
|
|
25
|
+
.map(({ table }) => [
|
|
26
|
+
...(0, ddl_1.generateCreateSequencesSQL)(table),
|
|
27
|
+
(0, ddl_1.generateCreateTableSQL)(table)
|
|
28
|
+
])
|
|
29
|
+
.flat()
|
|
30
|
+
.join('; ') + ';');
|
|
31
|
+
for (const tableWithData of tablesWithData) {
|
|
32
|
+
if (tableWithData.startData.length !== 0) {
|
|
33
|
+
const insertResult = await (0, entity_1.createEntity)(tableWithData.table)
|
|
34
|
+
.insert(tableWithData.startData, [{ expression: true, name: 'confirm' }], {
|
|
35
|
+
nullableDefaultColumns: Object.entries(tableWithData.table.columns)
|
|
36
|
+
.filter(([, column]) => column.nullable || column.default)
|
|
37
|
+
.map(([key]) => key)
|
|
38
|
+
})
|
|
39
|
+
.execute(client, [
|
|
40
|
+
'count',
|
|
41
|
+
tableWithData.startData.length
|
|
42
|
+
]);
|
|
43
|
+
if (!insertResult.ok) {
|
|
44
|
+
return (0, never_catch_1.err)([JSON.stringify(insertResult.error)]);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
await callback(client);
|
|
49
|
+
const differences = [];
|
|
50
|
+
for (const { table, finalData } of tablesWithData) {
|
|
51
|
+
const selectResult = await (0, entity_1.createEntity)(table)
|
|
52
|
+
.select(Object.keys(table.columns), true)
|
|
53
|
+
.execute(client, []);
|
|
54
|
+
if (!selectResult.ok) {
|
|
55
|
+
return (0, never_catch_1.err)([JSON.stringify(selectResult.error)]);
|
|
56
|
+
}
|
|
57
|
+
for (const finalRow of finalData) {
|
|
58
|
+
const i = selectResult.value.findIndex(v => isEqual(v, finalRow));
|
|
59
|
+
if (i === -1) {
|
|
60
|
+
differences.push('\nfinal row not found:\n' +
|
|
61
|
+
JSON.stringify(finalRow, null, 4));
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
selectResult.value.splice(i, 1);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
differences.push(...selectResult.value.map(v => '\ndb row without match:\n' +
|
|
68
|
+
JSON.stringify(v, null, 4)));
|
|
69
|
+
}
|
|
70
|
+
if (differences.length !== 0) {
|
|
71
|
+
return (0, never_catch_1.err)(differences);
|
|
72
|
+
}
|
|
73
|
+
if (rollback) {
|
|
74
|
+
return (0, never_catch_1.err)(undefined);
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
return (0, never_catch_1.ok)(undefined);
|
|
78
|
+
}
|
|
79
|
+
}, isolationLevel).then(result => {
|
|
80
|
+
if (!result.ok && result.error !== undefined) {
|
|
81
|
+
throw result.error.join('\n');
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
exports.testTransaction = testTransaction;
|
|
85
|
+
//# sourceMappingURL=testTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testTransaction.js","sourceRoot":"","sources":["../../src/testTransaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Pool, PoolClient } from 'pg';
|
|
2
|
+
import { Result } from 'never-catch';
|
|
3
|
+
type TransactionIsolationLevel = 'read-uncommitted' | 'read-committed' | 'repeatable-read' | 'serializable';
|
|
4
|
+
declare const transaction: <R extends Result<unknown, unknown>>(pool: Pool, callback: (client: PoolClient) => Promise<R>, isolationLevel?: TransactionIsolationLevel, readOnly?: boolean) => Promise<R>;
|
|
5
|
+
export { type TransactionIsolationLevel, transaction };
|
|
6
|
+
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAGrC,KAAK,yBAAyB,GACxB,kBAAkB,GAClB,gBAAgB,GAChB,iBAAiB,GACjB,cAAc,CAAC;AAErB,QAAA,MAAM,WAAW,6CACP,IAAI,qBACS,UAAU,KAAK,QAAQ,CAAC,CAAC,+EA4B3C,CAAC;AAEN,OAAO,EAAE,KAAK,yBAAyB,EAAE,WAAW,EAAE,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.transaction = void 0;
|
|
4
|
+
const keywords_1 = require("./keywords");
|
|
5
|
+
const transaction = async (pool, callback, isolationLevel = 'serializable', readOnly = false) => pool.connect().then(client => client
|
|
6
|
+
.query(`BEGIN TRANSACTION ISOLATION LEVEL ${keywords_1.Dictionary.TransactionIsolationLevel[isolationLevel]} READ ${readOnly ? 'ONLY' : 'WRITE'};`)
|
|
7
|
+
.then(async () => {
|
|
8
|
+
const result = await callback(client);
|
|
9
|
+
if (result.ok) {
|
|
10
|
+
await client.query('COMMIT;');
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
await client.query('ROLLBACK;');
|
|
14
|
+
}
|
|
15
|
+
client.release();
|
|
16
|
+
return result;
|
|
17
|
+
})
|
|
18
|
+
.catch(async (err) => {
|
|
19
|
+
try {
|
|
20
|
+
await client.query('ROLLBACK;');
|
|
21
|
+
}
|
|
22
|
+
catch (_) {
|
|
23
|
+
}
|
|
24
|
+
client.release();
|
|
25
|
+
throw err;
|
|
26
|
+
}));
|
|
27
|
+
exports.transaction = transaction;
|
|
28
|
+
//# sourceMappingURL=transaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/transaction.ts"],"names":[],"mappings":";;;AAEA,yCAAwC;AAQxC,MAAM,WAAW,GAAG,KAAK,EACrB,IAAU,EACV,QAA4C,EAC5C,iBAAiB,cAA2C,EAC5D,QAAQ,GAAG,KAAK,EAClB,EAAE,CACA,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CACzB,MAAM;KACD,KAAK,CACF,qCAAqC,qBAAU,CAAC,yBAAyB,CAAC,cAAc,CAAC,SAAS,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,GAAG,CACnI;KACA,IAAI,CAAC,KAAK,IAAI,EAAE;IACb,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,CAAC;IACtC,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;QACZ,MAAM,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;SAAM,CAAC;QACJ,MAAM,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACpC,CAAC;IACD,MAAM,CAAC,OAAO,EAAE,CAAC;IACjB,OAAO,MAAM,CAAC;AAClB,CAAC,CAAC;KACD,KAAK,CAAC,KAAK,EAAC,GAAG,EAAC,EAAE;IACf,IAAI,CAAC;QACD,MAAM,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACpC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;IAEb,CAAC;IACD,MAAM,CAAC,OAAO,EAAE,CAAC;IACjB,MAAM,GAAG,CAAC;AACd,CAAC,CAAC,CACT,CAAC;AAEmC,kCAAW"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import Decimal from 'decimal.js';
|
|
2
|
+
import { Json, NullableType, Schema, Table } from './Table';
|
|
3
|
+
import { LikeOperator, ListOperator, NullOperator, BetweenOperator, BooleanOperator, CompareOperator, ArithmeticOperator } from './keywords';
|
|
4
|
+
import { Query } from './entity';
|
|
5
|
+
declare const value: <T>(expression: T) => T;
|
|
6
|
+
declare function arithmetic<T extends undefined | null | number>(expressionA: T, operator: ArithmeticOperator, expressionB: T): Extract<T, undefined | null> | (T extends number ? number : never);
|
|
7
|
+
declare function arithmetic<T extends undefined | null | bigint>(expressionA: T, operator: ArithmeticOperator, expressionB: T): Extract<T, undefined | null> | (T extends bigint ? bigint : never);
|
|
8
|
+
declare function arithmetic<T extends undefined | null | Decimal>(expressionA: T, operator: ArithmeticOperator, expressionB: T): Extract<T, undefined | null> | (T extends Decimal ? Decimal : never);
|
|
9
|
+
declare function arithmetic<T extends undefined | null | number>(operator: ArithmeticOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends number ? number : never);
|
|
10
|
+
declare function arithmetic<T extends undefined | null | bigint>(operator: ArithmeticOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends bigint ? bigint : never);
|
|
11
|
+
declare function arithmetic<T extends undefined | null | Decimal>(operator: ArithmeticOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends Decimal ? Decimal : never);
|
|
12
|
+
declare function json<T extends undefined | Json, K extends undefined | null | string>(expression: T, operator: '->', key: K, _?: never): (undefined extends K ? undefined : never) | (undefined extends T ? undefined : never) | (null extends K ? null : never) | (T extends Json ? Json : never);
|
|
13
|
+
declare function json<T extends undefined | Json, K extends undefined | null | string, C extends undefined | string>(expression: T, operator: '->>', key: K, cast?: C): (undefined extends K ? undefined : never) | (undefined extends T ? undefined : never) | (null extends K ? null : never) | (C extends string ? unknown : T extends Json ? string : never);
|
|
14
|
+
declare function json<T extends undefined | Json, B extends undefined | null | string>(expressionA: T, operator: 'j-', expressionB: B, _?: never): (undefined extends B ? undefined : never) | (null extends B ? null | Partial<T> : Partial<T>);
|
|
15
|
+
declare function json<T extends undefined | null | Json, B extends undefined | null | string>(expressionA: T, operator: 'j- Array', expressionB: readonly B[], _?: never): (undefined extends B ? undefined : never) | (null extends T ? null | Partial<T> : Partial<T>);
|
|
16
|
+
declare const fun: (name: string, args: readonly unknown[], cast?: string) => unknown;
|
|
17
|
+
declare const switchCase: <W extends boolean | undefined, T>(cases: readonly {
|
|
18
|
+
when: W;
|
|
19
|
+
then: T;
|
|
20
|
+
}[], otherwise?: T) => undefined extends W ? undefined | T : T;
|
|
21
|
+
declare function concat<T extends undefined | null | string>(...expressions: T[]): Extract<T, undefined | null> | (T extends string ? string : never);
|
|
22
|
+
declare function concat<T extends undefined | null | Json>(...expressions: T[]): Extract<T, undefined | null> | (T extends Json ? Json : never);
|
|
23
|
+
declare const column: <S extends Schema, C extends keyof S & string>(table: Table<S>, column: C, full?: boolean, alias?: string) => NullableType<S[C]['type'], S[C]['nullable']>;
|
|
24
|
+
declare const raw: <T>(get: (paramsStart: number) => {
|
|
25
|
+
expression: string;
|
|
26
|
+
params: string[];
|
|
27
|
+
}) => T;
|
|
28
|
+
declare const ignore: <T>(expression: T, otherwise: Exclude<T, undefined>) => Exclude<T, undefined>;
|
|
29
|
+
declare const not: <T extends boolean | null | undefined>(expression: T) => T;
|
|
30
|
+
declare const and: <T extends boolean | null | undefined>(...expressions: readonly T[]) => T;
|
|
31
|
+
declare const or: <T extends boolean | null | undefined>(...expressions: readonly T[]) => T;
|
|
32
|
+
declare function compare<T>(expression: T, operator: null extends T ? NullOperator : never, _?: never, __?: never): undefined extends T ? undefined | boolean : boolean;
|
|
33
|
+
declare function compare<T extends undefined | null | boolean>(expression: T, operator: BooleanOperator, _?: never, __?: never): T;
|
|
34
|
+
declare function compare<T extends undefined | null | number>(expressionA: T, operator: CompareOperator, expressionB: T, _?: never): Extract<T, undefined | null> | (T extends number ? boolean : never);
|
|
35
|
+
declare function compare<T extends undefined | null | bigint>(expressionA: T, operator: CompareOperator, expressionB: T, _?: never): Extract<T, undefined | null> | (T extends bigint ? boolean : never);
|
|
36
|
+
declare function compare<T extends undefined | null | Decimal>(expressionA: T, operator: CompareOperator, expressionB: T, _?: never): Extract<T, undefined | null> | (T extends Decimal ? boolean : never);
|
|
37
|
+
declare function compare<T extends undefined | null | string>(expressionA: T, operator: CompareOperator, expressionB: T, _?: never): Extract<T, undefined | null> | (T extends string ? boolean : never);
|
|
38
|
+
declare function compare<T extends undefined | null | Date>(expressionA: T, operator: CompareOperator, expressionB: T, _?: never): Extract<T, undefined | null> | (T extends Date ? boolean : never);
|
|
39
|
+
declare function compare<T extends undefined | null | number>(expressionA: T, operator: ListOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends number ? boolean : never);
|
|
40
|
+
declare function compare<T extends undefined | null | bigint>(expressionA: T, operator: ListOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends bigint ? boolean : never);
|
|
41
|
+
declare function compare<T extends undefined | null | Decimal>(expressionA: T, operator: ListOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends Decimal ? boolean : never);
|
|
42
|
+
declare function compare<T extends undefined | null | string>(expressionA: T, operator: ListOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends string ? boolean : never);
|
|
43
|
+
declare function compare<T extends undefined | null | Date>(expressionA: T, operator: ListOperator, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends Date ? boolean : never);
|
|
44
|
+
declare function compare<T extends undefined | null | string>(expressionA: T, operator: 'like', expressionB: T, _?: never): Extract<T, undefined | null> | (T extends string ? boolean : never);
|
|
45
|
+
declare function compare<T extends undefined | null | string>(expressionA: T, operator: Exclude<LikeOperator, 'like'>, expressions: readonly T[], _?: never): Extract<T, undefined | null> | (T extends string ? boolean : never);
|
|
46
|
+
declare function compare<T extends undefined | null | number>(expression: T, operator: BetweenOperator, expressionStart: T, expressionEnd: T): Extract<T, undefined | null> | (T extends number ? boolean : never);
|
|
47
|
+
declare function compare<T extends undefined | null | bigint>(expression: T, operator: BetweenOperator, expressionStart: T, expressionEnd: T): Extract<T, undefined | null> | (T extends bigint ? boolean : never);
|
|
48
|
+
declare function compare<T extends undefined | null | Decimal>(expression: T, operator: BetweenOperator, expressionStart: T, expressionEnd: T): Extract<T, undefined | null> | (T extends Decimal ? boolean : never);
|
|
49
|
+
declare function compare<T extends undefined | null | string>(expression: T, operator: BetweenOperator, expressionStart: T, expressionEnd: T): Extract<T, undefined | null> | (T extends string ? boolean : never);
|
|
50
|
+
declare function compare<T extends undefined | null | Date>(expression: T, operator: BetweenOperator, expressionStart: T, expressionEnd: T): Extract<T, undefined | null> | (T extends Date ? boolean : never);
|
|
51
|
+
declare function compare<T extends undefined | null | Json>(expressionA: T, operator: '@>' | '<@', expressionB: T, _?: never): Extract<T, undefined | null> | (T extends Json ? boolean : never);
|
|
52
|
+
declare function compare<T extends undefined | null | Json, B extends undefined | null | string>(expressionA: T, operator: '?', expressionB: B, _?: never): Extract<T, undefined | null> | Extract<B, undefined | null> | (T extends Json ? (B extends string ? boolean : never) : never);
|
|
53
|
+
declare function compare<T extends undefined | null | Json, B extends undefined | null | string>(expressionA: T, operator: '?&' | '?|', expressions: readonly B[], _?: never): Extract<T, undefined | null> | Extract<B, undefined | null> | (T extends Json ? (B extends string ? boolean : never) : never);
|
|
54
|
+
declare const subQuery: <T>(query: Query<Schema, [
|
|
55
|
+
]>) => T;
|
|
56
|
+
declare const subQueryExist: <T>(query: Query<Schema, [
|
|
57
|
+
]>) => T;
|
|
58
|
+
declare const stringify: (value: unknown, inline?: boolean) => string;
|
|
59
|
+
declare const Cast: {
|
|
60
|
+
boolean: <N extends boolean = false>(v: unknown, nullable?: N) => NullableType<boolean, N> | undefined;
|
|
61
|
+
number: <N_1 extends boolean = false>(v: unknown, nullable?: N_1) => NullableType<number, N_1> | undefined;
|
|
62
|
+
integer: <N_2 extends boolean = false>(v: unknown, nullable?: N_2) => NullableType<number, N_2> | undefined;
|
|
63
|
+
bigInt: <N_3 extends boolean = false>(v: unknown, nullable?: N_3) => NullableType<bigint, N_3> | undefined;
|
|
64
|
+
decimal: <N_4 extends boolean = false>(v: unknown, nullable?: N_4) => NullableType<Decimal, N_4> | undefined;
|
|
65
|
+
string: <N_5 extends boolean = false>(v: unknown, nullable?: N_5) => NullableType<string, N_5> | undefined;
|
|
66
|
+
date: <N_6 extends boolean = false>(v: unknown, nullable?: N_6) => NullableType<Date, N_6> | undefined;
|
|
67
|
+
json: <N_7 extends boolean = false>(v: unknown, nullable?: N_7) => NullableType<Json, N_7> | undefined;
|
|
68
|
+
};
|
|
69
|
+
export { value, arithmetic, json, fun, switchCase, concat, column, raw, ignore, not, and, or, compare, subQuery, subQueryExist, stringify, Cast };
|
|
70
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Cast = exports.stringify = exports.subQueryExist = exports.subQuery = exports.compare = exports.or = exports.and = exports.not = exports.ignore = exports.raw = exports.column = exports.concat = exports.switchCase = exports.fun = exports.json = exports.arithmetic = exports.value = void 0;
|
|
7
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
8
|
+
const resolve_1 = require("./resolve");
|
|
9
|
+
const keywords_1 = require("./keywords");
|
|
10
|
+
const value = (expression) => [keywords_1.OperatorCode.Value, expression];
|
|
11
|
+
exports.value = value;
|
|
12
|
+
function arithmetic(a, b, c) {
|
|
13
|
+
return Array.isArray(b)
|
|
14
|
+
? [keywords_1.OperatorMap[a], b]
|
|
15
|
+
: [keywords_1.OperatorMap[b], [a, c]];
|
|
16
|
+
}
|
|
17
|
+
exports.arithmetic = arithmetic;
|
|
18
|
+
function json(a, operator, b, c) {
|
|
19
|
+
return [keywords_1.OperatorMap[operator], a, b, c];
|
|
20
|
+
}
|
|
21
|
+
exports.json = json;
|
|
22
|
+
const fun = (name, args, cast = '') => [keywords_1.OperatorCode.Function, name, args, cast];
|
|
23
|
+
exports.fun = fun;
|
|
24
|
+
const switchCase = (cases, otherwise) => [keywords_1.OperatorCode.SwitchCase, cases, otherwise];
|
|
25
|
+
exports.switchCase = switchCase;
|
|
26
|
+
function concat(...a) {
|
|
27
|
+
return [keywords_1.OperatorCode.Concat, a];
|
|
28
|
+
}
|
|
29
|
+
exports.concat = concat;
|
|
30
|
+
const column = (table, column, full, alias) => [
|
|
31
|
+
keywords_1.OperatorCode.Column,
|
|
32
|
+
(0, resolve_1.resolveColumn)(table, column, full, alias)
|
|
33
|
+
];
|
|
34
|
+
exports.column = column;
|
|
35
|
+
const raw = (get) => [keywords_1.OperatorCode.Raw, get];
|
|
36
|
+
exports.raw = raw;
|
|
37
|
+
const ignore = (expression, otherwise) => [keywords_1.OperatorCode.Ignore, expression, otherwise];
|
|
38
|
+
exports.ignore = ignore;
|
|
39
|
+
const not = (expression) => [keywords_1.OperatorCode.Not, expression];
|
|
40
|
+
exports.not = not;
|
|
41
|
+
const and = (...expressions) => [keywords_1.OperatorCode.And, expressions];
|
|
42
|
+
exports.and = and;
|
|
43
|
+
const or = (...expressions) => [keywords_1.OperatorCode.Or, expressions];
|
|
44
|
+
exports.or = or;
|
|
45
|
+
function compare(a, operator, b, c) {
|
|
46
|
+
return [keywords_1.OperatorMap[operator], a, b, c];
|
|
47
|
+
}
|
|
48
|
+
exports.compare = compare;
|
|
49
|
+
const subQuery = (query) => [keywords_1.OperatorCode.SubQuery, query];
|
|
50
|
+
exports.subQuery = subQuery;
|
|
51
|
+
const subQueryExist = (query) => [keywords_1.OperatorCode.SubQueryExist, query];
|
|
52
|
+
exports.subQueryExist = subQueryExist;
|
|
53
|
+
const stringify = (value, inline = false) => {
|
|
54
|
+
switch (typeof value) {
|
|
55
|
+
case 'boolean':
|
|
56
|
+
return value ? 'TRUE' : 'FALSE';
|
|
57
|
+
case 'number':
|
|
58
|
+
case 'bigint':
|
|
59
|
+
return `${value}`;
|
|
60
|
+
case 'string':
|
|
61
|
+
return inline ? `'${value}'` : `${value}`;
|
|
62
|
+
case 'object':
|
|
63
|
+
if (value === null) {
|
|
64
|
+
return 'NULL';
|
|
65
|
+
}
|
|
66
|
+
if (value instanceof decimal_js_1.default) {
|
|
67
|
+
return inline ? `'${value}'` : `${value}`;
|
|
68
|
+
}
|
|
69
|
+
if (value instanceof Date) {
|
|
70
|
+
return inline
|
|
71
|
+
? `'${value.toISOString()}'`
|
|
72
|
+
: value.toISOString();
|
|
73
|
+
}
|
|
74
|
+
return inline
|
|
75
|
+
? `'${JSON.stringify(value)}'::JSONB`
|
|
76
|
+
: JSON.stringify(value);
|
|
77
|
+
case 'undefined':
|
|
78
|
+
case 'function':
|
|
79
|
+
case 'symbol':
|
|
80
|
+
throw `${String(value)} is not serializable`;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
exports.stringify = stringify;
|
|
84
|
+
const Cast = {
|
|
85
|
+
boolean: (v, nullable = false) => {
|
|
86
|
+
if (nullable &&
|
|
87
|
+
(v === null ||
|
|
88
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
switch (typeof v) {
|
|
92
|
+
case 'boolean':
|
|
93
|
+
return v;
|
|
94
|
+
case 'string':
|
|
95
|
+
switch (v) {
|
|
96
|
+
case 't':
|
|
97
|
+
case 'true':
|
|
98
|
+
return true;
|
|
99
|
+
case 'f':
|
|
100
|
+
case 'false':
|
|
101
|
+
return false;
|
|
102
|
+
default:
|
|
103
|
+
return undefined;
|
|
104
|
+
}
|
|
105
|
+
default:
|
|
106
|
+
return undefined;
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
number: (v, nullable = false) => {
|
|
110
|
+
if (nullable &&
|
|
111
|
+
(v === null ||
|
|
112
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
113
|
+
return null;
|
|
114
|
+
}
|
|
115
|
+
if (typeof v === 'number') {
|
|
116
|
+
return v;
|
|
117
|
+
}
|
|
118
|
+
else if (typeof v === 'string') {
|
|
119
|
+
const _v = Number(v);
|
|
120
|
+
return Number.isNaN(_v) ? undefined : _v;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
return undefined;
|
|
124
|
+
}
|
|
125
|
+
},
|
|
126
|
+
integer: (v, nullable = false) => {
|
|
127
|
+
const _v = Cast.number(v, nullable);
|
|
128
|
+
return typeof _v === 'number' ? Math.trunc(_v) : _v;
|
|
129
|
+
},
|
|
130
|
+
bigInt: (v, nullable = false) => {
|
|
131
|
+
if (nullable &&
|
|
132
|
+
(v === null ||
|
|
133
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
switch (typeof v) {
|
|
137
|
+
case 'bigint':
|
|
138
|
+
return v;
|
|
139
|
+
case 'number':
|
|
140
|
+
return BigInt(v);
|
|
141
|
+
case 'string':
|
|
142
|
+
try {
|
|
143
|
+
return BigInt(v);
|
|
144
|
+
}
|
|
145
|
+
catch (_) {
|
|
146
|
+
return undefined;
|
|
147
|
+
}
|
|
148
|
+
default:
|
|
149
|
+
return undefined;
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
decimal: (v, nullable = false) => {
|
|
153
|
+
if (nullable &&
|
|
154
|
+
(v === null ||
|
|
155
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
156
|
+
return null;
|
|
157
|
+
}
|
|
158
|
+
if (v instanceof decimal_js_1.default) {
|
|
159
|
+
return v;
|
|
160
|
+
}
|
|
161
|
+
switch (typeof v) {
|
|
162
|
+
case 'number':
|
|
163
|
+
return new decimal_js_1.default(v);
|
|
164
|
+
case 'string':
|
|
165
|
+
try {
|
|
166
|
+
return new decimal_js_1.default(v);
|
|
167
|
+
}
|
|
168
|
+
catch (_) {
|
|
169
|
+
return undefined;
|
|
170
|
+
}
|
|
171
|
+
default:
|
|
172
|
+
return undefined;
|
|
173
|
+
}
|
|
174
|
+
},
|
|
175
|
+
string: (v, nullable = false) => {
|
|
176
|
+
if (nullable &&
|
|
177
|
+
(v === null ||
|
|
178
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
switch (typeof v) {
|
|
182
|
+
case 'boolean':
|
|
183
|
+
case 'number':
|
|
184
|
+
case 'bigint':
|
|
185
|
+
return `${v}`;
|
|
186
|
+
case 'string':
|
|
187
|
+
return v;
|
|
188
|
+
default:
|
|
189
|
+
return undefined;
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
date: (v, nullable = false) => {
|
|
193
|
+
if (nullable &&
|
|
194
|
+
(v === null ||
|
|
195
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
196
|
+
return null;
|
|
197
|
+
}
|
|
198
|
+
if (v instanceof Date) {
|
|
199
|
+
return v;
|
|
200
|
+
}
|
|
201
|
+
if (typeof v === 'number' || typeof v === 'string') {
|
|
202
|
+
const _v = new Date(v);
|
|
203
|
+
return `${_v}` === 'Invalid Date' ? undefined : _v;
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
return undefined;
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
json: (v, nullable = false) => {
|
|
210
|
+
if (nullable &&
|
|
211
|
+
(v === null ||
|
|
212
|
+
(typeof v === 'string' && v.toLowerCase() === 'null'))) {
|
|
213
|
+
return null;
|
|
214
|
+
}
|
|
215
|
+
const _v = typeof v !== 'string' ? JSON.stringify(v) : v;
|
|
216
|
+
try {
|
|
217
|
+
const parsedV = JSON.parse(_v);
|
|
218
|
+
if (typeof parsedV !== 'object' || parsedV === null) {
|
|
219
|
+
return undefined;
|
|
220
|
+
}
|
|
221
|
+
return parsedV;
|
|
222
|
+
}
|
|
223
|
+
catch (_) {
|
|
224
|
+
return undefined;
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
exports.Cast = Cast;
|
|
229
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,16 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mrnafisia/type-query",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.0",
|
|
4
4
|
"description": "mini-orm with full type support for postgres.",
|
|
5
|
-
"main": "dist/index.js",
|
|
6
|
-
"types": "dist/index.d.ts",
|
|
7
|
-
"files": [
|
|
8
|
-
"dist"
|
|
9
|
-
],
|
|
10
|
-
"scripts": {
|
|
11
|
-
"build": "tsc",
|
|
12
|
-
"test": "jest ./tests"
|
|
13
|
-
},
|
|
14
5
|
"keywords": [
|
|
15
6
|
"orm",
|
|
16
7
|
"query-builder",
|
|
@@ -18,23 +9,36 @@
|
|
|
18
9
|
"sql",
|
|
19
10
|
"type-safe"
|
|
20
11
|
],
|
|
21
|
-
"repository": "https://github.com/MRNafisiA/type-query.git",
|
|
22
|
-
"author": "MRNafisiA <mnafisiasl@gmail.com>",
|
|
23
12
|
"license": "MIT",
|
|
13
|
+
"author": "MRNafisiA <mnafisiasl@gmail.com>",
|
|
14
|
+
"files": [
|
|
15
|
+
"dist"
|
|
16
|
+
],
|
|
17
|
+
"main": "./dist/src/index.js",
|
|
18
|
+
"repository": {
|
|
19
|
+
"type": "git",
|
|
20
|
+
"url": "https://github.com/MRNafisiA/type-query.git"
|
|
21
|
+
},
|
|
22
|
+
"scripts": {
|
|
23
|
+
"test": "jest ./tests",
|
|
24
|
+
"build": "tsc --build prd.tsconfig.json"
|
|
25
|
+
},
|
|
24
26
|
"devDependencies": {
|
|
25
|
-
"@types/jest": "^29.5.
|
|
26
|
-
"@types/
|
|
27
|
-
"@types/
|
|
28
|
-
"@
|
|
29
|
-
"
|
|
30
|
-
"
|
|
31
|
-
"
|
|
32
|
-
"
|
|
27
|
+
"@types/jest": "^29.5.12",
|
|
28
|
+
"@types/node": "^20.11.26",
|
|
29
|
+
"@types/pg": "^8.11.3",
|
|
30
|
+
"@typescript-eslint/eslint-plugin": "^7.2.0",
|
|
31
|
+
"@typescript-eslint/parser": "^7.2.0",
|
|
32
|
+
"eslint": "^8.57.0",
|
|
33
|
+
"eslint-config-prettier": "^9.1.0",
|
|
34
|
+
"jest": "^29.7.0",
|
|
35
|
+
"prettier": "^3.2.5",
|
|
36
|
+
"ts-jest": "^29.1.2",
|
|
37
|
+
"typescript": "^5.4.3"
|
|
33
38
|
},
|
|
34
39
|
"dependencies": {
|
|
35
|
-
"decimal.js": "
|
|
36
|
-
"
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
+
"decimal.js": "10.4.3",
|
|
41
|
+
"never-catch": "1.1.0"
|
|
42
|
+
},
|
|
43
|
+
"types": "./dist/src/index.d.ts"
|
|
40
44
|
}
|
package/dist/U.d.ts
DELETED
package/dist/U.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"U.d.ts","sourceRoot":"","sources":["../src/U.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,SAAS,CAAC;AAE7B,OAAO,EAAE,CAAC,EAAE,CAAC"}
|
package/dist/U.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.U = void 0;
|
|
27
|
-
var U = __importStar(require("./utils"));
|
|
28
|
-
exports.U = U;
|
|
29
|
-
//# sourceMappingURL=U.js.map
|
package/dist/U.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"U.js","sourceRoot":"","sources":["../src/U.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,yCAA6B;AAEpB,cAAC"}
|
package/dist/cast.d.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import Decimal from 'decimal.js';
|
|
2
|
-
import { JSON as Json } from './types/Json';
|
|
3
|
-
type NullableType<V extends boolean, T> = V extends true ? T | null : T;
|
|
4
|
-
declare const Cast: {
|
|
5
|
-
boolean: <N extends boolean = false>(v: unknown, nullable?: N) => NullableType<N, boolean> | undefined;
|
|
6
|
-
number: <N_1 extends boolean = false>(v: unknown, nullable?: N_1) => NullableType<N_1, number> | undefined;
|
|
7
|
-
integer: <N_2 extends boolean = false>(v: unknown, nullable?: N_2) => NullableType<N_2, number> | undefined;
|
|
8
|
-
bigInt: <N_3 extends boolean = false>(v: unknown, nullable?: N_3) => NullableType<N_3, bigint> | undefined;
|
|
9
|
-
decimal: <N_4 extends boolean = false>(v: unknown, nullable?: N_4) => NullableType<N_4, Decimal> | undefined;
|
|
10
|
-
string: <N_5 extends boolean = false>(v: unknown, nullable?: N_5) => NullableType<N_5, string> | undefined;
|
|
11
|
-
date: <N_6 extends boolean = false>(v: unknown, nullable?: N_6) => NullableType<N_6, Date> | undefined;
|
|
12
|
-
json: <N_7 extends boolean = false>(v: unknown, nullable?: N_7) => NullableType<N_7, Json> | undefined;
|
|
13
|
-
};
|
|
14
|
-
export { Cast };
|
|
15
|
-
//# sourceMappingURL=cast.d.ts.map
|
package/dist/cast.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cast.d.ts","sourceRoot":"","sources":["../src/cast.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,YAAY,CAAC;AACjC,OAAO,EAAE,IAAI,IAAI,IAAI,EAAE,MAAM,cAAc,CAAC;AAE5C,KAAK,YAAY,CAAC,CAAC,SAAS,OAAO,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;AAExE,QAAA,MAAM,IAAI;4CACkC,OAAO;6CAoBR,OAAO;8CAcN,OAAO;6CAOR,OAAO;8CAmBN,OAAO;6CAoBR,OAAO;2CAeT,OAAO;2CAgBP,OAAO;CAkB/C,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,CAAC"}
|