@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.
Files changed (47) hide show
  1. package/dist/{EnvironmentParser-C-arQEHQ.d.mts → EnvironmentParser-B8--woiB.d.cts} +40 -2
  2. package/dist/{EnvironmentParser-X4h2Vp4r.d.cts → EnvironmentParser-C_9v2BDw.d.mts} +40 -2
  3. package/dist/{EnvironmentParser-CQUOGqc0.mjs → EnvironmentParser-STvN_RCc.mjs} +46 -3
  4. package/dist/EnvironmentParser-STvN_RCc.mjs.map +1 -0
  5. package/dist/{EnvironmentParser-BDPDLv6i.cjs → EnvironmentParser-cnxuy7lw.cjs} +46 -3
  6. package/dist/EnvironmentParser-cnxuy7lw.cjs.map +1 -0
  7. package/dist/EnvironmentParser.cjs +1 -1
  8. package/dist/EnvironmentParser.d.cts +1 -1
  9. package/dist/EnvironmentParser.d.mts +1 -1
  10. package/dist/EnvironmentParser.mjs +1 -1
  11. package/dist/SnifferEnvironmentParser.cjs +140 -0
  12. package/dist/SnifferEnvironmentParser.cjs.map +1 -0
  13. package/dist/SnifferEnvironmentParser.d.cts +50 -0
  14. package/dist/SnifferEnvironmentParser.d.mts +50 -0
  15. package/dist/SnifferEnvironmentParser.mjs +139 -0
  16. package/dist/SnifferEnvironmentParser.mjs.map +1 -0
  17. package/dist/index.cjs +2 -1
  18. package/dist/index.d.cts +2 -2
  19. package/dist/index.d.mts +2 -2
  20. package/dist/index.mjs +2 -2
  21. package/dist/sst.cjs +131 -4
  22. package/dist/sst.cjs.map +1 -0
  23. package/dist/sst.d.cts +2 -1
  24. package/dist/sst.d.mts +2 -1
  25. package/dist/sst.mjs +128 -2
  26. package/dist/sst.mjs.map +1 -0
  27. package/package.json +9 -2
  28. package/src/EnvironmentParser.ts +51 -2
  29. package/src/SnifferEnvironmentParser.ts +207 -0
  30. package/src/__tests__/EnvironmentParser.spec.ts +147 -0
  31. package/src/__tests__/SnifferEnvironmentParser.spec.ts +332 -0
  32. package/src/__tests__/sst.spec.ts +9 -6
  33. package/src/index.ts +1 -1
  34. package/dist/__tests__/ConfigParser.spec.cjs +0 -323
  35. package/dist/__tests__/ConfigParser.spec.d.cts +0 -1
  36. package/dist/__tests__/ConfigParser.spec.d.mts +0 -1
  37. package/dist/__tests__/ConfigParser.spec.mjs +0 -322
  38. package/dist/__tests__/EnvironmentParser.spec.cjs +0 -422
  39. package/dist/__tests__/EnvironmentParser.spec.d.cts +0 -1
  40. package/dist/__tests__/EnvironmentParser.spec.d.mts +0 -1
  41. package/dist/__tests__/EnvironmentParser.spec.mjs +0 -421
  42. package/dist/__tests__/sst.spec.cjs +0 -305
  43. package/dist/__tests__/sst.spec.d.cts +0 -1
  44. package/dist/__tests__/sst.spec.d.mts +0 -1
  45. package/dist/__tests__/sst.spec.mjs +0 -304
  46. package/dist/sst-BSxwaAdz.cjs +0 -146
  47. 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":";;;;;;;;;;;;AAUA,IAAa,eAAb,MAAyD;;;;;;;CAOvD,YACmBA,QACAC,0BAAuB,IAAI,OAC5C;EAFiB;EACA;CACf;;;;;CAKJ,QAAgC;EAC9B,MAAMC,SAA6B,CAAE;EAErC,MAAM,YAAY,CAAIC,QAAWC,OAAiB,CAAE,MAAK;GACvD,MAAMC,SAAsB,CAAE;AAE9B,OAAI,iBAAiB,WAAW,SAC9B,QAAO;AAGT,QAAK,MAAM,OAAO,QAAQ;IACxB,MAAM,SAAS,OAAO;IACtB,MAAM,cAAc,CAAC,GAAG,MAAM,GAAI;AAElC,QAAI,kBAAkBC,SAAE,SAAS;KAC/B,MAAM,SAAS,OAAO,iBAAoB;AAC1C,SAAI,OAAO,QACT,yBAAI,QAAQ,KAAK,OAAO,KAAK;SAG7B,QAAO,KACL,GAAG,OAAO,MAAM,OAAO,IAAI,CAAC,WAAW;MACrC,GAAG;MACH,MAAM,CAAC,GAAG,aAAa,GAAI,MAAM,IAAkB;KACpD,GAAE,CACJ;IAEJ,WAAU,OACT,yBAAI,QAAQ,KAAK,UAAU,QAAuB,YAAY,CAAC;GAElE;AAED,UAAO;EACR;EAED,MAAM,eAAe,UACnB,KAAK,OACN;AAED,MAAI,OAAO,SAAS,EAElB,OAAM,IAAIA,SAAE,SAAS;AAGvB,SAAO;CACR;;;;;;;;;;;;;;;;;CAkBD,0BAAoC;AAClC,SAAO,MAAM,KAAK,KAAK,QAAQ,CAAC,MAAM;CACvC;AACF;;;;;;;;;;;;;;;;;;;;AAqBD,IAAa,oBAAb,MAAsD;;;;CAIpD,AAAiB,+BAA4B,IAAI;;;;;;CAOjD,YAA6BH,QAAW;EAAX;CAAa;;;;;;;;;CAU1C,AAAQ,aAAa,CAACI,QAAmBC,SAA4B;AAEnE,SAAO,IAAI,MAAM,QAAQ,EACvB,KAAK,CAAC,QAAQ,SAAS;AACrB,OAAI,SAAS,QACX,QAAO,MAAM;IACX,MAAM,QAAQ,wBAAI,KAAK,QAAQ,KAAK;AACpC,QAAI;AACF,YAAO,OAAO,MAAM,MAAM;IAC3B,SAAQ,OAAO;AACd,SAAI,iBAAiBF,SAAE,UAAU;MAE/B,MAAM,iBAAiB,MAAM,OAAO,IAAI,CAAC,WAAW;OAClD,GAAG;OACH,UAAU,wBAAwB,KAAK,KAAK,MAAM,QAAQ;OAC1D,MAAM,CAAC,MAAM,GAAG,MAAM,IAAK;MAC5B,GAAE;AACH,YAAM,IAAIA,SAAE,SAAS;KACtB;AACD,WAAM;IACP;GACF;AAGH,OAAI,SAAS,YACX,QAAO,MAAM;IACX,MAAM,QAAQ,wBAAI,KAAK,QAAQ,KAAK;IACpC,MAAM,SAAS,OAAO,UAAU,MAAM;AAEtC,SAAK,OAAO,SAAS;KAEnB,MAAM,iBAAiB,OAAO,MAAM,OAAO,IACzC,CAACG,WAA6B;MAC5B,GAAG;MACH,UAAU,wBAAwB,KAAK,KAAK,MAAM,QAAQ;MAC1D,MAAM,CAAC,MAAM,GAAG,MAAM,IAAK;KAC5B,GACF;AACD,YAAO;MACL,SAAS;MACT,OAAO,IAAIH,SAAE,SAAS;KACvB;IACF;AAED,WAAO;GACR;GAKH,MAAM,eAAe,OAAO;AAC5B,cAAW,iBAAiB,WAC1B,QAAO,CAAC,GAAG,SAAgB;IACzB,MAAM,SAAS,aAAa,MAAM,QAAQ,KAAK;AAE/C,QAAI,iBAAiB,WAAW,YAAY,WAAW,OACrD,QAAO,KAAK,WAAW,QAAQ,KAAK;AAEtC,WAAO;GACR;AAGH,UAAO;EACR,EACF;CACF;;;;;;;;CASD,AAAQ,eAAe,CAACE,SAAiB;AAEvC,OAAK,aAAa,IAAI,KAAK;AAG3B,SAAO,IAAI,MACT,EAAE,GAAGF,SAAG,GACR,EACE,KAAK,CAAC,QAAQ,SAAS;GAGrB,MAAM,QAAQ,OAAO;AAErB,cAAW,UAAU,WAEnB,QAAO,CAAC,GAAG,SAAgB;IACzB,MAAM,SAAS,MAAM,GAAG,KAAK;AAC7B,WAAO,KAAK,WAAW,QAAQ,KAAK;GACrC;AAIH,OAAI,gBAAgB,UAAU,SAC5B,QAAO,IAAI,MAAM,OAAO,EACtB,KAAK,CAAC,cAAc,eAAe;IACjC,MAAM,cACJ,aAAa;AACf,eAAW,gBAAgB,WACzB,QAAO,CAAC,GAAG,SAAgB;KACzB,MAAM,SAAS,YAAY,GAAG,KAAK;AACnC,YAAO,KAAK,WAAW,QAAQ,KAAK;IACrC;AAEH,WAAO;GACR,EACF;AAGH,UAAO;EACR,EACF;CAEJ;;;;;;;CAQD,OACEI,SACuB;EACvB,MAAM,SAAS,QAAQ,KAAK,aAAa;AACzC,SAAO,IAAI,aAAa,QAAQ,KAAK;CACtC;;;;;;;;;;;;;;CAeD,0BAAoC;AAClC,SAAO,MAAM,KAAK,KAAK,aAAa,CAAC,MAAM;CAC5C;AACF"}
@@ -1,4 +1,4 @@
1
- const require_EnvironmentParser = require('./EnvironmentParser-BDPDLv6i.cjs');
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-X4h2Vp4r.cjs";
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-C-arQEHQ.mjs";
1
+ import { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig } from "./EnvironmentParser-C_9v2BDw.mjs";
2
2
  export { ConfigParser, EmptyObject, EnvFetcher, EnvironmentBuilder, EnvironmentParser, InferConfig };
@@ -1,3 +1,3 @@
1
- import { ConfigParser, EnvironmentParser } from "./EnvironmentParser-CQUOGqc0.mjs";
1
+ import { ConfigParser, EnvironmentParser } from "./EnvironmentParser-STvN_RCc.mjs";
2
2
 
3
3
  export { ConfigParser, EnvironmentParser };
@@ -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