@rawsql-ts/sql-contract 0.1.0 → 0.2.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/README.md +406 -300
- package/dist/.tsbuildinfo +1 -1
- package/dist/catalog/index.d.ts +163 -0
- package/dist/catalog/index.js +377 -0
- package/dist/catalog/index.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/mapper/index.d.ts +61 -8
- package/dist/mapper/index.js +261 -42
- package/dist/mapper/index.js.map +1 -1
- package/dist/mapper/internal.d.ts +21 -0
- package/dist/mapper/internal.js +103 -0
- package/dist/mapper/internal.js.map +1 -0
- package/dist/utils/coercions.d.ts +20 -0
- package/dist/utils/coercions.js +80 -0
- package/dist/utils/coercions.js.map +1 -0
- package/package.json +11 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Attempts to parse a numeric string into a JavaScript number while making the
|
|
3
|
+
* unsafe precision loss explicit in the API name.
|
|
4
|
+
*
|
|
5
|
+
* This helper leaves non-string values untouched so callers can safely run it
|
|
6
|
+
* over raw database output without branching on the column type themselves.
|
|
7
|
+
*/
|
|
8
|
+
export declare function decimalStringToNumberUnsafe(value: unknown): unknown;
|
|
9
|
+
/**
|
|
10
|
+
* Coerces bigint-encoded strings into actual `bigint` values while avoiding
|
|
11
|
+
* falsy or empty strings.
|
|
12
|
+
*/
|
|
13
|
+
export declare function bigintStringToBigInt(value: unknown): unknown;
|
|
14
|
+
/**
|
|
15
|
+
* Normalizes timestamp values returned by SQL drivers into a valid `Date`.
|
|
16
|
+
*
|
|
17
|
+
* Accepts `Date` instances and parseable timestamp strings.
|
|
18
|
+
* Throws for invalid dates, empty strings, or unsupported value types.
|
|
19
|
+
*/
|
|
20
|
+
export declare function timestampFromDriver(value: unknown, fieldName?: string): Date;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decimalStringToNumberUnsafe = decimalStringToNumberUnsafe;
|
|
4
|
+
exports.bigintStringToBigInt = bigintStringToBigInt;
|
|
5
|
+
exports.timestampFromDriver = timestampFromDriver;
|
|
6
|
+
/**
|
|
7
|
+
* Attempts to parse a numeric string into a JavaScript number while making the
|
|
8
|
+
* unsafe precision loss explicit in the API name.
|
|
9
|
+
*
|
|
10
|
+
* This helper leaves non-string values untouched so callers can safely run it
|
|
11
|
+
* over raw database output without branching on the column type themselves.
|
|
12
|
+
*/
|
|
13
|
+
function decimalStringToNumberUnsafe(value) {
|
|
14
|
+
if (typeof value === 'number') {
|
|
15
|
+
return value;
|
|
16
|
+
}
|
|
17
|
+
if (typeof value === 'string') {
|
|
18
|
+
const trimmed = value.trim();
|
|
19
|
+
if (!trimmed) {
|
|
20
|
+
return value;
|
|
21
|
+
}
|
|
22
|
+
const parsed = Number(trimmed);
|
|
23
|
+
if (Number.isFinite(parsed)) {
|
|
24
|
+
return parsed;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return value;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Coerces bigint-encoded strings into actual `bigint` values while avoiding
|
|
31
|
+
* falsy or empty strings.
|
|
32
|
+
*/
|
|
33
|
+
function bigintStringToBigInt(value) {
|
|
34
|
+
if (typeof value === 'bigint') {
|
|
35
|
+
return value;
|
|
36
|
+
}
|
|
37
|
+
if (typeof value === 'string') {
|
|
38
|
+
const trimmed = value.trim();
|
|
39
|
+
if (trimmed) {
|
|
40
|
+
try {
|
|
41
|
+
return BigInt(trimmed);
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
return value;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return value;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Normalizes timestamp values returned by SQL drivers into a valid `Date`.
|
|
52
|
+
*
|
|
53
|
+
* Accepts `Date` instances and parseable timestamp strings.
|
|
54
|
+
* Throws for invalid dates, empty strings, or unsupported value types.
|
|
55
|
+
*/
|
|
56
|
+
function timestampFromDriver(value, fieldName) {
|
|
57
|
+
const fieldLabel = (fieldName === null || fieldName === void 0 ? void 0 : fieldName.trim()) ? ` for "${fieldName}"` : '';
|
|
58
|
+
// Preserve valid Date instances while rejecting "Invalid Date".
|
|
59
|
+
if (value instanceof Date) {
|
|
60
|
+
if (Number.isNaN(value.getTime())) {
|
|
61
|
+
throw new Error(`Invalid Date value${fieldLabel}.`);
|
|
62
|
+
}
|
|
63
|
+
return value;
|
|
64
|
+
}
|
|
65
|
+
// Parse driver-returned timestamp strings after trimming transport whitespace.
|
|
66
|
+
if (typeof value === 'string') {
|
|
67
|
+
const trimmed = value.trim();
|
|
68
|
+
if (!trimmed) {
|
|
69
|
+
throw new Error(`Expected a non-empty timestamp string${fieldLabel}.`);
|
|
70
|
+
}
|
|
71
|
+
const timestamp = Date.parse(trimmed);
|
|
72
|
+
if (Number.isNaN(timestamp)) {
|
|
73
|
+
throw new Error(`Invalid timestamp string${fieldLabel}: "${value}".`);
|
|
74
|
+
}
|
|
75
|
+
return new Date(timestamp);
|
|
76
|
+
}
|
|
77
|
+
const actualType = value === null ? 'null' : typeof value;
|
|
78
|
+
throw new Error(`Expected Date or timestamp string${fieldLabel}, received ${actualType}.`);
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=coercions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coercions.js","sourceRoot":"","sources":["../../src/utils/coercions.ts"],"names":[],"mappings":";;AAOA,kEAeC;AAMD,oDAeC;AAQD,kDA+BC;AAlFD;;;;;;GAMG;AACH,SAAgB,2BAA2B,CAAC,KAAc;IACxD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAA;IACd,CAAC;IACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;QAC5B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,KAAK,CAAA;QACd,CAAC;QACD,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,CAAA;QAC9B,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5B,OAAO,MAAM,CAAA;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;;GAGG;AACH,SAAgB,oBAAoB,CAAC,KAAc;IACjD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAA;IACd,CAAC;IACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;QAC5B,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC;gBACH,OAAO,MAAM,CAAC,OAAO,CAAC,CAAA;YACxB,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,KAAK,CAAA;YACd,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;;;;GAKG;AACH,SAAgB,mBAAmB,CAAC,KAAc,EAAE,SAAkB;IACpE,MAAM,UAAU,GAAG,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,IAAI,EAAE,EAAC,CAAC,CAAC,SAAS,SAAS,GAAG,CAAC,CAAC,CAAC,EAAE,CAAA;IAEjE,gEAAgE;IAChE,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;QAC1B,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,KAAK,CAAC,qBAAqB,UAAU,GAAG,CAAC,CAAA;QACrD,CAAC;QACD,OAAO,KAAK,CAAA;IACd,CAAC;IAED,+EAA+E;IAC/E,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;QAC5B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,wCAAwC,UAAU,GAAG,CAAC,CAAA;QACxE,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QACrC,IAAI,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CACb,2BAA2B,UAAU,MAAM,KAAK,IAAI,CACrD,CAAA;QACH,CAAC;QACD,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,CAAA;IAC5B,CAAC;IAED,MAAM,UAAU,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,KAAK,CAAA;IACzD,MAAM,IAAI,KAAK,CACb,oCAAoC,UAAU,cAAc,UAAU,GAAG,CAC1E,CAAA;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rawsql-ts/sql-contract",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "Lightweight mapper and writer helpers that keep client SQL authoritative while exposing an explicit contract for data hydration and CUD emitters.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -17,6 +17,14 @@
|
|
|
17
17
|
"types": "./dist/mapper/*.d.ts",
|
|
18
18
|
"default": "./dist/mapper/*.js"
|
|
19
19
|
},
|
|
20
|
+
"./utils/coercions": {
|
|
21
|
+
"types": "./dist/utils/coercions.d.ts",
|
|
22
|
+
"default": "./dist/utils/coercions.js"
|
|
23
|
+
},
|
|
24
|
+
"./utils/*": {
|
|
25
|
+
"types": "./dist/utils/*.d.ts",
|
|
26
|
+
"default": "./dist/utils/*.js"
|
|
27
|
+
},
|
|
20
28
|
"./writer": {
|
|
21
29
|
"types": "./dist/writer/index.d.ts",
|
|
22
30
|
"default": "./dist/writer/index.js"
|
|
@@ -47,6 +55,7 @@
|
|
|
47
55
|
"node": ">=20"
|
|
48
56
|
},
|
|
49
57
|
"devDependencies": {
|
|
58
|
+
"zod": "^4.3.6",
|
|
50
59
|
"typescript": "^5.8.2",
|
|
51
60
|
"vitest": "^4.0.7",
|
|
52
61
|
"pg-promise": "^12.0.0"
|
|
@@ -57,6 +66,7 @@
|
|
|
57
66
|
"scripts": {
|
|
58
67
|
"build": "tsc -p tsconfig.json",
|
|
59
68
|
"test": "vitest run",
|
|
69
|
+
"test:integration": "vitest run --config ../../vitest.integration.config.ts",
|
|
60
70
|
"test:watch": "vitest",
|
|
61
71
|
"lint": "eslint src --ext .ts"
|
|
62
72
|
}
|