@decaf-ts/utils 0.2.12 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +21 -157
- package/README.md +403 -12
- package/bin/build-scripts.cjs +236 -52
- package/bin/tag-release.cjs +168 -47
- package/bin/update-scripts.cjs +207 -47
- package/dist/utils.cjs +364 -70
- package/dist/utils.esm.cjs +364 -70
- package/lib/cli/command.cjs +2 -2
- package/lib/cli/command.d.ts +1 -1
- package/lib/cli/commands/build-scripts.cjs +8 -6
- package/lib/cli/constants.cjs +3 -1
- package/lib/cli/constants.d.ts +2 -0
- package/lib/cli/types.cjs +1 -1
- package/lib/cli/types.d.ts +2 -0
- package/lib/esm/bin/build-scripts.js +2 -2
- package/lib/esm/bin/tag-release.js +2 -2
- package/lib/esm/bin/update-scripts.js +2 -2
- package/lib/esm/cli/command.d.ts +1 -1
- package/lib/esm/cli/command.js +7 -7
- package/lib/esm/cli/commands/build-scripts.js +11 -9
- package/lib/esm/cli/commands/index.js +4 -4
- package/lib/esm/cli/commands/tag-release.js +5 -5
- package/lib/esm/cli/commands/update-scripts.js +4 -4
- package/lib/esm/cli/constants.d.ts +2 -0
- package/lib/esm/cli/constants.js +3 -1
- package/lib/esm/cli/index.js +4 -4
- package/lib/esm/cli/types.d.ts +2 -0
- package/lib/esm/cli/types.js +1 -1
- package/lib/esm/index.d.ts +4 -4
- package/lib/esm/index.js +10 -10
- package/lib/esm/input/index.js +3 -3
- package/lib/esm/input/input.d.ts +65 -19
- package/lib/esm/input/input.js +61 -22
- package/lib/esm/input/types.d.ts +7 -7
- package/lib/esm/input/types.js +1 -1
- package/lib/esm/output/common.d.ts +2 -0
- package/lib/esm/output/common.js +4 -1
- package/lib/esm/output/index.js +2 -2
- package/lib/esm/utils/constants.d.ts +12 -6
- package/lib/esm/utils/constants.js +13 -7
- package/lib/esm/utils/environment.d.ts +13 -0
- package/lib/esm/utils/environment.js +16 -3
- package/lib/esm/utils/fs.d.ts +111 -5
- package/lib/esm/utils/fs.js +114 -8
- package/lib/esm/utils/http.d.ts +1 -1
- package/lib/esm/utils/http.js +2 -2
- package/lib/esm/utils/index.js +8 -8
- package/lib/esm/utils/md.d.ts +15 -15
- package/lib/esm/utils/md.js +1 -1
- package/lib/esm/utils/tests.d.ts +26 -3
- package/lib/esm/utils/tests.js +40 -2
- package/lib/esm/utils/text.d.ts +33 -7
- package/lib/esm/utils/text.js +34 -8
- package/lib/esm/utils/timeout.d.ts +11 -0
- package/lib/esm/utils/timeout.js +12 -1
- package/lib/esm/utils/types.d.ts +33 -2
- package/lib/esm/utils/types.js +1 -1
- package/lib/esm/utils/utils.d.ts +44 -2
- package/lib/esm/utils/utils.js +23 -5
- package/lib/esm/utils/web.d.ts +3 -2
- package/lib/esm/utils/web.js +4 -3
- package/lib/esm/writers/OutputWriter.d.ts +2 -2
- package/lib/esm/writers/OutputWriter.js +1 -1
- package/lib/esm/writers/RegexpOutputWriter.d.ts +51 -10
- package/lib/esm/writers/RegexpOutputWriter.js +53 -12
- package/lib/esm/writers/StandardOutputWriter.d.ts +49 -10
- package/lib/esm/writers/StandardOutputWriter.js +51 -12
- package/lib/esm/writers/index.js +5 -5
- package/lib/esm/writers/types.d.ts +2 -2
- package/lib/esm/writers/types.js +1 -1
- package/lib/index.cjs +5 -5
- package/lib/index.d.ts +4 -4
- package/lib/input/input.cjs +61 -22
- package/lib/input/input.d.ts +65 -19
- package/lib/input/types.cjs +1 -1
- package/lib/input/types.d.ts +7 -7
- package/lib/output/common.cjs +4 -1
- package/lib/output/common.d.ts +2 -0
- package/lib/utils/constants.cjs +13 -7
- package/lib/utils/constants.d.ts +12 -6
- package/lib/utils/environment.cjs +14 -1
- package/lib/utils/environment.d.ts +13 -0
- package/lib/utils/fs.cjs +112 -6
- package/lib/utils/fs.d.ts +111 -5
- package/lib/utils/http.cjs +2 -2
- package/lib/utils/http.d.ts +1 -1
- package/lib/utils/md.cjs +1 -1
- package/lib/utils/md.d.ts +15 -15
- package/lib/utils/tests.cjs +39 -1
- package/lib/utils/tests.d.ts +26 -3
- package/lib/utils/text.cjs +34 -8
- package/lib/utils/text.d.ts +33 -7
- package/lib/utils/timeout.cjs +12 -1
- package/lib/utils/timeout.d.ts +11 -0
- package/lib/utils/types.cjs +1 -1
- package/lib/utils/types.d.ts +33 -2
- package/lib/utils/utils.cjs +21 -3
- package/lib/utils/utils.d.ts +44 -2
- package/lib/utils/web.cjs +4 -3
- package/lib/utils/web.d.ts +3 -2
- package/lib/writers/OutputWriter.cjs +1 -1
- package/lib/writers/OutputWriter.d.ts +2 -2
- package/lib/writers/RegexpOutputWriter.cjs +52 -11
- package/lib/writers/RegexpOutputWriter.d.ts +51 -10
- package/lib/writers/StandardOutputWriter.cjs +50 -11
- package/lib/writers/StandardOutputWriter.d.ts +49 -10
- package/lib/writers/types.cjs +1 -1
- package/lib/writers/types.d.ts +2 -2
- package/package.json +2 -2
|
@@ -2,21 +2,21 @@
|
|
|
2
2
|
* @description Default encoding for text operations.
|
|
3
3
|
* @summary The standard UTF-8 encoding used for text processing.
|
|
4
4
|
* @const {string} Encoding
|
|
5
|
-
* @memberOf
|
|
5
|
+
* @memberOf module:utils
|
|
6
6
|
*/
|
|
7
7
|
export declare const Encoding = "utf-8";
|
|
8
8
|
/**
|
|
9
9
|
* @description Regular expression for semantic versioning.
|
|
10
10
|
* @summary A regex pattern to match and parse semantic version strings.
|
|
11
11
|
* @const {RegExp} SemVersionRegex
|
|
12
|
-
* @memberOf
|
|
12
|
+
* @memberOf module:utils
|
|
13
13
|
*/
|
|
14
14
|
export declare const SemVersionRegex: RegExp;
|
|
15
15
|
/**
|
|
16
16
|
* @description Enum for semantic version components.
|
|
17
17
|
* @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.
|
|
18
18
|
* @enum {string}
|
|
19
|
-
* @memberOf
|
|
19
|
+
* @memberOf module:utils
|
|
20
20
|
*/
|
|
21
21
|
export declare enum SemVersion {
|
|
22
22
|
/** Patch version for backwards-compatible bug fixes. */
|
|
@@ -30,21 +30,21 @@ export declare enum SemVersion {
|
|
|
30
30
|
* @description Flag to indicate non-CI environment.
|
|
31
31
|
* @summary Used to specify that a command should run outside of a Continuous Integration environment.
|
|
32
32
|
* @const {string} NoCIFLag
|
|
33
|
-
* @memberOf
|
|
33
|
+
* @memberOf module:utils
|
|
34
34
|
*/
|
|
35
35
|
export declare const NoCIFLag = "-no-ci";
|
|
36
36
|
/**
|
|
37
37
|
* @description Key for the setup script in package.json.
|
|
38
38
|
* @summary Identifies the script that runs after package installation.
|
|
39
39
|
* @const {string} SetupScriptKey
|
|
40
|
-
* @memberOf
|
|
40
|
+
* @memberOf module:utils
|
|
41
41
|
*/
|
|
42
42
|
export declare const SetupScriptKey = "postinstall";
|
|
43
43
|
/**
|
|
44
44
|
* @description Enum for various authentication tokens.
|
|
45
45
|
* @summary Defines the file names for storing different types of authentication tokens.
|
|
46
46
|
* @enum {string}
|
|
47
|
-
* @memberOf
|
|
47
|
+
* @memberOf module:utils
|
|
48
48
|
*/
|
|
49
49
|
export declare enum Tokens {
|
|
50
50
|
/** Git authentication token file name. */
|
|
@@ -56,4 +56,10 @@ export declare enum Tokens {
|
|
|
56
56
|
/** Confluence authentication token file name. */
|
|
57
57
|
CONFLUENCE = ".confluence-token"
|
|
58
58
|
}
|
|
59
|
+
/**
|
|
60
|
+
* @description Code used to indicate an operation was aborted.
|
|
61
|
+
* @summary Standard message used when a process is manually terminated.
|
|
62
|
+
* @const {string} AbortCode
|
|
63
|
+
* @memberOf module:utils
|
|
64
|
+
*/
|
|
59
65
|
export declare const AbortCode = "Aborted";
|
|
@@ -2,21 +2,21 @@
|
|
|
2
2
|
* @description Default encoding for text operations.
|
|
3
3
|
* @summary The standard UTF-8 encoding used for text processing.
|
|
4
4
|
* @const {string} Encoding
|
|
5
|
-
* @memberOf
|
|
5
|
+
* @memberOf module:utils
|
|
6
6
|
*/
|
|
7
7
|
export const Encoding = "utf-8";
|
|
8
8
|
/**
|
|
9
9
|
* @description Regular expression for semantic versioning.
|
|
10
10
|
* @summary A regex pattern to match and parse semantic version strings.
|
|
11
11
|
* @const {RegExp} SemVersionRegex
|
|
12
|
-
* @memberOf
|
|
12
|
+
* @memberOf module:utils
|
|
13
13
|
*/
|
|
14
14
|
export const SemVersionRegex = /^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z])))/g;
|
|
15
15
|
/**
|
|
16
16
|
* @description Enum for semantic version components.
|
|
17
17
|
* @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.
|
|
18
18
|
* @enum {string}
|
|
19
|
-
* @memberOf
|
|
19
|
+
* @memberOf module:utils
|
|
20
20
|
*/
|
|
21
21
|
export var SemVersion;
|
|
22
22
|
(function (SemVersion) {
|
|
@@ -31,21 +31,21 @@ export var SemVersion;
|
|
|
31
31
|
* @description Flag to indicate non-CI environment.
|
|
32
32
|
* @summary Used to specify that a command should run outside of a Continuous Integration environment.
|
|
33
33
|
* @const {string} NoCIFLag
|
|
34
|
-
* @memberOf
|
|
34
|
+
* @memberOf module:utils
|
|
35
35
|
*/
|
|
36
36
|
export const NoCIFLag = "-no-ci";
|
|
37
37
|
/**
|
|
38
38
|
* @description Key for the setup script in package.json.
|
|
39
39
|
* @summary Identifies the script that runs after package installation.
|
|
40
40
|
* @const {string} SetupScriptKey
|
|
41
|
-
* @memberOf
|
|
41
|
+
* @memberOf module:utils
|
|
42
42
|
*/
|
|
43
43
|
export const SetupScriptKey = "postinstall";
|
|
44
44
|
/**
|
|
45
45
|
* @description Enum for various authentication tokens.
|
|
46
46
|
* @summary Defines the file names for storing different types of authentication tokens.
|
|
47
47
|
* @enum {string}
|
|
48
|
-
* @memberOf
|
|
48
|
+
* @memberOf module:utils
|
|
49
49
|
*/
|
|
50
50
|
export var Tokens;
|
|
51
51
|
(function (Tokens) {
|
|
@@ -58,5 +58,11 @@ export var Tokens;
|
|
|
58
58
|
/** Confluence authentication token file name. */
|
|
59
59
|
Tokens["CONFLUENCE"] = ".confluence-token";
|
|
60
60
|
})(Tokens || (Tokens = {}));
|
|
61
|
+
/**
|
|
62
|
+
* @description Code used to indicate an operation was aborted.
|
|
63
|
+
* @summary Standard message used when a process is manually terminated.
|
|
64
|
+
* @const {string} AbortCode
|
|
65
|
+
* @memberOf module:utils
|
|
66
|
+
*/
|
|
61
67
|
export const AbortCode = "Aborted";
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUM7QUFFaEM7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQzFCLDREQUE0RCxDQUFDO0FBRS9EOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFOLElBQVksVUFPWDtBQVBELFdBQVksVUFBVTtJQUNwQix3REFBd0Q7SUFDeEQsNkJBQWUsQ0FBQTtJQUNmLDJEQUEyRDtJQUMzRCw2QkFBZSxDQUFBO0lBQ2Ysb0VBQW9FO0lBQ3BFLDZCQUFlLENBQUE7QUFDakIsQ0FBQyxFQVBXLFVBQVUsS0FBVixVQUFVLFFBT3JCO0FBRUQ7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDO0FBRWpDOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLGFBQWEsQ0FBQztBQUU1Qzs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBTixJQUFZLE1BU1g7QUFURCxXQUFZLE1BQU07SUFDaEIsMENBQTBDO0lBQzFDLHdCQUFjLENBQUE7SUFDZCwwQ0FBMEM7SUFDMUMsMkJBQWlCLENBQUE7SUFDakIsNkNBQTZDO0lBQzdDLGlDQUF1QixDQUFBO0lBQ3ZCLGlEQUFpRDtJQUNqRCwwQ0FBZ0MsQ0FBQTtBQUNsQyxDQUFDLEVBVFcsTUFBTSxLQUFOLE1BQU0sUUFTakI7QUFFRDs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGVuY29kaW5nIGZvciB0ZXh0IG9wZXJhdGlvbnMuXG4gKiBAc3VtbWFyeSBUaGUgc3RhbmRhcmQgVVRGLTggZW5jb2RpbmcgdXNlZCBmb3IgdGV4dCBwcm9jZXNzaW5nLlxuICogQGNvbnN0IHtzdHJpbmd9IEVuY29kaW5nXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnV0aWxzXG4gKi9cbmV4cG9ydCBjb25zdCBFbmNvZGluZyA9IFwidXRmLThcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gUmVndWxhciBleHByZXNzaW9uIGZvciBzZW1hbnRpYyB2ZXJzaW9uaW5nLlxuICogQHN1bW1hcnkgQSByZWdleCBwYXR0ZXJuIHRvIG1hdGNoIGFuZCBwYXJzZSBzZW1hbnRpYyB2ZXJzaW9uIHN0cmluZ3MuXG4gKiBAY29uc3Qge1JlZ0V4cH0gU2VtVmVyc2lvblJlZ2V4XG4gKiBAbWVtYmVyT2YgbW9kdWxlOnV0aWxzXG4gKi9cbmV4cG9ydCBjb25zdCBTZW1WZXJzaW9uUmVnZXggPVxuICAvXihcXGQrKVxcLihcXGQrKVxcLihcXGQrKSg/Oi0oWzAtOUEtWmEtei1dKyg/OlxcLlswLTlBLVphLXpdKSkpL2c7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEVudW0gZm9yIHNlbWFudGljIHZlcnNpb24gY29tcG9uZW50cy5cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIHRocmVlIGxldmVscyBvZiBzZW1hbnRpYyB2ZXJzaW9uaW5nOiBQQVRDSCwgTUlOT1IsIGFuZCBNQUpPUi5cbiAqIEBlbnVtIHtzdHJpbmd9XG4gKiBAbWVtYmVyT2YgbW9kdWxlOnV0aWxzXG4gKi9cbmV4cG9ydCBlbnVtIFNlbVZlcnNpb24ge1xuICAvKiogUGF0Y2ggdmVyc2lvbiBmb3IgYmFja3dhcmRzLWNvbXBhdGlibGUgYnVnIGZpeGVzLiAqL1xuICBQQVRDSCA9IFwicGF0Y2hcIixcbiAgLyoqIE1pbm9yIHZlcnNpb24gZm9yIGJhY2t3YXJkcy1jb21wYXRpYmxlIG5ldyBmZWF0dXJlcy4gKi9cbiAgTUlOT1IgPSBcIm1pbm9yXCIsXG4gIC8qKiBNYWpvciB2ZXJzaW9uIGZvciBjaGFuZ2VzIHRoYXQgYnJlYWsgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuICovXG4gIE1BSk9SID0gXCJtYWpvclwiLFxufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBGbGFnIHRvIGluZGljYXRlIG5vbi1DSSBlbnZpcm9ubWVudC5cbiAqIEBzdW1tYXJ5IFVzZWQgdG8gc3BlY2lmeSB0aGF0IGEgY29tbWFuZCBzaG91bGQgcnVuIG91dHNpZGUgb2YgYSBDb250aW51b3VzIEludGVncmF0aW9uIGVudmlyb25tZW50LlxuICogQGNvbnN0IHtzdHJpbmd9IE5vQ0lGTGFnXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnV0aWxzXG4gKi9cbmV4cG9ydCBjb25zdCBOb0NJRkxhZyA9IFwiLW5vLWNpXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEtleSBmb3IgdGhlIHNldHVwIHNjcmlwdCBpbiBwYWNrYWdlLmpzb24uXG4gKiBAc3VtbWFyeSBJZGVudGlmaWVzIHRoZSBzY3JpcHQgdGhhdCBydW5zIGFmdGVyIHBhY2thZ2UgaW5zdGFsbGF0aW9uLlxuICogQGNvbnN0IHtzdHJpbmd9IFNldHVwU2NyaXB0S2V5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOnV0aWxzXG4gKi9cbmV4cG9ydCBjb25zdCBTZXR1cFNjcmlwdEtleSA9IFwicG9zdGluc3RhbGxcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRW51bSBmb3IgdmFyaW91cyBhdXRoZW50aWNhdGlvbiB0b2tlbnMuXG4gKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBmaWxlIG5hbWVzIGZvciBzdG9yaW5nIGRpZmZlcmVudCB0eXBlcyBvZiBhdXRoZW50aWNhdGlvbiB0b2tlbnMuXG4gKiBAZW51bSB7c3RyaW5nfVxuICogQG1lbWJlck9mIG1vZHVsZTp1dGlsc1xuICovXG5leHBvcnQgZW51bSBUb2tlbnMge1xuICAvKiogR2l0IGF1dGhlbnRpY2F0aW9uIHRva2VuIGZpbGUgbmFtZS4gKi9cbiAgR0lUID0gXCIudG9rZW5cIixcbiAgLyoqIE5QTSBhdXRoZW50aWNhdGlvbiB0b2tlbiBmaWxlIG5hbWUuICovXG4gIE5QTSA9IFwiLm5wbXRva2VuXCIsXG4gIC8qKiBEb2NrZXIgYXV0aGVudGljYXRpb24gdG9rZW4gZmlsZSBuYW1lLiAqL1xuICBET0NLRVIgPSBcIi5kb2NrZXJ0b2tlblwiLFxuICAvKiogQ29uZmx1ZW5jZSBhdXRoZW50aWNhdGlvbiB0b2tlbiBmaWxlIG5hbWUuICovXG4gIENPTkZMVUVOQ0UgPSBcIi5jb25mbHVlbmNlLXRva2VuXCIsXG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIENvZGUgdXNlZCB0byBpbmRpY2F0ZSBhbiBvcGVyYXRpb24gd2FzIGFib3J0ZWQuXG4gKiBAc3VtbWFyeSBTdGFuZGFyZCBtZXNzYWdlIHVzZWQgd2hlbiBhIHByb2Nlc3MgaXMgbWFudWFsbHkgdGVybWluYXRlZC5cbiAqIEBjb25zdCB7c3RyaW5nfSBBYm9ydENvZGVcbiAqIEBtZW1iZXJPZiBtb2R1bGU6dXRpbHNcbiAqL1xuZXhwb3J0IGNvbnN0IEFib3J0Q29kZSA9IFwiQWJvcnRlZFwiO1xuIl19
|
|
@@ -25,7 +25,20 @@ export declare class Environment<T extends object> extends ObjectAccumulator<T>
|
|
|
25
25
|
*/
|
|
26
26
|
private static _instance;
|
|
27
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
|
+
*/
|
|
28
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
|
+
*/
|
|
29
42
|
protected expand<V extends object>(value: V): void;
|
|
30
43
|
/**
|
|
31
44
|
* @protected
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { toENVFormat } from "./text";
|
|
2
|
-
import { isBrowser } from "./web";
|
|
1
|
+
import { toENVFormat } from "./text.js";
|
|
2
|
+
import { isBrowser } from "./web.js";
|
|
3
3
|
import { ObjectAccumulator } from "typed-object-accumulator";
|
|
4
4
|
/**
|
|
5
5
|
* @class Environment
|
|
@@ -21,6 +21,12 @@ export class Environment extends ObjectAccumulator {
|
|
|
21
21
|
constructor() {
|
|
22
22
|
super();
|
|
23
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
|
+
*/
|
|
24
30
|
fromEnv(k) {
|
|
25
31
|
let env;
|
|
26
32
|
if (isBrowser()) {
|
|
@@ -32,6 +38,13 @@ export class Environment extends ObjectAccumulator {
|
|
|
32
38
|
}
|
|
33
39
|
return env[k];
|
|
34
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
|
+
*/
|
|
35
48
|
expand(value) {
|
|
36
49
|
Object.entries(value).forEach(([k, v]) => {
|
|
37
50
|
Object.defineProperty(this, k, {
|
|
@@ -87,4 +100,4 @@ export class Environment extends ObjectAccumulator {
|
|
|
87
100
|
.map((k) => (toEnv ? toENVFormat(k) : k));
|
|
88
101
|
}
|
|
89
102
|
}
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"]}
|
package/lib/esm/utils/fs.d.ts
CHANGED
|
@@ -31,7 +31,7 @@ import { DependencyMap, SimpleDependencyMap } from "./types";
|
|
|
31
31
|
* writeFile-->>patchFile: File written
|
|
32
32
|
* patchFile-->>Caller: Patching complete
|
|
33
33
|
*
|
|
34
|
-
* @memberOf module:
|
|
34
|
+
* @memberOf module:utils
|
|
35
35
|
*/
|
|
36
36
|
export declare function patchFile(path: string, values: Record<string, number | string>): void;
|
|
37
37
|
/**
|
|
@@ -64,16 +64,51 @@ export declare function writeFile(path: string, data: string | Buffer): void;
|
|
|
64
64
|
* @summary Traverses through directories and subdirectories to collect all file paths.
|
|
65
65
|
*
|
|
66
66
|
* @param {string} p - The path to start searching from.
|
|
67
|
-
* @param filter
|
|
67
|
+
* @param {function} [filter] - Optional function to filter files by name or index.
|
|
68
68
|
* @return {string[]} Array of file paths.
|
|
69
69
|
*
|
|
70
70
|
* @function getAllFiles
|
|
71
71
|
*
|
|
72
|
-
* @memberOf module:
|
|
72
|
+
* @memberOf module:utils
|
|
73
73
|
*/
|
|
74
74
|
export declare function getAllFiles(p: string, filter?: (f: string, i?: number) => boolean): string[];
|
|
75
|
+
/**
|
|
76
|
+
* @description Renames a file or directory.
|
|
77
|
+
* @summary Moves a file or directory from the source path to the destination path.
|
|
78
|
+
*
|
|
79
|
+
* @param {string} source - The source path of the file or directory.
|
|
80
|
+
* @param {string} dest - The destination path for the file or directory.
|
|
81
|
+
* @return {Promise<void>} A promise that resolves when the rename operation is complete.
|
|
82
|
+
*
|
|
83
|
+
* @function renameFile
|
|
84
|
+
*
|
|
85
|
+
* @memberOf module:utils
|
|
86
|
+
*/
|
|
75
87
|
export declare function renameFile(source: string, dest: string): Promise<void>;
|
|
88
|
+
/**
|
|
89
|
+
* @description Copies a file or directory.
|
|
90
|
+
* @summary Creates a copy of a file or directory from the source path to the destination path.
|
|
91
|
+
*
|
|
92
|
+
* @param {string} source - The source path of the file or directory.
|
|
93
|
+
* @param {string} dest - The destination path for the file or directory.
|
|
94
|
+
* @return {void}
|
|
95
|
+
*
|
|
96
|
+
* @function copyFile
|
|
97
|
+
*
|
|
98
|
+
* @memberOf module:utils
|
|
99
|
+
*/
|
|
76
100
|
export declare function copyFile(source: string, dest: string): void;
|
|
101
|
+
/**
|
|
102
|
+
* @description Deletes a file or directory.
|
|
103
|
+
* @summary Removes a file or directory at the specified path, with recursive and force options enabled.
|
|
104
|
+
*
|
|
105
|
+
* @param {string} p - The path to the file or directory to delete.
|
|
106
|
+
* @return {void}
|
|
107
|
+
*
|
|
108
|
+
* @function deletePath
|
|
109
|
+
*
|
|
110
|
+
* @memberOf module:utils
|
|
111
|
+
*/
|
|
77
112
|
export declare function deletePath(p: string): void;
|
|
78
113
|
/**
|
|
79
114
|
* @description Retrieves package information from package.json.
|
|
@@ -106,6 +141,19 @@ export declare function deletePath(p: string): void;
|
|
|
106
141
|
* @memberOf module:utils
|
|
107
142
|
*/
|
|
108
143
|
export declare function getPackage(p?: string, property?: string): object | string;
|
|
144
|
+
/**
|
|
145
|
+
* @description Sets an attribute in the package.json file.
|
|
146
|
+
* @summary Updates a specific attribute in the package.json file with the provided value.
|
|
147
|
+
*
|
|
148
|
+
* @param {string} attr - The attribute name to set in package.json.
|
|
149
|
+
* @param {string | number | object} value - The value to set for the attribute.
|
|
150
|
+
* @param {string} [p=process.cwd()] - The directory path where the package.json file is located.
|
|
151
|
+
* @return {void}
|
|
152
|
+
*
|
|
153
|
+
* @function setPackageAttribute
|
|
154
|
+
*
|
|
155
|
+
* @memberOf module:utils
|
|
156
|
+
*/
|
|
109
157
|
export declare function setPackageAttribute(attr: string, value: string, p?: string): void;
|
|
110
158
|
/**
|
|
111
159
|
* @description Retrieves the version from package.json.
|
|
@@ -113,7 +161,7 @@ export declare function setPackageAttribute(attr: string, value: string, p?: str
|
|
|
113
161
|
* @param {string} [p=process.cwd()] - The directory path where the package.json file is located.
|
|
114
162
|
* @return {string} The version string from package.json.
|
|
115
163
|
* @function getPackageVersion
|
|
116
|
-
* @memberOf module:
|
|
164
|
+
* @memberOf module:utils
|
|
117
165
|
*/
|
|
118
166
|
export declare function getPackageVersion(p?: string): string;
|
|
119
167
|
/**
|
|
@@ -135,15 +183,73 @@ export declare function getPackageVersion(p?: string): string;
|
|
|
135
183
|
* JSON-->>getDependencies: Return parsed object
|
|
136
184
|
* getDependencies->>getDependencies: Process dependencies
|
|
137
185
|
* getDependencies-->>Caller: Return processed dependencies
|
|
138
|
-
* @memberOf module:
|
|
186
|
+
* @memberOf module:utils
|
|
139
187
|
*/
|
|
140
188
|
export declare function getDependencies(path?: string): Promise<DependencyMap>;
|
|
189
|
+
/**
|
|
190
|
+
* @description Updates project dependencies to their latest versions.
|
|
191
|
+
* @summary Runs npm-check-updates to update package.json and then installs the updated dependencies.
|
|
192
|
+
*
|
|
193
|
+
* @return {Promise<void>} A promise that resolves when dependencies are updated.
|
|
194
|
+
*
|
|
195
|
+
* @function updateDependencies
|
|
196
|
+
*
|
|
197
|
+
* @memberOf module:utils
|
|
198
|
+
*/
|
|
141
199
|
export declare function updateDependencies(): Promise<void>;
|
|
200
|
+
/**
|
|
201
|
+
* @description Installs dependencies if they are not already available.
|
|
202
|
+
* @summary Checks if specified dependencies are installed and installs any that are missing.
|
|
203
|
+
*
|
|
204
|
+
* @param {string[] | string} deps - The dependencies to check and potentially install.
|
|
205
|
+
* @param {SimpleDependencyMap} [dependencies] - Optional map of existing dependencies.
|
|
206
|
+
* @return {Promise<SimpleDependencyMap>} Updated map of dependencies.
|
|
207
|
+
*
|
|
208
|
+
* @function installIfNotAvailable
|
|
209
|
+
*
|
|
210
|
+
* @memberOf module:utils
|
|
211
|
+
*/
|
|
142
212
|
export declare function installIfNotAvailable(deps: string[] | string, dependencies?: SimpleDependencyMap): Promise<SimpleDependencyMap>;
|
|
213
|
+
/**
|
|
214
|
+
* @description Pushes changes to Git repository.
|
|
215
|
+
* @summary Temporarily changes Git user configuration, commits all changes, pushes to remote, and restores original user configuration.
|
|
216
|
+
*
|
|
217
|
+
* @return {Promise<void>} A promise that resolves when changes are pushed.
|
|
218
|
+
*
|
|
219
|
+
* @function pushToGit
|
|
220
|
+
*
|
|
221
|
+
* @memberOf module:utils
|
|
222
|
+
*/
|
|
143
223
|
export declare function pushToGit(): Promise<void>;
|
|
224
|
+
/**
|
|
225
|
+
* @description Installs project dependencies.
|
|
226
|
+
* @summary Installs production, development, and peer dependencies as specified.
|
|
227
|
+
*
|
|
228
|
+
* @param {object} dependencies - Object containing arrays of dependencies to install.
|
|
229
|
+
* @param {string[]} [dependencies.prod] - Production dependencies to install.
|
|
230
|
+
* @param {string[]} [dependencies.dev] - Development dependencies to install.
|
|
231
|
+
* @param {string[]} [dependencies.peer] - Peer dependencies to install.
|
|
232
|
+
* @return {Promise<void>} A promise that resolves when all dependencies are installed.
|
|
233
|
+
*
|
|
234
|
+
* @function installDependencies
|
|
235
|
+
*
|
|
236
|
+
* @memberOf module:utils
|
|
237
|
+
*/
|
|
144
238
|
export declare function installDependencies(dependencies: {
|
|
145
239
|
prod?: string[];
|
|
146
240
|
dev?: string[];
|
|
147
241
|
peer?: string[];
|
|
148
242
|
}): Promise<void>;
|
|
243
|
+
/**
|
|
244
|
+
* @description Normalizes imports to handle both CommonJS and ESModule formats.
|
|
245
|
+
* @summary Utility function to handle module import differences between formats.
|
|
246
|
+
*
|
|
247
|
+
* @template T - Type of the imported module.
|
|
248
|
+
* @param {Promise<T>} importPromise - Promise returned by dynamic import.
|
|
249
|
+
* @return {Promise<T>} Normalized module.
|
|
250
|
+
*
|
|
251
|
+
* @function normalizeImport
|
|
252
|
+
*
|
|
253
|
+
* @memberOf module:utils
|
|
254
|
+
*/
|
|
149
255
|
export declare function normalizeImport<T>(importPromise: Promise<T>): Promise<T>;
|