@geekmidas/envkit 0.0.6 → 0.0.8
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/{EnvironmentParser-C-arQEHQ.d.mts → EnvironmentParser-B8--woiB.d.cts} +40 -2
- package/dist/{EnvironmentParser-X4h2Vp4r.d.cts → EnvironmentParser-C_9v2BDw.d.mts} +40 -2
- package/dist/{EnvironmentParser-CQUOGqc0.mjs → EnvironmentParser-STvN_RCc.mjs} +46 -3
- package/dist/EnvironmentParser-STvN_RCc.mjs.map +1 -0
- package/dist/{EnvironmentParser-BDPDLv6i.cjs → EnvironmentParser-cnxuy7lw.cjs} +46 -3
- package/dist/EnvironmentParser-cnxuy7lw.cjs.map +1 -0
- package/dist/EnvironmentParser.cjs +1 -1
- package/dist/EnvironmentParser.d.cts +1 -1
- package/dist/EnvironmentParser.d.mts +1 -1
- package/dist/EnvironmentParser.mjs +1 -1
- package/dist/SnifferEnvironmentParser.cjs +140 -0
- package/dist/SnifferEnvironmentParser.cjs.map +1 -0
- package/dist/SnifferEnvironmentParser.d.cts +50 -0
- package/dist/SnifferEnvironmentParser.d.mts +50 -0
- package/dist/SnifferEnvironmentParser.mjs +139 -0
- package/dist/SnifferEnvironmentParser.mjs.map +1 -0
- package/dist/index.cjs +2 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.mts +2 -2
- package/dist/index.mjs +2 -2
- package/dist/sst.cjs +131 -4
- package/dist/sst.cjs.map +1 -0
- package/dist/sst.d.cts +2 -1
- package/dist/sst.d.mts +2 -1
- package/dist/sst.mjs +128 -2
- package/dist/sst.mjs.map +1 -0
- package/package.json +9 -2
- package/src/EnvironmentParser.ts +51 -2
- package/src/SnifferEnvironmentParser.ts +207 -0
- package/src/__tests__/EnvironmentParser.spec.ts +147 -0
- package/src/__tests__/SnifferEnvironmentParser.spec.ts +332 -0
- package/src/__tests__/sst.spec.ts +9 -6
- package/src/index.ts +1 -1
- package/dist/__tests__/ConfigParser.spec.cjs +0 -323
- package/dist/__tests__/ConfigParser.spec.d.cts +0 -1
- package/dist/__tests__/ConfigParser.spec.d.mts +0 -1
- package/dist/__tests__/ConfigParser.spec.mjs +0 -322
- package/dist/__tests__/EnvironmentParser.spec.cjs +0 -422
- package/dist/__tests__/EnvironmentParser.spec.d.cts +0 -1
- package/dist/__tests__/EnvironmentParser.spec.d.mts +0 -1
- package/dist/__tests__/EnvironmentParser.spec.mjs +0 -421
- package/dist/__tests__/sst.spec.cjs +0 -305
- package/dist/__tests__/sst.spec.d.cts +0 -1
- package/dist/__tests__/sst.spec.d.mts +0 -1
- package/dist/__tests__/sst.spec.mjs +0 -304
- package/dist/sst-BSxwaAdz.cjs +0 -146
- package/dist/sst-CQhO0S6y.mjs +0 -128
|
@@ -10,17 +10,36 @@ import { z } from "zod/v4";
|
|
|
10
10
|
*/
|
|
11
11
|
declare class ConfigParser<TResponse extends EmptyObject> {
|
|
12
12
|
private readonly config;
|
|
13
|
+
private readonly envVars;
|
|
13
14
|
/**
|
|
14
15
|
* Creates a new ConfigParser instance.
|
|
15
16
|
*
|
|
16
17
|
* @param config - The configuration object to parse
|
|
18
|
+
* @param envVars - Set of environment variable names that were accessed
|
|
17
19
|
*/
|
|
18
|
-
constructor(config: TResponse);
|
|
20
|
+
constructor(config: TResponse, envVars?: Set<string>);
|
|
19
21
|
/**
|
|
20
22
|
* Parses the config object and validates it against the Zod schemas
|
|
21
23
|
* @returns The parsed config object
|
|
22
24
|
*/
|
|
23
25
|
parse(): InferConfig<TResponse>;
|
|
26
|
+
/**
|
|
27
|
+
* Returns an array of environment variable names that were accessed during config creation.
|
|
28
|
+
* This is useful for deployment and configuration management to know which env vars are required.
|
|
29
|
+
*
|
|
30
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const config = envParser.create((get) => ({
|
|
35
|
+
* dbUrl: get('DATABASE_URL').string(),
|
|
36
|
+
* port: get('PORT').number()
|
|
37
|
+
* }));
|
|
38
|
+
*
|
|
39
|
+
* config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
getEnvironmentVariables(): string[];
|
|
24
43
|
}
|
|
25
44
|
/**
|
|
26
45
|
* Parses environment variables with type-safe validation using Zod schemas.
|
|
@@ -43,6 +62,10 @@ declare class ConfigParser<TResponse extends EmptyObject> {
|
|
|
43
62
|
*/
|
|
44
63
|
declare class EnvironmentParser<T extends EmptyObject> {
|
|
45
64
|
private readonly config;
|
|
65
|
+
/**
|
|
66
|
+
* Set to track which environment variable names have been accessed
|
|
67
|
+
*/
|
|
68
|
+
private readonly accessedVars;
|
|
46
69
|
/**
|
|
47
70
|
* Creates a new EnvironmentParser instance.
|
|
48
71
|
*
|
|
@@ -73,6 +96,20 @@ declare class EnvironmentParser<T extends EmptyObject> {
|
|
|
73
96
|
* @returns A ConfigParser object that can be used to parse the config object
|
|
74
97
|
*/
|
|
75
98
|
create<TReturn extends EmptyObject>(builder: (get: EnvFetcher) => TReturn): ConfigParser<TReturn>;
|
|
99
|
+
/**
|
|
100
|
+
* Returns an array of environment variable names that were accessed via the getter.
|
|
101
|
+
* This is useful for build-time analysis to determine which env vars a service needs.
|
|
102
|
+
*
|
|
103
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
104
|
+
*
|
|
105
|
+
* @example
|
|
106
|
+
* ```typescript
|
|
107
|
+
* const sniffer = new EnvironmentParser({});
|
|
108
|
+
* service.register(sniffer);
|
|
109
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
110
|
+
* ```
|
|
111
|
+
*/
|
|
112
|
+
getEnvironmentVariables(): string[];
|
|
76
113
|
}
|
|
77
114
|
/**
|
|
78
115
|
* Infers the TypeScript type of a configuration object based on its Zod schemas.
|
|
@@ -105,4 +142,5 @@ type EnvironmentBuilder<TResponse extends EmptyObject> = (get: EnvFetcher) => TR
|
|
|
105
142
|
*/
|
|
106
143
|
type EmptyObject = Record<string | number | symbol, unknown>;
|
|
107
144
|
//#endregion
|
|
108
|
-
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
145
|
+
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
146
|
+
//# sourceMappingURL=EnvironmentParser-B8--woiB.d.cts.map
|
|
@@ -10,17 +10,36 @@ import { z } from "zod/v4";
|
|
|
10
10
|
*/
|
|
11
11
|
declare class ConfigParser<TResponse extends EmptyObject> {
|
|
12
12
|
private readonly config;
|
|
13
|
+
private readonly envVars;
|
|
13
14
|
/**
|
|
14
15
|
* Creates a new ConfigParser instance.
|
|
15
16
|
*
|
|
16
17
|
* @param config - The configuration object to parse
|
|
18
|
+
* @param envVars - Set of environment variable names that were accessed
|
|
17
19
|
*/
|
|
18
|
-
constructor(config: TResponse);
|
|
20
|
+
constructor(config: TResponse, envVars?: Set<string>);
|
|
19
21
|
/**
|
|
20
22
|
* Parses the config object and validates it against the Zod schemas
|
|
21
23
|
* @returns The parsed config object
|
|
22
24
|
*/
|
|
23
25
|
parse(): InferConfig<TResponse>;
|
|
26
|
+
/**
|
|
27
|
+
* Returns an array of environment variable names that were accessed during config creation.
|
|
28
|
+
* This is useful for deployment and configuration management to know which env vars are required.
|
|
29
|
+
*
|
|
30
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const config = envParser.create((get) => ({
|
|
35
|
+
* dbUrl: get('DATABASE_URL').string(),
|
|
36
|
+
* port: get('PORT').number()
|
|
37
|
+
* }));
|
|
38
|
+
*
|
|
39
|
+
* config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
getEnvironmentVariables(): string[];
|
|
24
43
|
}
|
|
25
44
|
/**
|
|
26
45
|
* Parses environment variables with type-safe validation using Zod schemas.
|
|
@@ -43,6 +62,10 @@ declare class ConfigParser<TResponse extends EmptyObject> {
|
|
|
43
62
|
*/
|
|
44
63
|
declare class EnvironmentParser<T extends EmptyObject> {
|
|
45
64
|
private readonly config;
|
|
65
|
+
/**
|
|
66
|
+
* Set to track which environment variable names have been accessed
|
|
67
|
+
*/
|
|
68
|
+
private readonly accessedVars;
|
|
46
69
|
/**
|
|
47
70
|
* Creates a new EnvironmentParser instance.
|
|
48
71
|
*
|
|
@@ -73,6 +96,20 @@ declare class EnvironmentParser<T extends EmptyObject> {
|
|
|
73
96
|
* @returns A ConfigParser object that can be used to parse the config object
|
|
74
97
|
*/
|
|
75
98
|
create<TReturn extends EmptyObject>(builder: (get: EnvFetcher) => TReturn): ConfigParser<TReturn>;
|
|
99
|
+
/**
|
|
100
|
+
* Returns an array of environment variable names that were accessed via the getter.
|
|
101
|
+
* This is useful for build-time analysis to determine which env vars a service needs.
|
|
102
|
+
*
|
|
103
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
104
|
+
*
|
|
105
|
+
* @example
|
|
106
|
+
* ```typescript
|
|
107
|
+
* const sniffer = new EnvironmentParser({});
|
|
108
|
+
* service.register(sniffer);
|
|
109
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
110
|
+
* ```
|
|
111
|
+
*/
|
|
112
|
+
getEnvironmentVariables(): string[];
|
|
76
113
|
}
|
|
77
114
|
/**
|
|
78
115
|
* Infers the TypeScript type of a configuration object based on its Zod schemas.
|
|
@@ -105,4 +142,5 @@ type EnvironmentBuilder<TResponse extends EmptyObject> = (get: EnvFetcher) => TR
|
|
|
105
142
|
*/
|
|
106
143
|
type EmptyObject = Record<string | number | symbol, unknown>;
|
|
107
144
|
//#endregion
|
|
108
|
-
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
145
|
+
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
146
|
+
//# sourceMappingURL=EnvironmentParser-C_9v2BDw.d.mts.map
|
|
@@ -14,9 +14,11 @@ var ConfigParser = class {
|
|
|
14
14
|
* Creates a new ConfigParser instance.
|
|
15
15
|
*
|
|
16
16
|
* @param config - The configuration object to parse
|
|
17
|
+
* @param envVars - Set of environment variable names that were accessed
|
|
17
18
|
*/
|
|
18
|
-
constructor(config) {
|
|
19
|
+
constructor(config, envVars = /* @__PURE__ */ new Set()) {
|
|
19
20
|
this.config = config;
|
|
21
|
+
this.envVars = envVars;
|
|
20
22
|
}
|
|
21
23
|
/**
|
|
22
24
|
* Parses the config object and validates it against the Zod schemas
|
|
@@ -45,6 +47,25 @@ var ConfigParser = class {
|
|
|
45
47
|
if (errors.length > 0) throw new z.ZodError(errors);
|
|
46
48
|
return parsedConfig;
|
|
47
49
|
}
|
|
50
|
+
/**
|
|
51
|
+
* Returns an array of environment variable names that were accessed during config creation.
|
|
52
|
+
* This is useful for deployment and configuration management to know which env vars are required.
|
|
53
|
+
*
|
|
54
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
55
|
+
*
|
|
56
|
+
* @example
|
|
57
|
+
* ```typescript
|
|
58
|
+
* const config = envParser.create((get) => ({
|
|
59
|
+
* dbUrl: get('DATABASE_URL').string(),
|
|
60
|
+
* port: get('PORT').number()
|
|
61
|
+
* }));
|
|
62
|
+
*
|
|
63
|
+
* config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
64
|
+
* ```
|
|
65
|
+
*/
|
|
66
|
+
getEnvironmentVariables() {
|
|
67
|
+
return Array.from(this.envVars).sort();
|
|
68
|
+
}
|
|
48
69
|
};
|
|
49
70
|
/**
|
|
50
71
|
* Parses environment variables with type-safe validation using Zod schemas.
|
|
@@ -66,6 +87,10 @@ var ConfigParser = class {
|
|
|
66
87
|
* ```
|
|
67
88
|
*/
|
|
68
89
|
var EnvironmentParser = class {
|
|
90
|
+
/**
|
|
91
|
+
* Set to track which environment variable names have been accessed
|
|
92
|
+
*/
|
|
93
|
+
accessedVars = /* @__PURE__ */ new Set();
|
|
69
94
|
/**
|
|
70
95
|
* Creates a new EnvironmentParser instance.
|
|
71
96
|
*
|
|
@@ -133,6 +158,7 @@ var EnvironmentParser = class {
|
|
|
133
158
|
* @returns A proxied Zod object with wrapped schema creators
|
|
134
159
|
*/
|
|
135
160
|
getZodGetter = (name) => {
|
|
161
|
+
this.accessedVars.add(name);
|
|
136
162
|
return new Proxy({ ...z }, { get: (target, prop) => {
|
|
137
163
|
const value = target[prop];
|
|
138
164
|
if (typeof value === "function") return (...args) => {
|
|
@@ -158,9 +184,26 @@ var EnvironmentParser = class {
|
|
|
158
184
|
*/
|
|
159
185
|
create(builder) {
|
|
160
186
|
const config = builder(this.getZodGetter);
|
|
161
|
-
return new ConfigParser(config);
|
|
187
|
+
return new ConfigParser(config, this.accessedVars);
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Returns an array of environment variable names that were accessed via the getter.
|
|
191
|
+
* This is useful for build-time analysis to determine which env vars a service needs.
|
|
192
|
+
*
|
|
193
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
194
|
+
*
|
|
195
|
+
* @example
|
|
196
|
+
* ```typescript
|
|
197
|
+
* const sniffer = new EnvironmentParser({});
|
|
198
|
+
* service.register(sniffer);
|
|
199
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
200
|
+
* ```
|
|
201
|
+
*/
|
|
202
|
+
getEnvironmentVariables() {
|
|
203
|
+
return Array.from(this.accessedVars).sort();
|
|
162
204
|
}
|
|
163
205
|
};
|
|
164
206
|
|
|
165
207
|
//#endregion
|
|
166
|
-
export { ConfigParser, EnvironmentParser };
|
|
208
|
+
export { ConfigParser, EnvironmentParser };
|
|
209
|
+
//# sourceMappingURL=EnvironmentParser-STvN_RCc.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnvironmentParser-STvN_RCc.mjs","names":["config: TResponse","envVars: Set<string>","errors: z.core.$ZodIssue[]","config: T","path: string[]","result: EmptyObject","schema: z.ZodType","name: string","issue: z.core.$ZodIssue","builder: (get: EnvFetcher) => TReturn"],"sources":["../src/EnvironmentParser.ts"],"sourcesContent":["import get from 'lodash.get';\nimport set from 'lodash.set';\nimport { z } from 'zod/v4';\n\n/**\n * Parses and validates configuration objects against Zod schemas.\n * Handles nested configurations and aggregates validation errors.\n *\n * @template TResponse - The shape of the configuration object\n */\nexport class ConfigParser<TResponse extends EmptyObject> {\n /**\n * Creates a new ConfigParser instance.\n *\n * @param config - The configuration object to parse\n * @param envVars - Set of environment variable names that were accessed\n */\n constructor(\n private readonly config: TResponse,\n private readonly envVars: Set<string> = new Set(),\n ) {}\n /**\n * Parses the config object and validates it against the Zod schemas\n * @returns The parsed config object\n */\n parse(): InferConfig<TResponse> {\n const errors: z.core.$ZodIssue[] = [];\n\n const parseDeep = <T>(config: T, path: string[] = []) => {\n const result: EmptyObject = {};\n\n if (config && typeof config !== 'object') {\n return config;\n }\n\n for (const key in config) {\n const schema = config[key];\n const currentPath = [...path, key];\n\n if (schema instanceof z.ZodType) {\n const parsed = schema.safeParse(undefined);\n if (parsed.success) {\n set(result, key, parsed.data);\n } else {\n // If the schema is invalid, assign the error\n errors.push(\n ...parsed.error.issues.map((issue) => ({\n ...issue,\n path: [...currentPath, ...(issue.path as string[])],\n })),\n );\n }\n } else if (schema) {\n set(result, key, parseDeep(schema as EmptyObject, currentPath));\n }\n }\n\n return result;\n };\n\n const parsedConfig = parseDeep(\n this.config,\n ) as unknown as InferConfig<TResponse>;\n\n if (errors.length > 0) {\n // If there are errors, throw them\n throw new z.ZodError(errors);\n }\n\n return parsedConfig;\n }\n\n /**\n * Returns an array of environment variable names that were accessed during config creation.\n * This is useful for deployment and configuration management to know which env vars are required.\n *\n * @returns Array of environment variable names, sorted alphabetically\n *\n * @example\n * ```typescript\n * const config = envParser.create((get) => ({\n * dbUrl: get('DATABASE_URL').string(),\n * port: get('PORT').number()\n * }));\n *\n * config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']\n * ```\n */\n getEnvironmentVariables(): string[] {\n return Array.from(this.envVars).sort();\n }\n}\n\n/**\n * Parses environment variables with type-safe validation using Zod schemas.\n * Provides a fluent API for defining environment variable schemas with automatic\n * error context enrichment.\n *\n * @template T - The type of the configuration object (typically process.env)\n *\n * @example\n * ```typescript\n * const config = new EnvironmentParser(process.env)\n * .create((get) => ({\n * port: get('PORT').string().transform(Number).default(3000),\n * database: {\n * url: get('DATABASE_URL').string().url()\n * }\n * }))\n * .parse();\n * ```\n */\nexport class EnvironmentParser<T extends EmptyObject> {\n /**\n * Set to track which environment variable names have been accessed\n */\n private readonly accessedVars: Set<string> = new Set();\n\n /**\n * Creates a new EnvironmentParser instance.\n *\n * @param config - The configuration object to parse (typically process.env)\n */\n constructor(private readonly config: T) {}\n\n /**\n * Wraps a Zod schema to intercept parse/safeParse calls and enrich error messages\n * with environment variable context.\n *\n * @param schema - The Zod schema to wrap\n * @param name - The environment variable name for error context\n * @returns A wrapped Zod schema with enhanced error reporting\n */\n private wrapSchema = (schema: z.ZodType, name: string): z.ZodType => {\n // Create a proxy that intercepts all method calls on the schema\n return new Proxy(schema, {\n get: (target, prop) => {\n if (prop === 'parse') {\n return () => {\n const value = get(this.config, name);\n try {\n return target.parse(value);\n } catch (error) {\n if (error instanceof z.ZodError) {\n // Modify the error to include the environment variable name\n const modifiedIssues = error.issues.map((issue) => ({\n ...issue,\n message: `Environment variable \"${name}\": ${issue.message}`,\n path: [name, ...issue.path],\n }));\n throw new z.ZodError(modifiedIssues);\n }\n throw error;\n }\n };\n }\n\n if (prop === 'safeParse') {\n return () => {\n const value = get(this.config, name);\n const result = target.safeParse(value);\n\n if (!result.success) {\n // Modify the error to include the environment variable name\n const modifiedIssues = result.error.issues.map(\n (issue: z.core.$ZodIssue) => ({\n ...issue,\n message: `Environment variable \"${name}\": ${issue.message}`,\n path: [name, ...issue.path],\n }),\n );\n return {\n success: false as const,\n error: new z.ZodError(modifiedIssues),\n };\n }\n\n return result;\n };\n }\n\n // For any method that returns a new schema (like transform, optional, etc.),\n // wrap the result as well\n const originalProp = target[prop as keyof typeof target];\n if (typeof originalProp === 'function') {\n return (...args: any[]) => {\n const result = originalProp.apply(target, args);\n // If the result is a ZodType, wrap it too\n if (result && typeof result === 'object' && 'parse' in result) {\n return this.wrapSchema(result, name);\n }\n return result;\n };\n }\n\n return originalProp;\n },\n });\n };\n\n /**\n * Creates a proxied version of the Zod object that wraps all schema creators\n * to provide enhanced error messages with environment variable context.\n *\n * @param name - The environment variable name\n * @returns A proxied Zod object with wrapped schema creators\n */\n private getZodGetter = (name: string) => {\n // Track that this environment variable was accessed\n this.accessedVars.add(name);\n\n // Return an object that has all Zod schemas but with our wrapper\n return new Proxy(\n { ...z },\n {\n get: (target, prop) => {\n // deno-lint-ignore ban-ts-comment\n // @ts-ignore\n const value = target[prop];\n\n if (typeof value === 'function') {\n // Return a wrapper around each Zod schema creator\n return (...args: any[]) => {\n const schema = value(...args);\n return this.wrapSchema(schema, name);\n };\n }\n\n // Handle objects like z.coerce\n if (value && typeof value === 'object') {\n return new Proxy(value, {\n get: (nestedTarget, nestedProp) => {\n const nestedValue =\n nestedTarget[nestedProp as keyof typeof nestedTarget];\n if (typeof nestedValue === 'function') {\n return (...args: any[]) => {\n const schema = nestedValue(...args);\n return this.wrapSchema(schema, name);\n };\n }\n return nestedValue;\n },\n });\n }\n\n return value;\n },\n },\n );\n };\n\n /**\n * Creates a new ConfigParser object that can be used to parse the config object\n *\n * @param builder - A function that takes a getter function and returns a config object\n * @returns A ConfigParser object that can be used to parse the config object\n */\n create<TReturn extends EmptyObject>(\n builder: (get: EnvFetcher) => TReturn,\n ): ConfigParser<TReturn> {\n const config = builder(this.getZodGetter);\n return new ConfigParser(config, this.accessedVars);\n }\n\n /**\n * Returns an array of environment variable names that were accessed via the getter.\n * This is useful for build-time analysis to determine which env vars a service needs.\n *\n * @returns Array of environment variable names, sorted alphabetically\n *\n * @example\n * ```typescript\n * const sniffer = new EnvironmentParser({});\n * service.register(sniffer);\n * const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']\n * ```\n */\n getEnvironmentVariables(): string[] {\n return Array.from(this.accessedVars).sort();\n }\n}\n\n/**\n * Infers the TypeScript type of a configuration object based on its Zod schemas.\n * Recursively processes nested objects and extracts types from Zod schemas.\n *\n * @template T - The configuration object type\n */\nexport type InferConfig<T extends EmptyObject> = {\n [K in keyof T]: T[K] extends z.ZodSchema\n ? z.infer<T[K]>\n : T[K] extends Record<string, unknown>\n ? InferConfig<T[K]>\n : T[K];\n};\n\n/**\n * Function type for fetching environment variables with Zod validation.\n * Returns a Zod object scoped to a specific environment variable.\n *\n * @template TPath - The environment variable path type\n * @param name - The environment variable name\n * @returns A Zod object for defining the schema\n */\nexport type EnvFetcher<TPath extends string = string> = (\n name: TPath,\n) => typeof z;\n\n/**\n * Function type for building environment configuration objects.\n * Takes an EnvFetcher and returns a configuration object with Zod schemas.\n *\n * @template TResponse - The response configuration object type\n * @param get - The environment variable fetcher function\n * @returns The configuration object with Zod schemas\n */\nexport type EnvironmentBuilder<TResponse extends EmptyObject> = (\n get: EnvFetcher,\n) => TResponse;\n\n/**\n * Type alias for a generic object with unknown values.\n * Used as a constraint for configuration objects.\n */\nexport type EmptyObject = Record<string | number | symbol, unknown>;\n"],"mappings":"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"}
|
|
@@ -15,9 +15,11 @@ var ConfigParser = class {
|
|
|
15
15
|
* Creates a new ConfigParser instance.
|
|
16
16
|
*
|
|
17
17
|
* @param config - The configuration object to parse
|
|
18
|
+
* @param envVars - Set of environment variable names that were accessed
|
|
18
19
|
*/
|
|
19
|
-
constructor(config) {
|
|
20
|
+
constructor(config, envVars = /* @__PURE__ */ new Set()) {
|
|
20
21
|
this.config = config;
|
|
22
|
+
this.envVars = envVars;
|
|
21
23
|
}
|
|
22
24
|
/**
|
|
23
25
|
* Parses the config object and validates it against the Zod schemas
|
|
@@ -46,6 +48,25 @@ var ConfigParser = class {
|
|
|
46
48
|
if (errors.length > 0) throw new zod_v4.z.ZodError(errors);
|
|
47
49
|
return parsedConfig;
|
|
48
50
|
}
|
|
51
|
+
/**
|
|
52
|
+
* Returns an array of environment variable names that were accessed during config creation.
|
|
53
|
+
* This is useful for deployment and configuration management to know which env vars are required.
|
|
54
|
+
*
|
|
55
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* ```typescript
|
|
59
|
+
* const config = envParser.create((get) => ({
|
|
60
|
+
* dbUrl: get('DATABASE_URL').string(),
|
|
61
|
+
* port: get('PORT').number()
|
|
62
|
+
* }));
|
|
63
|
+
*
|
|
64
|
+
* config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
65
|
+
* ```
|
|
66
|
+
*/
|
|
67
|
+
getEnvironmentVariables() {
|
|
68
|
+
return Array.from(this.envVars).sort();
|
|
69
|
+
}
|
|
49
70
|
};
|
|
50
71
|
/**
|
|
51
72
|
* Parses environment variables with type-safe validation using Zod schemas.
|
|
@@ -67,6 +88,10 @@ var ConfigParser = class {
|
|
|
67
88
|
* ```
|
|
68
89
|
*/
|
|
69
90
|
var EnvironmentParser = class {
|
|
91
|
+
/**
|
|
92
|
+
* Set to track which environment variable names have been accessed
|
|
93
|
+
*/
|
|
94
|
+
accessedVars = /* @__PURE__ */ new Set();
|
|
70
95
|
/**
|
|
71
96
|
* Creates a new EnvironmentParser instance.
|
|
72
97
|
*
|
|
@@ -134,6 +159,7 @@ var EnvironmentParser = class {
|
|
|
134
159
|
* @returns A proxied Zod object with wrapped schema creators
|
|
135
160
|
*/
|
|
136
161
|
getZodGetter = (name) => {
|
|
162
|
+
this.accessedVars.add(name);
|
|
137
163
|
return new Proxy({ ...zod_v4.z }, { get: (target, prop) => {
|
|
138
164
|
const value = target[prop];
|
|
139
165
|
if (typeof value === "function") return (...args) => {
|
|
@@ -159,7 +185,23 @@ var EnvironmentParser = class {
|
|
|
159
185
|
*/
|
|
160
186
|
create(builder) {
|
|
161
187
|
const config = builder(this.getZodGetter);
|
|
162
|
-
return new ConfigParser(config);
|
|
188
|
+
return new ConfigParser(config, this.accessedVars);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Returns an array of environment variable names that were accessed via the getter.
|
|
192
|
+
* This is useful for build-time analysis to determine which env vars a service needs.
|
|
193
|
+
*
|
|
194
|
+
* @returns Array of environment variable names, sorted alphabetically
|
|
195
|
+
*
|
|
196
|
+
* @example
|
|
197
|
+
* ```typescript
|
|
198
|
+
* const sniffer = new EnvironmentParser({});
|
|
199
|
+
* service.register(sniffer);
|
|
200
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']
|
|
201
|
+
* ```
|
|
202
|
+
*/
|
|
203
|
+
getEnvironmentVariables() {
|
|
204
|
+
return Array.from(this.accessedVars).sort();
|
|
163
205
|
}
|
|
164
206
|
};
|
|
165
207
|
|
|
@@ -175,4 +217,5 @@ Object.defineProperty(exports, 'EnvironmentParser', {
|
|
|
175
217
|
get: function () {
|
|
176
218
|
return EnvironmentParser;
|
|
177
219
|
}
|
|
178
|
-
});
|
|
220
|
+
});
|
|
221
|
+
//# sourceMappingURL=EnvironmentParser-cnxuy7lw.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnvironmentParser-cnxuy7lw.cjs","names":["config: TResponse","envVars: Set<string>","errors: z.core.$ZodIssue[]","config: T","path: string[]","result: EmptyObject","z","schema: z.ZodType","name: string","issue: z.core.$ZodIssue","builder: (get: EnvFetcher) => TReturn"],"sources":["../src/EnvironmentParser.ts"],"sourcesContent":["import get from 'lodash.get';\nimport set from 'lodash.set';\nimport { z } from 'zod/v4';\n\n/**\n * Parses and validates configuration objects against Zod schemas.\n * Handles nested configurations and aggregates validation errors.\n *\n * @template TResponse - The shape of the configuration object\n */\nexport class ConfigParser<TResponse extends EmptyObject> {\n /**\n * Creates a new ConfigParser instance.\n *\n * @param config - The configuration object to parse\n * @param envVars - Set of environment variable names that were accessed\n */\n constructor(\n private readonly config: TResponse,\n private readonly envVars: Set<string> = new Set(),\n ) {}\n /**\n * Parses the config object and validates it against the Zod schemas\n * @returns The parsed config object\n */\n parse(): InferConfig<TResponse> {\n const errors: z.core.$ZodIssue[] = [];\n\n const parseDeep = <T>(config: T, path: string[] = []) => {\n const result: EmptyObject = {};\n\n if (config && typeof config !== 'object') {\n return config;\n }\n\n for (const key in config) {\n const schema = config[key];\n const currentPath = [...path, key];\n\n if (schema instanceof z.ZodType) {\n const parsed = schema.safeParse(undefined);\n if (parsed.success) {\n set(result, key, parsed.data);\n } else {\n // If the schema is invalid, assign the error\n errors.push(\n ...parsed.error.issues.map((issue) => ({\n ...issue,\n path: [...currentPath, ...(issue.path as string[])],\n })),\n );\n }\n } else if (schema) {\n set(result, key, parseDeep(schema as EmptyObject, currentPath));\n }\n }\n\n return result;\n };\n\n const parsedConfig = parseDeep(\n this.config,\n ) as unknown as InferConfig<TResponse>;\n\n if (errors.length > 0) {\n // If there are errors, throw them\n throw new z.ZodError(errors);\n }\n\n return parsedConfig;\n }\n\n /**\n * Returns an array of environment variable names that were accessed during config creation.\n * This is useful for deployment and configuration management to know which env vars are required.\n *\n * @returns Array of environment variable names, sorted alphabetically\n *\n * @example\n * ```typescript\n * const config = envParser.create((get) => ({\n * dbUrl: get('DATABASE_URL').string(),\n * port: get('PORT').number()\n * }));\n *\n * config.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']\n * ```\n */\n getEnvironmentVariables(): string[] {\n return Array.from(this.envVars).sort();\n }\n}\n\n/**\n * Parses environment variables with type-safe validation using Zod schemas.\n * Provides a fluent API for defining environment variable schemas with automatic\n * error context enrichment.\n *\n * @template T - The type of the configuration object (typically process.env)\n *\n * @example\n * ```typescript\n * const config = new EnvironmentParser(process.env)\n * .create((get) => ({\n * port: get('PORT').string().transform(Number).default(3000),\n * database: {\n * url: get('DATABASE_URL').string().url()\n * }\n * }))\n * .parse();\n * ```\n */\nexport class EnvironmentParser<T extends EmptyObject> {\n /**\n * Set to track which environment variable names have been accessed\n */\n private readonly accessedVars: Set<string> = new Set();\n\n /**\n * Creates a new EnvironmentParser instance.\n *\n * @param config - The configuration object to parse (typically process.env)\n */\n constructor(private readonly config: T) {}\n\n /**\n * Wraps a Zod schema to intercept parse/safeParse calls and enrich error messages\n * with environment variable context.\n *\n * @param schema - The Zod schema to wrap\n * @param name - The environment variable name for error context\n * @returns A wrapped Zod schema with enhanced error reporting\n */\n private wrapSchema = (schema: z.ZodType, name: string): z.ZodType => {\n // Create a proxy that intercepts all method calls on the schema\n return new Proxy(schema, {\n get: (target, prop) => {\n if (prop === 'parse') {\n return () => {\n const value = get(this.config, name);\n try {\n return target.parse(value);\n } catch (error) {\n if (error instanceof z.ZodError) {\n // Modify the error to include the environment variable name\n const modifiedIssues = error.issues.map((issue) => ({\n ...issue,\n message: `Environment variable \"${name}\": ${issue.message}`,\n path: [name, ...issue.path],\n }));\n throw new z.ZodError(modifiedIssues);\n }\n throw error;\n }\n };\n }\n\n if (prop === 'safeParse') {\n return () => {\n const value = get(this.config, name);\n const result = target.safeParse(value);\n\n if (!result.success) {\n // Modify the error to include the environment variable name\n const modifiedIssues = result.error.issues.map(\n (issue: z.core.$ZodIssue) => ({\n ...issue,\n message: `Environment variable \"${name}\": ${issue.message}`,\n path: [name, ...issue.path],\n }),\n );\n return {\n success: false as const,\n error: new z.ZodError(modifiedIssues),\n };\n }\n\n return result;\n };\n }\n\n // For any method that returns a new schema (like transform, optional, etc.),\n // wrap the result as well\n const originalProp = target[prop as keyof typeof target];\n if (typeof originalProp === 'function') {\n return (...args: any[]) => {\n const result = originalProp.apply(target, args);\n // If the result is a ZodType, wrap it too\n if (result && typeof result === 'object' && 'parse' in result) {\n return this.wrapSchema(result, name);\n }\n return result;\n };\n }\n\n return originalProp;\n },\n });\n };\n\n /**\n * Creates a proxied version of the Zod object that wraps all schema creators\n * to provide enhanced error messages with environment variable context.\n *\n * @param name - The environment variable name\n * @returns A proxied Zod object with wrapped schema creators\n */\n private getZodGetter = (name: string) => {\n // Track that this environment variable was accessed\n this.accessedVars.add(name);\n\n // Return an object that has all Zod schemas but with our wrapper\n return new Proxy(\n { ...z },\n {\n get: (target, prop) => {\n // deno-lint-ignore ban-ts-comment\n // @ts-ignore\n const value = target[prop];\n\n if (typeof value === 'function') {\n // Return a wrapper around each Zod schema creator\n return (...args: any[]) => {\n const schema = value(...args);\n return this.wrapSchema(schema, name);\n };\n }\n\n // Handle objects like z.coerce\n if (value && typeof value === 'object') {\n return new Proxy(value, {\n get: (nestedTarget, nestedProp) => {\n const nestedValue =\n nestedTarget[nestedProp as keyof typeof nestedTarget];\n if (typeof nestedValue === 'function') {\n return (...args: any[]) => {\n const schema = nestedValue(...args);\n return this.wrapSchema(schema, name);\n };\n }\n return nestedValue;\n },\n });\n }\n\n return value;\n },\n },\n );\n };\n\n /**\n * Creates a new ConfigParser object that can be used to parse the config object\n *\n * @param builder - A function that takes a getter function and returns a config object\n * @returns A ConfigParser object that can be used to parse the config object\n */\n create<TReturn extends EmptyObject>(\n builder: (get: EnvFetcher) => TReturn,\n ): ConfigParser<TReturn> {\n const config = builder(this.getZodGetter);\n return new ConfigParser(config, this.accessedVars);\n }\n\n /**\n * Returns an array of environment variable names that were accessed via the getter.\n * This is useful for build-time analysis to determine which env vars a service needs.\n *\n * @returns Array of environment variable names, sorted alphabetically\n *\n * @example\n * ```typescript\n * const sniffer = new EnvironmentParser({});\n * service.register(sniffer);\n * const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'PORT']\n * ```\n */\n getEnvironmentVariables(): string[] {\n return Array.from(this.accessedVars).sort();\n }\n}\n\n/**\n * Infers the TypeScript type of a configuration object based on its Zod schemas.\n * Recursively processes nested objects and extracts types from Zod schemas.\n *\n * @template T - The configuration object type\n */\nexport type InferConfig<T extends EmptyObject> = {\n [K in keyof T]: T[K] extends z.ZodSchema\n ? z.infer<T[K]>\n : T[K] extends Record<string, unknown>\n ? InferConfig<T[K]>\n : T[K];\n};\n\n/**\n * Function type for fetching environment variables with Zod validation.\n * Returns a Zod object scoped to a specific environment variable.\n *\n * @template TPath - The environment variable path type\n * @param name - The environment variable name\n * @returns A Zod object for defining the schema\n */\nexport type EnvFetcher<TPath extends string = string> = (\n name: TPath,\n) => typeof z;\n\n/**\n * Function type for building environment configuration objects.\n * Takes an EnvFetcher and returns a configuration object with Zod schemas.\n *\n * @template TResponse - The response configuration object type\n * @param get - The environment variable fetcher function\n * @returns The configuration object with Zod schemas\n */\nexport type EnvironmentBuilder<TResponse extends EmptyObject> = (\n get: EnvFetcher,\n) => TResponse;\n\n/**\n * Type alias for a generic object with unknown values.\n * Used as a constraint for configuration objects.\n */\nexport type EmptyObject = Record<string | number | symbol, unknown>;\n"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const require_EnvironmentParser = require('./EnvironmentParser-
|
|
1
|
+
const require_EnvironmentParser = require('./EnvironmentParser-cnxuy7lw.cjs');
|
|
2
2
|
|
|
3
3
|
exports.ConfigParser = require_EnvironmentParser.ConfigParser;
|
|
4
4
|
exports.EnvironmentParser = require_EnvironmentParser.EnvironmentParser;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig } from "./EnvironmentParser-
|
|
1
|
+
import { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig } from "./EnvironmentParser-B8--woiB.cjs";
|
|
2
2
|
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig } from "./EnvironmentParser-
|
|
1
|
+
import { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig } from "./EnvironmentParser-C_9v2BDw.mjs";
|
|
2
2
|
export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
const require_chunk = require('./chunk-CUT6urMc.cjs');
|
|
2
|
+
const require_EnvironmentParser = require('./EnvironmentParser-cnxuy7lw.cjs');
|
|
3
|
+
const zod_v4 = require_chunk.__toESM(require("zod/v4"));
|
|
4
|
+
|
|
5
|
+
//#region src/SnifferEnvironmentParser.ts
|
|
6
|
+
/**
|
|
7
|
+
* A specialized EnvironmentParser for build-time analysis that tracks
|
|
8
|
+
* which environment variables are accessed without requiring actual values.
|
|
9
|
+
*
|
|
10
|
+
* Unlike the regular EnvironmentParser, the sniffer:
|
|
11
|
+
* - Always returns mock values from .parse() and .safeParse()
|
|
12
|
+
* - Never throws validation errors
|
|
13
|
+
* - Tracks all accessed environment variable names
|
|
14
|
+
*
|
|
15
|
+
* This allows service registration to succeed during build-time analysis
|
|
16
|
+
* even when environment variables are not set.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const sniffer = new SnifferEnvironmentParser();
|
|
21
|
+
* await service.register(sniffer); // Always succeeds
|
|
22
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'API_KEY']
|
|
23
|
+
* ```
|
|
24
|
+
*/
|
|
25
|
+
var SnifferEnvironmentParser = class {
|
|
26
|
+
accessedVars = /* @__PURE__ */ new Set();
|
|
27
|
+
/**
|
|
28
|
+
* Wraps a Zod schema to always return mock values.
|
|
29
|
+
* This ensures .parse() and .safeParse() never fail.
|
|
30
|
+
*/
|
|
31
|
+
wrapSchema = (schema, name) => {
|
|
32
|
+
return new Proxy(schema, { get: (target, prop) => {
|
|
33
|
+
if (prop === "parse") return () => this.getMockValue(target);
|
|
34
|
+
if (prop === "safeParse") return () => ({
|
|
35
|
+
success: true,
|
|
36
|
+
data: this.getMockValue(target)
|
|
37
|
+
});
|
|
38
|
+
const originalProp = target[prop];
|
|
39
|
+
if (typeof originalProp === "function") return (...args) => {
|
|
40
|
+
const result = originalProp.apply(target, args);
|
|
41
|
+
if (result && typeof result === "object" && "parse" in result) return this.wrapSchema(result, name);
|
|
42
|
+
return result;
|
|
43
|
+
};
|
|
44
|
+
return originalProp;
|
|
45
|
+
} });
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Returns a mock value based on the Zod schema type.
|
|
49
|
+
*/
|
|
50
|
+
getMockValue(schema) {
|
|
51
|
+
if (schema instanceof zod_v4.z.ZodString) return "";
|
|
52
|
+
if (schema instanceof zod_v4.z.ZodNumber) return 0;
|
|
53
|
+
if (schema instanceof zod_v4.z.ZodBoolean) return false;
|
|
54
|
+
if (schema instanceof zod_v4.z.ZodArray) return [];
|
|
55
|
+
if (schema instanceof zod_v4.z.ZodOptional) return void 0;
|
|
56
|
+
if (schema instanceof zod_v4.z.ZodNullable) return null;
|
|
57
|
+
if (schema instanceof zod_v4.z.ZodObject && schema.shape) {
|
|
58
|
+
const result = {};
|
|
59
|
+
for (const [key, value] of Object.entries(schema.shape)) if (value instanceof zod_v4.z.ZodType) result[key] = this.getMockValue(value);
|
|
60
|
+
return result;
|
|
61
|
+
}
|
|
62
|
+
return "";
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Creates a proxied Zod getter that tracks environment variable access.
|
|
66
|
+
*/
|
|
67
|
+
getZodGetter = (name) => {
|
|
68
|
+
this.accessedVars.add(name);
|
|
69
|
+
return new Proxy({ ...zod_v4.z }, { get: (target, prop) => {
|
|
70
|
+
const value = target[prop];
|
|
71
|
+
if (typeof value === "function") return (...args) => {
|
|
72
|
+
const schema = value(...args);
|
|
73
|
+
return this.wrapSchema(schema, name);
|
|
74
|
+
};
|
|
75
|
+
if (value && typeof value === "object") return new Proxy(value, { get: (nestedTarget, nestedProp) => {
|
|
76
|
+
const nestedValue = nestedTarget[nestedProp];
|
|
77
|
+
if (typeof nestedValue === "function") return (...args) => {
|
|
78
|
+
const schema = nestedValue(...args);
|
|
79
|
+
return this.wrapSchema(schema, name);
|
|
80
|
+
};
|
|
81
|
+
return nestedValue;
|
|
82
|
+
} });
|
|
83
|
+
return value;
|
|
84
|
+
} });
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Creates a ConfigParser that will return mock values when parsed.
|
|
88
|
+
*/
|
|
89
|
+
create(builder) {
|
|
90
|
+
const config = builder(this.getZodGetter);
|
|
91
|
+
return new SnifferConfigParser(config, this.accessedVars);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Returns all environment variable names that were accessed.
|
|
95
|
+
*/
|
|
96
|
+
getEnvironmentVariables() {
|
|
97
|
+
return Array.from(this.accessedVars).sort();
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
/**
|
|
101
|
+
* A ConfigParser that always succeeds with mock values.
|
|
102
|
+
*/
|
|
103
|
+
var SnifferConfigParser = class extends require_EnvironmentParser.ConfigParser {
|
|
104
|
+
parse() {
|
|
105
|
+
return this.parseWithMocks(this.getConfig());
|
|
106
|
+
}
|
|
107
|
+
getConfig() {
|
|
108
|
+
return this.config;
|
|
109
|
+
}
|
|
110
|
+
parseWithMocks(config) {
|
|
111
|
+
const result = {};
|
|
112
|
+
if (config && typeof config !== "object") return config;
|
|
113
|
+
for (const key in config) {
|
|
114
|
+
const schema = config[key];
|
|
115
|
+
if (schema instanceof zod_v4.z.ZodType) {
|
|
116
|
+
const parsed = schema.safeParse(void 0);
|
|
117
|
+
result[key] = parsed.success ? parsed.data : this.getDefaultForSchema(schema);
|
|
118
|
+
} else if (schema && typeof schema === "object") result[key] = this.parseWithMocks(schema);
|
|
119
|
+
}
|
|
120
|
+
return result;
|
|
121
|
+
}
|
|
122
|
+
getDefaultForSchema(schema) {
|
|
123
|
+
if (schema instanceof zod_v4.z.ZodString) return "";
|
|
124
|
+
if (schema instanceof zod_v4.z.ZodNumber) return 0;
|
|
125
|
+
if (schema instanceof zod_v4.z.ZodBoolean) return false;
|
|
126
|
+
if (schema instanceof zod_v4.z.ZodArray) return [];
|
|
127
|
+
if (schema instanceof zod_v4.z.ZodOptional) return void 0;
|
|
128
|
+
if (schema instanceof zod_v4.z.ZodNullable) return null;
|
|
129
|
+
if (schema instanceof zod_v4.z.ZodObject && schema.shape) {
|
|
130
|
+
const result = {};
|
|
131
|
+
for (const [key, value] of Object.entries(schema.shape)) if (value instanceof zod_v4.z.ZodType) result[key] = this.getDefaultForSchema(value);
|
|
132
|
+
return result;
|
|
133
|
+
}
|
|
134
|
+
return "";
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
//#endregion
|
|
139
|
+
exports.SnifferEnvironmentParser = SnifferEnvironmentParser;
|
|
140
|
+
//# sourceMappingURL=SnifferEnvironmentParser.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SnifferEnvironmentParser.cjs","names":["schema: z.ZodType","name: string","z","result: Record<string, unknown>","builder: (get: EnvFetcher) => TReturn","ConfigParser","config: T","result: EmptyObject"],"sources":["../src/SnifferEnvironmentParser.ts"],"sourcesContent":["import { z } from 'zod/v4';\nimport {\n ConfigParser,\n type EmptyObject,\n type EnvFetcher,\n} from './EnvironmentParser';\n\n/**\n * A specialized EnvironmentParser for build-time analysis that tracks\n * which environment variables are accessed without requiring actual values.\n *\n * Unlike the regular EnvironmentParser, the sniffer:\n * - Always returns mock values from .parse() and .safeParse()\n * - Never throws validation errors\n * - Tracks all accessed environment variable names\n *\n * This allows service registration to succeed during build-time analysis\n * even when environment variables are not set.\n *\n * @example\n * ```typescript\n * const sniffer = new SnifferEnvironmentParser();\n * await service.register(sniffer); // Always succeeds\n * const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'API_KEY']\n * ```\n */\nexport class SnifferEnvironmentParser<\n T extends EmptyObject = EmptyObject,\n> {\n private readonly accessedVars: Set<string> = new Set();\n\n /**\n * Wraps a Zod schema to always return mock values.\n * This ensures .parse() and .safeParse() never fail.\n */\n private wrapSchema = (schema: z.ZodType, name: string): z.ZodType => {\n return new Proxy(schema, {\n get: (target, prop) => {\n if (prop === 'parse') {\n return () => this.getMockValue(target);\n }\n\n if (prop === 'safeParse') {\n return () => ({\n success: true as const,\n data: this.getMockValue(target),\n });\n }\n\n const originalProp = target[prop as keyof typeof target];\n if (typeof originalProp === 'function') {\n return (...args: any[]) => {\n const result = originalProp.apply(target, args);\n if (result && typeof result === 'object' && 'parse' in result) {\n return this.wrapSchema(result, name);\n }\n return result;\n };\n }\n\n return originalProp;\n },\n });\n };\n\n /**\n * Returns a mock value based on the Zod schema type.\n */\n private getMockValue(schema: z.ZodType): unknown {\n // Return type-appropriate mock values\n if (schema instanceof z.ZodString) return '';\n if (schema instanceof z.ZodNumber) return 0;\n if (schema instanceof z.ZodBoolean) return false;\n if (schema instanceof z.ZodArray) return [];\n if (schema instanceof z.ZodOptional) return undefined;\n if (schema instanceof z.ZodNullable) return null;\n\n // For object schemas, build mock object from shape\n if (schema instanceof z.ZodObject && schema.shape) {\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(schema.shape)) {\n if (value instanceof z.ZodType) {\n result[key] = this.getMockValue(value);\n }\n }\n return result;\n }\n\n return '';\n }\n\n /**\n * Creates a proxied Zod getter that tracks environment variable access.\n */\n private getZodGetter = (name: string) => {\n this.accessedVars.add(name);\n\n return new Proxy(\n { ...z },\n {\n get: (target, prop) => {\n // @ts-ignore\n const value = target[prop];\n\n if (typeof value === 'function') {\n return (...args: any[]) => {\n const schema = value(...args);\n return this.wrapSchema(schema, name);\n };\n }\n\n if (value && typeof value === 'object') {\n return new Proxy(value, {\n get: (nestedTarget, nestedProp) => {\n const nestedValue =\n nestedTarget[nestedProp as keyof typeof nestedTarget];\n if (typeof nestedValue === 'function') {\n return (...args: any[]) => {\n const schema = nestedValue(...args);\n return this.wrapSchema(schema, name);\n };\n }\n return nestedValue;\n },\n });\n }\n\n return value;\n },\n },\n );\n };\n\n /**\n * Creates a ConfigParser that will return mock values when parsed.\n */\n create<TReturn extends EmptyObject>(\n builder: (get: EnvFetcher) => TReturn,\n ): ConfigParser<TReturn> {\n const config = builder(this.getZodGetter);\n return new SnifferConfigParser(config, this.accessedVars);\n }\n\n /**\n * Returns all environment variable names that were accessed.\n */\n getEnvironmentVariables(): string[] {\n return Array.from(this.accessedVars).sort();\n }\n}\n\n/**\n * A ConfigParser that always succeeds with mock values.\n */\nclass SnifferConfigParser<TResponse extends EmptyObject> extends ConfigParser<TResponse> {\n parse(): any {\n return this.parseWithMocks(this.getConfig());\n }\n\n private getConfig(): TResponse {\n // Access the private config via any cast\n return (this as any).config;\n }\n\n private parseWithMocks<T>(config: T): any {\n const result: EmptyObject = {};\n\n if (config && typeof config !== 'object') {\n return config;\n }\n\n for (const key in config) {\n const schema = config[key];\n\n if (schema instanceof z.ZodType) {\n // Use safeParse which will return mock values from our wrapped schema\n const parsed = schema.safeParse(undefined);\n result[key] = parsed.success ? parsed.data : this.getDefaultForSchema(schema);\n } else if (schema && typeof schema === 'object') {\n result[key] = this.parseWithMocks(schema as EmptyObject);\n }\n }\n\n return result;\n }\n\n private getDefaultForSchema(schema: z.ZodType): unknown {\n if (schema instanceof z.ZodString) return '';\n if (schema instanceof z.ZodNumber) return 0;\n if (schema instanceof z.ZodBoolean) return false;\n if (schema instanceof z.ZodArray) return [];\n if (schema instanceof z.ZodOptional) return undefined;\n if (schema instanceof z.ZodNullable) return null;\n\n if (schema instanceof z.ZodObject && schema.shape) {\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(schema.shape)) {\n if (value instanceof z.ZodType) {\n result[key] = this.getDefaultForSchema(value);\n }\n }\n return result;\n }\n\n return '';\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { ConfigParser, EmptyObject, EnvFetcher } from "./EnvironmentParser-B8--woiB.cjs";
|
|
2
|
+
|
|
3
|
+
//#region src/SnifferEnvironmentParser.d.ts
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* A specialized EnvironmentParser for build-time analysis that tracks
|
|
7
|
+
* which environment variables are accessed without requiring actual values.
|
|
8
|
+
*
|
|
9
|
+
* Unlike the regular EnvironmentParser, the sniffer:
|
|
10
|
+
* - Always returns mock values from .parse() and .safeParse()
|
|
11
|
+
* - Never throws validation errors
|
|
12
|
+
* - Tracks all accessed environment variable names
|
|
13
|
+
*
|
|
14
|
+
* This allows service registration to succeed during build-time analysis
|
|
15
|
+
* even when environment variables are not set.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```typescript
|
|
19
|
+
* const sniffer = new SnifferEnvironmentParser();
|
|
20
|
+
* await service.register(sniffer); // Always succeeds
|
|
21
|
+
* const envVars = sniffer.getEnvironmentVariables(); // ['DATABASE_URL', 'API_KEY']
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
declare class SnifferEnvironmentParser<T extends EmptyObject = EmptyObject> {
|
|
25
|
+
private readonly accessedVars;
|
|
26
|
+
/**
|
|
27
|
+
* Wraps a Zod schema to always return mock values.
|
|
28
|
+
* This ensures .parse() and .safeParse() never fail.
|
|
29
|
+
*/
|
|
30
|
+
private wrapSchema;
|
|
31
|
+
/**
|
|
32
|
+
* Returns a mock value based on the Zod schema type.
|
|
33
|
+
*/
|
|
34
|
+
private getMockValue;
|
|
35
|
+
/**
|
|
36
|
+
* Creates a proxied Zod getter that tracks environment variable access.
|
|
37
|
+
*/
|
|
38
|
+
private getZodGetter;
|
|
39
|
+
/**
|
|
40
|
+
* Creates a ConfigParser that will return mock values when parsed.
|
|
41
|
+
*/
|
|
42
|
+
create<TReturn extends EmptyObject>(builder: (get: EnvFetcher) => TReturn): ConfigParser<TReturn>;
|
|
43
|
+
/**
|
|
44
|
+
* Returns all environment variable names that were accessed.
|
|
45
|
+
*/
|
|
46
|
+
getEnvironmentVariables(): string[];
|
|
47
|
+
}
|
|
48
|
+
//#endregion
|
|
49
|
+
export { SnifferEnvironmentParser };
|
|
50
|
+
//# sourceMappingURL=SnifferEnvironmentParser.d.cts.map
|