@decaf-ts/utils 0.3.7 → 0.3.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.
@@ -1,70 +0,0 @@
1
- import { EnvironmentFactory } from "./types";
2
- import { ObjectAccumulator } from "typed-object-accumulator";
3
- /**
4
- * @class Environment
5
- * @extends {ObjectAccumulator<T>}
6
- * @template T
7
- * @description A class representing an environment with accumulation capabilities.
8
- * @summary Manages environment-related data and provides methods for accumulation and key retrieval.
9
- * @param {T} [initialData] - The initial data to populate the environment with.
10
- */
11
- export declare class Environment<T extends object> extends ObjectAccumulator<T> {
12
- /**
13
- * @static
14
- * @protected
15
- * @description A factory function for creating Environment instances.
16
- * @summary Defines how new instances of the Environment class should be created.
17
- * @return {Environment<any>} A new instance of the Environment class.
18
- */
19
- protected static factory: EnvironmentFactory<any, any>;
20
- /**
21
- * @static
22
- * @private
23
- * @description The singleton instance of the Environment class.
24
- * @type {Environment<any>}
25
- */
26
- private static _instance;
27
- protected constructor();
28
- /**
29
- * @description Retrieves a value from the environment
30
- * @summary Gets a value from the environment variables, handling browser and Node.js environments differently
31
- * @param {string} k - The key to retrieve from the environment
32
- * @return {unknown} The value from the environment, or undefined if not found
33
- */
34
- protected fromEnv(k: string): unknown;
35
- /**
36
- * @description Expands an object into the environment
37
- * @summary Defines properties on the environment object that can be accessed as getters and setters
38
- * @template V - Type of the object being expanded
39
- * @param {V} value - The object to expand into the environment
40
- * @return {void}
41
- */
42
- protected expand<V extends object>(value: V): void;
43
- /**
44
- * @protected
45
- * @static
46
- * @description Retrieves or creates the singleton instance of the Environment class.
47
- * @summary Ensures only one instance of the Environment class exists.
48
- * @template E
49
- * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.
50
- * @return {E} The singleton instance of the Environment class.
51
- */
52
- protected static instance<E extends Environment<any>>(...args: unknown[]): E;
53
- /**
54
- * @static
55
- * @description Accumulates the given value into the environment.
56
- * @summary Adds new properties to the environment from the provided object.
57
- * @template V
58
- * @param {V} value - The object to accumulate into the environment.
59
- * @return {V} The updated environment instance.
60
- */
61
- static accumulate<V extends object>(value: V): typeof Environment._instance & V & ObjectAccumulator<typeof Environment._instance & V>;
62
- /**
63
- * @static
64
- * @description Retrieves the keys of the environment, optionally converting them to ENV format.
65
- * @summary Gets all keys in the environment, with an option to format them for environment variables.
66
- * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.
67
- * @return {string[]} An array of keys from the environment.
68
- */
69
- static keys(toEnv?: boolean): string[];
70
- }
@@ -1,103 +0,0 @@
1
- import { toENVFormat } from "./text.js";
2
- import { isBrowser } from "./web.js";
3
- import { ObjectAccumulator } from "typed-object-accumulator";
4
- /**
5
- * @class Environment
6
- * @extends {ObjectAccumulator<T>}
7
- * @template T
8
- * @description A class representing an environment with accumulation capabilities.
9
- * @summary Manages environment-related data and provides methods for accumulation and key retrieval.
10
- * @param {T} [initialData] - The initial data to populate the environment with.
11
- */
12
- export class Environment extends ObjectAccumulator {
13
- /**
14
- * @static
15
- * @protected
16
- * @description A factory function for creating Environment instances.
17
- * @summary Defines how new instances of the Environment class should be created.
18
- * @return {Environment<any>} A new instance of the Environment class.
19
- */
20
- static { this.factory = () => new Environment(); }
21
- constructor() {
22
- super();
23
- }
24
- /**
25
- * @description Retrieves a value from the environment
26
- * @summary Gets a value from the environment variables, handling browser and Node.js environments differently
27
- * @param {string} k - The key to retrieve from the environment
28
- * @return {unknown} The value from the environment, or undefined if not found
29
- */
30
- fromEnv(k) {
31
- let env;
32
- if (isBrowser()) {
33
- env = globalThis["ENV"];
34
- }
35
- else {
36
- env = globalThis.process.env;
37
- k = toENVFormat(k);
38
- }
39
- return env[k];
40
- }
41
- /**
42
- * @description Expands an object into the environment
43
- * @summary Defines properties on the environment object that can be accessed as getters and setters
44
- * @template V - Type of the object being expanded
45
- * @param {V} value - The object to expand into the environment
46
- * @return {void}
47
- */
48
- expand(value) {
49
- Object.entries(value).forEach(([k, v]) => {
50
- Object.defineProperty(this, k, {
51
- get: () => {
52
- const fromEnv = this.fromEnv(k);
53
- return typeof fromEnv === "undefined" ? v : fromEnv;
54
- },
55
- set: (val) => {
56
- v = val;
57
- },
58
- configurable: true,
59
- enumerable: true,
60
- });
61
- });
62
- }
63
- /**
64
- * @protected
65
- * @static
66
- * @description Retrieves or creates the singleton instance of the Environment class.
67
- * @summary Ensures only one instance of the Environment class exists.
68
- * @template E
69
- * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.
70
- * @return {E} The singleton instance of the Environment class.
71
- */
72
- static instance(...args) {
73
- Environment._instance = !Environment._instance
74
- ? Environment.factory(...args)
75
- : Environment._instance;
76
- return Environment._instance;
77
- }
78
- /**
79
- * @static
80
- * @description Accumulates the given value into the environment.
81
- * @summary Adds new properties to the environment from the provided object.
82
- * @template V
83
- * @param {V} value - The object to accumulate into the environment.
84
- * @return {V} The updated environment instance.
85
- */
86
- static accumulate(value) {
87
- const instance = Environment.instance();
88
- return instance.accumulate(value);
89
- }
90
- /**
91
- * @static
92
- * @description Retrieves the keys of the environment, optionally converting them to ENV format.
93
- * @summary Gets all keys in the environment, with an option to format them for environment variables.
94
- * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.
95
- * @return {string[]} An array of keys from the environment.
96
- */
97
- static keys(toEnv = true) {
98
- return Environment.instance()
99
- .keys()
100
- .map((k) => (toEnv ? toENVFormat(k) : k));
101
- }
102
- }
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../../../src/utils/environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,kBAAe;AAErC,OAAO,EAAE,SAAS,EAAE,iBAAc;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAE7D;;;;;;;GAOG;AACH,MAAM,OAAO,WAA8B,SAAQ,iBAAoB;IACrE;;;;;;OAMG;aACc,YAAO,GACtB,GAAqB,EAAE,CAAC,IAAI,WAAW,EAAE,CAAC;IAU5C;QACE,KAAK,EAAE,CAAC;IACV,CAAC;IAED;;;;;OAKG;IACO,OAAO,CAAC,CAAS;QACzB,IAAI,GAA4B,CAAC;QACjC,IAAI,SAAS,EAAE,EAAE,CAAC;YAChB,GAAG,GAAI,UAA+D,CACpE,KAAK,CACN,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC;YAC7B,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QACrB,CAAC;QACD,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IACgB,MAAM,CAAmB,KAAQ;QAClD,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;YACvC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC,EAAE;gBAC7B,GAAG,EAAE,GAAG,EAAE;oBACR,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;oBAChC,OAAO,OAAO,OAAO,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;gBACtD,CAAC;gBACD,GAAG,EAAE,CAAC,GAAe,EAAE,EAAE;oBACvB,CAAC,GAAG,GAAG,CAAC;gBACV,CAAC;gBACD,YAAY,EAAE,IAAI;gBAClB,UAAU,EAAE,IAAI;aACjB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;OAQG;IACO,MAAM,CAAC,QAAQ,CAA6B,GAAG,IAAe;QACtE,WAAW,CAAC,SAAS,GAAG,CAAC,WAAW,CAAC,SAAS;YAC5C,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;YAC9B,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC;QAC1B,OAAO,WAAW,CAAC,SAAc,CAAC;IACpC,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CACf,KAAQ;QAIR,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,EAAE,CAAC;QACxC,OAAO,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,IAAI,CAAC,QAAiB,IAAI;QAC/B,OAAO,WAAW,CAAC,QAAQ,EAAE;aAC1B,IAAI,EAAE;aACN,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC","sourcesContent":["import { toENVFormat } from \"./text\";\nimport { EnvironmentFactory } from \"./types\";\nimport { isBrowser } from \"./web\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\n\n/**\n * @class Environment\n * @extends {ObjectAccumulator<T>}\n * @template T\n * @description A class representing an environment with accumulation capabilities.\n * @summary Manages environment-related data and provides methods for accumulation and key retrieval.\n * @param {T} [initialData] - The initial data to populate the environment with.\n */\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieves a value from the environment\n   * @summary Gets a value from the environment variables, handling browser and Node.js environments differently\n   * @param {string} k - The key to retrieve from the environment\n   * @return {unknown} The value from the environment, or undefined if not found\n   */\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env = (globalThis as typeof globalThis & { ENV: Record<string, any> })[\n        \"ENV\"\n      ];\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return env[k];\n  }\n\n  /**\n   * @description Expands an object into the environment\n   * @summary Defines properties on the environment object that can be accessed as getters and setters\n   * @template V - Type of the object being expanded\n   * @param {V} value - The object to expand into the environment\n   * @return {void}\n   */\n  protected override expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          return typeof fromEnv === \"undefined\" ? v : fromEnv;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one instance of the Environment class exists.\n   * @template E\n   * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.\n   * @return {E} The singleton instance of the Environment class.\n   */\n  protected static instance<E extends Environment<any>>(...args: unknown[]): E {\n    Environment._instance = !Environment._instance\n      ? Environment.factory(...args)\n      : Environment._instance;\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties to the environment from the provided object.\n   * @template V\n   * @param {V} value - The object to accumulate into the environment.\n   * @return {V} The updated environment instance.\n   */\n  static accumulate<V extends object>(\n    value: V\n  ): typeof Environment._instance &\n    V &\n    ObjectAccumulator<typeof Environment._instance & V> {\n    const instance = Environment.instance();\n    return instance.accumulate(value);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n}\n"]}
@@ -1,132 +0,0 @@
1
- /**
2
- * @description Pads the end of a string with a specified character.
3
- * @summary Extends the input string to a specified length by adding a padding character to the end.
4
- * If the input string is already longer than the specified length, it is returned unchanged.
5
- *
6
- * @param {string} str - The input string to be padded.
7
- * @param {number} length - The desired total length of the resulting string.
8
- * @param {string} [char=" "] - The character to use for padding. Defaults to a space.
9
- * @return {string} The padded string.
10
- * @throws {Error} If the padding character is not exactly one character long.
11
- *
12
- * @function padEnd
13
- *
14
- * @memberOf module:utils
15
- */
16
- export declare function padEnd(str: string, length: number, char?: string): string;
17
- /**
18
- * @description Replaces placeholders in a string with provided values.
19
- * @summary Interpolates a string by replacing placeholders of the form ${variableName}
20
- * with corresponding values from the provided object. If a placeholder doesn't have
21
- * a corresponding value, it is left unchanged in the string.
22
- *
23
- * @param {string} input - The input string containing placeholders to be replaced.
24
- * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
25
- * @return {string} The interpolated string with placeholders replaced by their corresponding values.
26
- *
27
- * @function patchPlaceholders
28
- *
29
- * @mermaid
30
- * sequenceDiagram
31
- * participant Caller
32
- * participant patchString
33
- * participant String.replace
34
- * Caller->>patchString: Call with input and values
35
- * patchString->>String.replace: Call with regex and replacement function
36
- * String.replace->>patchString: Return replaced string
37
- * patchString-->>Caller: Return patched string
38
- *
39
- * @memberOf module:utils
40
- */
41
- export declare function patchPlaceholders(input: string, values: Record<string, number | string>): string;
42
- /**
43
- * @description Replaces occurrences of keys with their corresponding values in a string.
44
- * @summary Iterates through a set of key-value pairs and replaces all occurrences of each key
45
- * in the input string with its corresponding value. Supports regular expression flags for customized replacement.
46
- *
47
- * @param {string} input - The input string in which replacements will be made.
48
- * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
49
- * @param {string} [flags="g"] - Regular expression flags to control the replacement behavior.
50
- * @return {string} The string with all specified replacements applied.
51
- *
52
- * @function patchString
53
- *
54
- * @memberOf module:utils
55
- */
56
- export declare function patchString(input: string, values: Record<string, number | string>, flags?: string): string;
57
- /**
58
- * @description Converts a string to camelCase.
59
- * @summary Transforms the input string into camelCase format, where words are joined without spaces
60
- * and each word after the first starts with a capital letter.
61
- *
62
- * @param {string} text - The input string to be converted.
63
- * @return {string} The input string converted to camelCase.
64
- *
65
- * @function toCamelCase
66
- *
67
- * @memberOf module:utils
68
- */
69
- export declare function toCamelCase(text: string): string;
70
- /**
71
- * @description Converts a string to ENVIRONMENT_VARIABLE format.
72
- * @summary Transforms the input string into uppercase with words separated by underscores,
73
- * typically used for environment variable names.
74
- *
75
- * @param {string} text - The input string to be converted.
76
- * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.
77
- *
78
- * @function toENVFormat
79
- *
80
- * @memberOf module:utils
81
- */
82
- export declare function toENVFormat(text: string): string;
83
- /**
84
- * @description Converts a string to snake_case.
85
- * @summary Transforms the input string into lowercase with words separated by underscores.
86
- *
87
- * @param {string} text - The input string to be converted.
88
- * @return {string} The input string converted to snake_case.
89
- *
90
- * @function toSnakeCase
91
- *
92
- * @memberOf module:utils
93
- */
94
- export declare function toSnakeCase(text: string): string;
95
- /**
96
- * @description Converts a string to kebab-case.
97
- * @summary Transforms the input string into lowercase with words separated by hyphens.
98
- *
99
- * @param {string} text - The input string to be converted.
100
- * @return {string} The input string converted to kebab-case.
101
- *
102
- * @function toKebabCase
103
- *
104
- * @memberOf module:utils
105
- */
106
- export declare function toKebabCase(text: string): string;
107
- /**
108
- * @description Converts a string to PascalCase.
109
- * @summary Transforms the input string into PascalCase format, where words are joined without spaces
110
- * and each word starts with a capital letter.
111
- *
112
- * @param {string} text - The input string to be converted.
113
- * @return {string} The input string converted to PascalCase.
114
- *
115
- * @function toPascalCase
116
- *
117
- * @memberOf module:utils
118
- */
119
- export declare function toPascalCase(text: string): string;
120
- /**
121
- * @description Escapes special characters in a string for use in a regular expression.
122
- * @summary Adds backslashes before characters that have special meaning in regular expressions,
123
- * allowing the string to be used as a literal match in a RegExp.
124
- *
125
- * @param {string} string - The string to escape for regular expression use.
126
- * @return {string} The escaped string safe for use in regular expressions.
127
- *
128
- * @function escapeRegExp
129
- *
130
- * @memberOf module:utils
131
- */
132
- export declare function escapeRegExp(string: string): string;
@@ -1,167 +0,0 @@
1
- /**
2
- * @description Pads the end of a string with a specified character.
3
- * @summary Extends the input string to a specified length by adding a padding character to the end.
4
- * If the input string is already longer than the specified length, it is returned unchanged.
5
- *
6
- * @param {string} str - The input string to be padded.
7
- * @param {number} length - The desired total length of the resulting string.
8
- * @param {string} [char=" "] - The character to use for padding. Defaults to a space.
9
- * @return {string} The padded string.
10
- * @throws {Error} If the padding character is not exactly one character long.
11
- *
12
- * @function padEnd
13
- *
14
- * @memberOf module:utils
15
- */
16
- export function padEnd(str, length, char = " ") {
17
- if (char.length !== 1)
18
- throw new Error("Invalid character length for padding. must be one!");
19
- return str.padEnd(length, char);
20
- }
21
- /**
22
- * @description Replaces placeholders in a string with provided values.
23
- * @summary Interpolates a string by replacing placeholders of the form ${variableName}
24
- * with corresponding values from the provided object. If a placeholder doesn't have
25
- * a corresponding value, it is left unchanged in the string.
26
- *
27
- * @param {string} input - The input string containing placeholders to be replaced.
28
- * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
29
- * @return {string} The interpolated string with placeholders replaced by their corresponding values.
30
- *
31
- * @function patchPlaceholders
32
- *
33
- * @mermaid
34
- * sequenceDiagram
35
- * participant Caller
36
- * participant patchString
37
- * participant String.replace
38
- * Caller->>patchString: Call with input and values
39
- * patchString->>String.replace: Call with regex and replacement function
40
- * String.replace->>patchString: Return replaced string
41
- * patchString-->>Caller: Return patched string
42
- *
43
- * @memberOf module:utils
44
- */
45
- export function patchPlaceholders(input, values) {
46
- return input.replace(/\$\{([a-zA-Z0-9_]+)\}/g, (match, variable) => values[variable] || match);
47
- }
48
- /**
49
- * @description Replaces occurrences of keys with their corresponding values in a string.
50
- * @summary Iterates through a set of key-value pairs and replaces all occurrences of each key
51
- * in the input string with its corresponding value. Supports regular expression flags for customized replacement.
52
- *
53
- * @param {string} input - The input string in which replacements will be made.
54
- * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.
55
- * @param {string} [flags="g"] - Regular expression flags to control the replacement behavior.
56
- * @return {string} The string with all specified replacements applied.
57
- *
58
- * @function patchString
59
- *
60
- * @memberOf module:utils
61
- */
62
- export function patchString(input, values, flags = "g") {
63
- Object.entries(values).forEach(([key, val]) => {
64
- const regexp = new RegExp(escapeRegExp(key), flags);
65
- input = input.replace(regexp, val);
66
- });
67
- return input;
68
- }
69
- /**
70
- * @description Converts a string to camelCase.
71
- * @summary Transforms the input string into camelCase format, where words are joined without spaces
72
- * and each word after the first starts with a capital letter.
73
- *
74
- * @param {string} text - The input string to be converted.
75
- * @return {string} The input string converted to camelCase.
76
- *
77
- * @function toCamelCase
78
- *
79
- * @memberOf module:utils
80
- */
81
- export function toCamelCase(text) {
82
- return text
83
- .replace(/(?:^\w|[A-Z]|\b\w)/g, (word, index) => index === 0 ? word.toLowerCase() : word.toUpperCase())
84
- .replace(/\s+/g, "");
85
- }
86
- /**
87
- * @description Converts a string to ENVIRONMENT_VARIABLE format.
88
- * @summary Transforms the input string into uppercase with words separated by underscores,
89
- * typically used for environment variable names.
90
- *
91
- * @param {string} text - The input string to be converted.
92
- * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.
93
- *
94
- * @function toENVFormat
95
- *
96
- * @memberOf module:utils
97
- */
98
- export function toENVFormat(text) {
99
- return toSnakeCase(text).toUpperCase();
100
- }
101
- /**
102
- * @description Converts a string to snake_case.
103
- * @summary Transforms the input string into lowercase with words separated by underscores.
104
- *
105
- * @param {string} text - The input string to be converted.
106
- * @return {string} The input string converted to snake_case.
107
- *
108
- * @function toSnakeCase
109
- *
110
- * @memberOf module:utils
111
- */
112
- export function toSnakeCase(text) {
113
- return text
114
- .replace(/([a-z])([A-Z])/g, "$1_$2")
115
- .replace(/[\s-]+/g, "_")
116
- .toLowerCase();
117
- }
118
- /**
119
- * @description Converts a string to kebab-case.
120
- * @summary Transforms the input string into lowercase with words separated by hyphens.
121
- *
122
- * @param {string} text - The input string to be converted.
123
- * @return {string} The input string converted to kebab-case.
124
- *
125
- * @function toKebabCase
126
- *
127
- * @memberOf module:utils
128
- */
129
- export function toKebabCase(text) {
130
- return text
131
- .replace(/([a-z])([A-Z])/g, "$1-$2")
132
- .replace(/[\s_]+/g, "-")
133
- .toLowerCase();
134
- }
135
- /**
136
- * @description Converts a string to PascalCase.
137
- * @summary Transforms the input string into PascalCase format, where words are joined without spaces
138
- * and each word starts with a capital letter.
139
- *
140
- * @param {string} text - The input string to be converted.
141
- * @return {string} The input string converted to PascalCase.
142
- *
143
- * @function toPascalCase
144
- *
145
- * @memberOf module:utils
146
- */
147
- export function toPascalCase(text) {
148
- return text
149
- .replace(/(?:^\w|[A-Z]|\b\w)/g, (word) => word.toUpperCase())
150
- .replace(/\s+/g, "");
151
- }
152
- /**
153
- * @description Escapes special characters in a string for use in a regular expression.
154
- * @summary Adds backslashes before characters that have special meaning in regular expressions,
155
- * allowing the string to be used as a literal match in a RegExp.
156
- *
157
- * @param {string} string - The string to escape for regular expression use.
158
- * @return {string} The escaped string safe for use in regular expressions.
159
- *
160
- * @function escapeRegExp
161
- *
162
- * @memberOf module:utils
163
- */
164
- export function escapeRegExp(string) {
165
- return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
166
- }
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../src/utils/text.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,MAAM,UAAU,MAAM,CACpB,GAAW,EACX,MAAc,EACd,OAAe,GAAG;IAElB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;IACxE,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;AAClC,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,UAAU,iBAAiB,CAC/B,KAAa,EACb,MAAuC;IAEvC,OAAO,KAAK,CAAC,OAAO,CAClB,wBAAwB,EACxB,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,CAAE,MAAM,CAAC,QAAkB,CAAY,IAAI,KAAK,CACrE,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,WAAW,CACzB,KAAa,EACb,MAAuC,EACvC,QAAgB,GAAG;IAEnB,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC5C,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;QACpD,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAa,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI;SACR,OAAO,CAAC,qBAAqB,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAC9C,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CACtD;SACA,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;AACzB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;AACzC,CAAC;AAED;;;;;;;;;;GAUG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI;SACR,OAAO,CAAC,iBAAiB,EAAE,OAAO,CAAC;SACnC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC;SACvB,WAAW,EAAE,CAAC;AACnB,CAAC;AAED;;;;;;;;;;GAUG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI;SACR,OAAO,CAAC,iBAAiB,EAAE,OAAO,CAAC;SACnC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC;SACvB,WAAW,EAAE,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,YAAY,CAAC,IAAY;IACvC,OAAO,IAAI;SACR,OAAO,CAAC,qBAAqB,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;SAC5D,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;AACzB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,YAAY,CAAC,MAAc;IACzC,OAAO,MAAM,CAAC,OAAO,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC,CAAC,oCAAoC;AAC5F,CAAC","sourcesContent":["/**\n * @description Pads the end of a string with a specified character.\n * @summary Extends the input string to a specified length by adding a padding character to the end.\n * If the input string is already longer than the specified length, it is returned unchanged.\n *\n * @param {string} str - The input string to be padded.\n * @param {number} length - The desired total length of the resulting string.\n * @param {string} [char=\" \"] - The character to use for padding. Defaults to a space.\n * @return {string} The padded string.\n * @throws {Error} If the padding character is not exactly one character long.\n *\n * @function padEnd\n *\n * @memberOf module:utils\n */\nexport function padEnd(\n  str: string,\n  length: number,\n  char: string = \" \"\n): string {\n  if (char.length !== 1)\n    throw new Error(\"Invalid character length for padding. must be one!\");\n  return str.padEnd(length, char);\n}\n\n/**\n * @description Replaces placeholders in a string with provided values.\n * @summary Interpolates a string by replacing placeholders of the form ${variableName}\n * with corresponding values from the provided object. If a placeholder doesn't have\n * a corresponding value, it is left unchanged in the string.\n *\n * @param {string} input - The input string containing placeholders to be replaced.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @return {string} The interpolated string with placeholders replaced by their corresponding values.\n *\n * @function patchPlaceholders\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchString\n *   participant String.replace\n *   Caller->>patchString: Call with input and values\n *   patchString->>String.replace: Call with regex and replacement function\n *   String.replace->>patchString: Return replaced string\n *   patchString-->>Caller: Return patched string\n *\n * @memberOf module:utils\n */\nexport function patchPlaceholders(\n  input: string,\n  values: Record<string, number | string>\n): string {\n  return input.replace(\n    /\\$\\{([a-zA-Z0-9_]+)\\}/g,\n    (match, variable) => (values[variable as string] as string) || match\n  );\n}\n\n/**\n * @description Replaces occurrences of keys with their corresponding values in a string.\n * @summary Iterates through a set of key-value pairs and replaces all occurrences of each key\n * in the input string with its corresponding value. Supports regular expression flags for customized replacement.\n *\n * @param {string} input - The input string in which replacements will be made.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @param {string} [flags=\"g\"] - Regular expression flags to control the replacement behavior.\n * @return {string} The string with all specified replacements applied.\n *\n * @function patchString\n *\n * @memberOf module:utils\n */\nexport function patchString(\n  input: string,\n  values: Record<string, number | string>,\n  flags: string = \"g\"\n): string {\n  Object.entries(values).forEach(([key, val]) => {\n    const regexp = new RegExp(escapeRegExp(key), flags);\n    input = input.replace(regexp, val as string);\n  });\n  return input;\n}\n\n/**\n * @description Converts a string to camelCase.\n * @summary Transforms the input string into camelCase format, where words are joined without spaces\n * and each word after the first starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to camelCase.\n *\n * @function toCamelCase\n *\n * @memberOf module:utils\n */\nexport function toCamelCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word, index) =>\n      index === 0 ? word.toLowerCase() : word.toUpperCase()\n    )\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Converts a string to ENVIRONMENT_VARIABLE format.\n * @summary Transforms the input string into uppercase with words separated by underscores,\n * typically used for environment variable names.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.\n *\n * @function toENVFormat\n *\n * @memberOf module:utils\n */\nexport function toENVFormat(text: string): string {\n  return toSnakeCase(text).toUpperCase();\n}\n\n/**\n * @description Converts a string to snake_case.\n * @summary Transforms the input string into lowercase with words separated by underscores.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to snake_case.\n *\n * @function toSnakeCase\n *\n * @memberOf module:utils\n */\nexport function toSnakeCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1_$2\")\n    .replace(/[\\s-]+/g, \"_\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to kebab-case.\n * @summary Transforms the input string into lowercase with words separated by hyphens.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to kebab-case.\n *\n * @function toKebabCase\n *\n * @memberOf module:utils\n */\nexport function toKebabCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n    .replace(/[\\s_]+/g, \"-\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to PascalCase.\n * @summary Transforms the input string into PascalCase format, where words are joined without spaces\n * and each word starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to PascalCase.\n *\n * @function toPascalCase\n *\n * @memberOf module:utils\n */\nexport function toPascalCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word) => word.toUpperCase())\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Escapes special characters in a string for use in a regular expression.\n * @summary Adds backslashes before characters that have special meaning in regular expressions,\n * allowing the string to be used as a literal match in a RegExp.\n *\n * @param {string} string - The string to escape for regular expression use.\n * @return {string} The escaped string safe for use in regular expressions.\n *\n * @function escapeRegExp\n *\n * @memberOf module:utils\n */\nexport function escapeRegExp(string: string) {\n  return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"); // $& means the whole matched string\n}\n"]}
@@ -1,8 +0,0 @@
1
- /**
2
- * @description Determines if the current environment is a browser by checking the prototype chain of the global object.
3
- * @summary Checks if the code is running in a browser environment.
4
- * @return {boolean} True if the environment is a browser, false otherwise.
5
- * @function isBrowser
6
- * @memberOf module:utils
7
- */
8
- export declare function isBrowser(): boolean;
@@ -1,12 +0,0 @@
1
- /**
2
- * @description Determines if the current environment is a browser by checking the prototype chain of the global object.
3
- * @summary Checks if the code is running in a browser environment.
4
- * @return {boolean} True if the environment is a browser, false otherwise.
5
- * @function isBrowser
6
- * @memberOf module:utils
7
- */
8
- export function isBrowser() {
9
- return (Object.getPrototypeOf(Object.getPrototypeOf(globalThis)) !==
10
- Object.prototype);
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL3dlYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsU0FBUztJQUN2QixPQUFPLENBQ0wsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3hELE1BQU0sQ0FBQyxTQUFTLENBQ2pCLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAZGVzY3JpcHRpb24gRGV0ZXJtaW5lcyBpZiB0aGUgY3VycmVudCBlbnZpcm9ubWVudCBpcyBhIGJyb3dzZXIgYnkgY2hlY2tpbmcgdGhlIHByb3RvdHlwZSBjaGFpbiBvZiB0aGUgZ2xvYmFsIG9iamVjdC5cbiAqIEBzdW1tYXJ5IENoZWNrcyBpZiB0aGUgY29kZSBpcyBydW5uaW5nIGluIGEgYnJvd3NlciBlbnZpcm9ubWVudC5cbiAqIEByZXR1cm4ge2Jvb2xlYW59IFRydWUgaWYgdGhlIGVudmlyb25tZW50IGlzIGEgYnJvd3NlciwgZmFsc2Ugb3RoZXJ3aXNlLlxuICogQGZ1bmN0aW9uIGlzQnJvd3NlclxuICogQG1lbWJlck9mIG1vZHVsZTp1dGlsc1xuICovXG5leHBvcnQgZnVuY3Rpb24gaXNCcm93c2VyKCk6IGJvb2xlYW4ge1xuICByZXR1cm4gKFxuICAgIE9iamVjdC5nZXRQcm90b3R5cGVPZihPYmplY3QuZ2V0UHJvdG90eXBlT2YoZ2xvYmFsVGhpcykpICE9PVxuICAgIE9iamVjdC5wcm90b3R5cGVcbiAgKTtcbn1cbiJdfQ==
@@ -1,107 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Environment = void 0;
4
- const text_1 = require("./text.cjs");
5
- const web_1 = require("./web.cjs");
6
- const typed_object_accumulator_1 = require("typed-object-accumulator");
7
- /**
8
- * @class Environment
9
- * @extends {ObjectAccumulator<T>}
10
- * @template T
11
- * @description A class representing an environment with accumulation capabilities.
12
- * @summary Manages environment-related data and provides methods for accumulation and key retrieval.
13
- * @param {T} [initialData] - The initial data to populate the environment with.
14
- */
15
- class Environment extends typed_object_accumulator_1.ObjectAccumulator {
16
- /**
17
- * @static
18
- * @protected
19
- * @description A factory function for creating Environment instances.
20
- * @summary Defines how new instances of the Environment class should be created.
21
- * @return {Environment<any>} A new instance of the Environment class.
22
- */
23
- static { this.factory = () => new Environment(); }
24
- constructor() {
25
- super();
26
- }
27
- /**
28
- * @description Retrieves a value from the environment
29
- * @summary Gets a value from the environment variables, handling browser and Node.js environments differently
30
- * @param {string} k - The key to retrieve from the environment
31
- * @return {unknown} The value from the environment, or undefined if not found
32
- */
33
- fromEnv(k) {
34
- let env;
35
- if ((0, web_1.isBrowser)()) {
36
- env = globalThis["ENV"];
37
- }
38
- else {
39
- env = globalThis.process.env;
40
- k = (0, text_1.toENVFormat)(k);
41
- }
42
- return env[k];
43
- }
44
- /**
45
- * @description Expands an object into the environment
46
- * @summary Defines properties on the environment object that can be accessed as getters and setters
47
- * @template V - Type of the object being expanded
48
- * @param {V} value - The object to expand into the environment
49
- * @return {void}
50
- */
51
- expand(value) {
52
- Object.entries(value).forEach(([k, v]) => {
53
- Object.defineProperty(this, k, {
54
- get: () => {
55
- const fromEnv = this.fromEnv(k);
56
- return typeof fromEnv === "undefined" ? v : fromEnv;
57
- },
58
- set: (val) => {
59
- v = val;
60
- },
61
- configurable: true,
62
- enumerable: true,
63
- });
64
- });
65
- }
66
- /**
67
- * @protected
68
- * @static
69
- * @description Retrieves or creates the singleton instance of the Environment class.
70
- * @summary Ensures only one instance of the Environment class exists.
71
- * @template E
72
- * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.
73
- * @return {E} The singleton instance of the Environment class.
74
- */
75
- static instance(...args) {
76
- Environment._instance = !Environment._instance
77
- ? Environment.factory(...args)
78
- : Environment._instance;
79
- return Environment._instance;
80
- }
81
- /**
82
- * @static
83
- * @description Accumulates the given value into the environment.
84
- * @summary Adds new properties to the environment from the provided object.
85
- * @template V
86
- * @param {V} value - The object to accumulate into the environment.
87
- * @return {V} The updated environment instance.
88
- */
89
- static accumulate(value) {
90
- const instance = Environment.instance();
91
- return instance.accumulate(value);
92
- }
93
- /**
94
- * @static
95
- * @description Retrieves the keys of the environment, optionally converting them to ENV format.
96
- * @summary Gets all keys in the environment, with an option to format them for environment variables.
97
- * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.
98
- * @return {string[]} An array of keys from the environment.
99
- */
100
- static keys(toEnv = true) {
101
- return Environment.instance()
102
- .keys()
103
- .map((k) => (toEnv ? (0, text_1.toENVFormat)(k) : k));
104
- }
105
- }
106
- exports.Environment = Environment;
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../../src/utils/environment.ts"],"names":[],"mappings":";;;AAAA,qCAAqC;AAErC,mCAAkC;AAClC,uEAA6D;AAE7D;;;;;;;GAOG;AACH,MAAa,WAA8B,SAAQ,4CAAoB;IACrE;;;;;;OAMG;aACc,YAAO,GACtB,GAAqB,EAAE,CAAC,IAAI,WAAW,EAAE,CAAC;IAU5C;QACE,KAAK,EAAE,CAAC;IACV,CAAC;IAED;;;;;OAKG;IACO,OAAO,CAAC,CAAS;QACzB,IAAI,GAA4B,CAAC;QACjC,IAAI,IAAA,eAAS,GAAE,EAAE,CAAC;YAChB,GAAG,GAAI,UAA+D,CACpE,KAAK,CACN,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC;YAC7B,CAAC,GAAG,IAAA,kBAAW,EAAC,CAAC,CAAC,CAAC;QACrB,CAAC;QACD,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IACgB,MAAM,CAAmB,KAAQ;QAClD,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;YACvC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC,EAAE;gBAC7B,GAAG,EAAE,GAAG,EAAE;oBACR,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;oBAChC,OAAO,OAAO,OAAO,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;gBACtD,CAAC;gBACD,GAAG,EAAE,CAAC,GAAe,EAAE,EAAE;oBACvB,CAAC,GAAG,GAAG,CAAC;gBACV,CAAC;gBACD,YAAY,EAAE,IAAI;gBAClB,UAAU,EAAE,IAAI;aACjB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;OAQG;IACO,MAAM,CAAC,QAAQ,CAA6B,GAAG,IAAe;QACtE,WAAW,CAAC,SAAS,GAAG,CAAC,WAAW,CAAC,SAAS;YAC5C,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;YAC9B,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC;QAC1B,OAAO,WAAW,CAAC,SAAc,CAAC;IACpC,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CACf,KAAQ;QAIR,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,EAAE,CAAC;QACxC,OAAO,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,IAAI,CAAC,QAAiB,IAAI;QAC/B,OAAO,WAAW,CAAC,QAAQ,EAAE;aAC1B,IAAI,EAAE;aACN,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAA,kBAAW,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC;;AA7GH,kCA8GC","sourcesContent":["import { toENVFormat } from \"./text\";\nimport { EnvironmentFactory } from \"./types\";\nimport { isBrowser } from \"./web\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\n\n/**\n * @class Environment\n * @extends {ObjectAccumulator<T>}\n * @template T\n * @description A class representing an environment with accumulation capabilities.\n * @summary Manages environment-related data and provides methods for accumulation and key retrieval.\n * @param {T} [initialData] - The initial data to populate the environment with.\n */\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n  }\n\n  /**\n   * @description Retrieves a value from the environment\n   * @summary Gets a value from the environment variables, handling browser and Node.js environments differently\n   * @param {string} k - The key to retrieve from the environment\n   * @return {unknown} The value from the environment, or undefined if not found\n   */\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env = (globalThis as typeof globalThis & { ENV: Record<string, any> })[\n        \"ENV\"\n      ];\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return env[k];\n  }\n\n  /**\n   * @description Expands an object into the environment\n   * @summary Defines properties on the environment object that can be accessed as getters and setters\n   * @template V - Type of the object being expanded\n   * @param {V} value - The object to expand into the environment\n   * @return {void}\n   */\n  protected override expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          return typeof fromEnv === \"undefined\" ? v : fromEnv;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one instance of the Environment class exists.\n   * @template E\n   * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.\n   * @return {E} The singleton instance of the Environment class.\n   */\n  protected static instance<E extends Environment<any>>(...args: unknown[]): E {\n    Environment._instance = !Environment._instance\n      ? Environment.factory(...args)\n      : Environment._instance;\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties to the environment from the provided object.\n   * @template V\n   * @param {V} value - The object to accumulate into the environment.\n   * @return {V} The updated environment instance.\n   */\n  static accumulate<V extends object>(\n    value: V\n  ): typeof Environment._instance &\n    V &\n    ObjectAccumulator<typeof Environment._instance & V> {\n    const instance = Environment.instance();\n    return instance.accumulate(value);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n}\n"]}