@pitininja/envious-zod 6.0.0-beta3
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 +56 -0
- package/dist/common/error.d.ts +21 -0
- package/dist/common/error.js +26 -0
- package/dist/common/error.js.map +1 -0
- package/dist/resolvers/zod/src/index.d.ts +7 -0
- package/dist/resolvers/zod/src/index.js +30 -0
- package/dist/resolvers/zod/src/index.js.map +1 -0
- package/package.json +22 -0
package/README.md
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# Envious Zod resolver
|
|
2
|
+
|
|
3
|
+
[](https://badge.fury.io/js/@pitininja%2Fenvious-zod)
|
|
4
|
+
|
|
5
|
+
> Only Zod v4 or superior is supported
|
|
6
|
+
|
|
7
|
+
- [Install](#install)
|
|
8
|
+
- [Usage](#usage)
|
|
9
|
+
- [About Zod schemas](#about-zod-schemas)
|
|
10
|
+
|
|
11
|
+
## Install
|
|
12
|
+
|
|
13
|
+
```shell
|
|
14
|
+
npm i @pitininja/envious-zod
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## Usage
|
|
18
|
+
|
|
19
|
+
```typescript
|
|
20
|
+
import { envious } from '@pitininja/envious';
|
|
21
|
+
import { zodResolver } from '@pitininja/envious-zod';
|
|
22
|
+
import * as z from 'zod';
|
|
23
|
+
|
|
24
|
+
const env = envious({
|
|
25
|
+
resolver: zodResolver({
|
|
26
|
+
schema: z.object({
|
|
27
|
+
STRING_VAR: z.string(),
|
|
28
|
+
NUMBER_VAR: z.coerce.number().int(),
|
|
29
|
+
BOOLEAN_VAR_WITH_DEFAULT: z.stringbool().default(true),
|
|
30
|
+
OPTIONAL_VAR: z.optional(z.string())
|
|
31
|
+
})
|
|
32
|
+
})
|
|
33
|
+
});
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
## About Zod schemas
|
|
37
|
+
|
|
38
|
+
Zod cannot programmatically convert object values from a schema. Therefore the conversion must happen at the schema level using :
|
|
39
|
+
|
|
40
|
+
- [coerce](https://zod.dev/api?id=coercion) for numbers
|
|
41
|
+
- [stringbool](https://zod.dev/api?id=stringbool) for booleans
|
|
42
|
+
|
|
43
|
+
```typescript
|
|
44
|
+
import { envious } from '@pitininja/envious';
|
|
45
|
+
import { zodResolver } from '@pitininja/envious-zod';
|
|
46
|
+
import * as z from 'zod';
|
|
47
|
+
|
|
48
|
+
const env = envious({
|
|
49
|
+
resolver: zodResolver({
|
|
50
|
+
schema: z.object({
|
|
51
|
+
NUMBER_VAR: z.coerce.number().int(),
|
|
52
|
+
BOOLEAN_VAR: z.stringbool()
|
|
53
|
+
})
|
|
54
|
+
})
|
|
55
|
+
});
|
|
56
|
+
```
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type EnviousErrorVariable = {
|
|
2
|
+
name: string;
|
|
3
|
+
messages: string[];
|
|
4
|
+
};
|
|
5
|
+
type EnviousErrorOptions = {
|
|
6
|
+
message?: string;
|
|
7
|
+
variables?: EnviousErrorVariable[];
|
|
8
|
+
};
|
|
9
|
+
export declare class EnviousError extends Error {
|
|
10
|
+
variables: EnviousErrorVariable[];
|
|
11
|
+
constructor({ message, variables }: EnviousErrorOptions);
|
|
12
|
+
}
|
|
13
|
+
type ResolverErrorsToEnviousErrorsOptions<T> = {
|
|
14
|
+
transform: (resolverError: T) => {
|
|
15
|
+
name: string;
|
|
16
|
+
message: string;
|
|
17
|
+
};
|
|
18
|
+
resolverErrors: T[];
|
|
19
|
+
};
|
|
20
|
+
export declare const resolverErrorsToEnviousErrors: <T>({ transform, resolverErrors }: ResolverErrorsToEnviousErrorsOptions<T>) => EnviousErrorVariable[];
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resolverErrorsToEnviousErrors = exports.EnviousError = void 0;
|
|
4
|
+
class EnviousError extends Error {
|
|
5
|
+
variables;
|
|
6
|
+
constructor({ message = 'Invalid environment variables', variables = [] }) {
|
|
7
|
+
super(message);
|
|
8
|
+
this.variables = variables;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.EnviousError = EnviousError;
|
|
12
|
+
const resolverErrorsToEnviousErrors = ({ transform, resolverErrors }) => {
|
|
13
|
+
const enviousErrors = [];
|
|
14
|
+
const validationErrorsMap = new Map();
|
|
15
|
+
for (const resolverError of resolverErrors) {
|
|
16
|
+
const { name, message } = transform(resolverError);
|
|
17
|
+
const errorMessages = validationErrorsMap.get(name);
|
|
18
|
+
validationErrorsMap.set(name, [...(errorMessages ?? []), message]);
|
|
19
|
+
}
|
|
20
|
+
for (const [name, messages] of validationErrorsMap.entries()) {
|
|
21
|
+
enviousErrors.push({ name, messages });
|
|
22
|
+
}
|
|
23
|
+
return enviousErrors;
|
|
24
|
+
};
|
|
25
|
+
exports.resolverErrorsToEnviousErrors = resolverErrorsToEnviousErrors;
|
|
26
|
+
//# sourceMappingURL=error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../../../common/error.ts"],"names":[],"mappings":";;;AAUA,kBAA0B,SAAQ,KAAK;IACnC,SAAS,CAAyB;IAClC,YAAY,EACR,OAAO,GAAG,+BAA+B,EACzC,SAAS,GAAG,EAAE,EACI,EAAE;QACpB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAAA,CAC9B;CACJ;;AAUM,MAAM,6BAA6B,GAAG,CAAI,EAC7C,SAAS,EACT,cAAc,EACwB,EAAE,EAAE,CAAC;IAC3C,MAAM,aAAa,GAA2B,EAAE,CAAC;IACjD,MAAM,mBAAmB,GAAG,IAAI,GAAG,EAAoB,CAAC;IACxD,KAAK,MAAM,aAAa,IAAI,cAAc,EAAE,CAAC;QACzC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,SAAS,CAAC,aAAa,CAAC,CAAC;QACnD,MAAM,aAAa,GAAG,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACpD,mBAAmB,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,aAAa,IAAI,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;IACvE,CAAC;IACD,KAAK,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,mBAAmB,CAAC,OAAO,EAAE,EAAE,CAAC;QAC3D,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3C,CAAC;IACD,OAAO,aAAa,CAAC;AAAA,CACxB,CAAC;AAfW,QAAA,6BAA6B,GAA7B,6BAA6B,CAexC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type core as ZodCore, type infer as ZodInfer, type ZodObject } from 'zod';
|
|
2
|
+
type EnviousZodResolver<T extends ZodObject> = (env: NodeJS.ProcessEnv) => ZodInfer<T>;
|
|
3
|
+
export type EnviousZodResolverOptions<T extends ZodObject> = {
|
|
4
|
+
schema: T;
|
|
5
|
+
};
|
|
6
|
+
export declare const zodResolver: <T extends ZodObject<ZodCore.$ZodLooseShape, ZodCore.$strip>>({ schema }: EnviousZodResolverOptions<T>) => EnviousZodResolver<T>;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.zodResolver = void 0;
|
|
4
|
+
const zod_1 = require("zod");
|
|
5
|
+
const error_1 = require("../../../common/error");
|
|
6
|
+
const zodIssuesToEnviousErrors = (zodIssues) => {
|
|
7
|
+
return (0, error_1.resolverErrorsToEnviousErrors)({
|
|
8
|
+
resolverErrors: zodIssues,
|
|
9
|
+
transform: (zodIssue) => {
|
|
10
|
+
const { path, message } = zodIssue;
|
|
11
|
+
return { name: path.join('/'), message };
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
const zodResolver = ({ schema }) => {
|
|
16
|
+
return (env) => {
|
|
17
|
+
const { success, data, error } = zod_1.z.safeParse(schema, env);
|
|
18
|
+
if (success && data) {
|
|
19
|
+
return data;
|
|
20
|
+
}
|
|
21
|
+
if (error) {
|
|
22
|
+
throw new error_1.EnviousError({
|
|
23
|
+
variables: zodIssuesToEnviousErrors(error.issues)
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
throw new Error();
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
exports.zodResolver = zodResolver;
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/index.ts"],"names":[],"mappings":";;;AAAA,6BAKa;AACb,iDAI+B;AAU/B,MAAM,wBAAwB,GAAG,CAC7B,SAA8B,EACR,EAAE,CAAC;IACzB,OAAO,IAAA,qCAA6B,EAAC;QACjC,cAAc,EAAE,SAAS;QACzB,SAAS,EAAE,CAAC,QAA2B,EAAE,EAAE,CAAC;YACxC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,QAAQ,CAAC;YACnC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC;QAAA,CAC5C;KACJ,CAAC,CAAC;AAAA,CACN,CAAC;AAEK,MAAM,WAAW,GAAG,CAAsB,EAC7C,MAAM,EACqB,EAAyB,EAAE,CAAC;IACvD,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;QACZ,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,OAAC,CAAC,SAAS,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC1D,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,IAAI,KAAK,EAAE,CAAC;YACR,MAAM,IAAI,oBAAY,CAAC;gBACnB,SAAS,EAAE,wBAAwB,CAAC,KAAK,CAAC,MAAM,CAAC;aACpD,CAAC,CAAC;QACP,CAAC;QACD,MAAM,IAAI,KAAK,EAAE,CAAC;IAAA,CACrB,CAAC;AAAA,CACL,CAAC;AAfW,QAAA,WAAW,GAAX,WAAW,CAetB"}
|
package/package.json
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@pitininja/envious-zod",
|
|
3
|
+
"version": "6.0.0-beta3",
|
|
4
|
+
"license": "AGPL-3.0-or-later",
|
|
5
|
+
"homepage": "https://codeberg.org/pitininja/envious",
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "https://codeberg.org/pitininja/envious"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"./dist",
|
|
12
|
+
"./package.json"
|
|
13
|
+
],
|
|
14
|
+
"main": "./dist/index.js",
|
|
15
|
+
"types": "./dist/index.d.ts",
|
|
16
|
+
"scripts": {
|
|
17
|
+
"build": "npx tsgo --build --clean tsconfig.json && npx tsgo -b ./tsconfig.json"
|
|
18
|
+
},
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"zod": "^4.1.11"
|
|
21
|
+
}
|
|
22
|
+
}
|