@willbooster/shared-lib-node 2.8.5 → 3.0.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/dist/env.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var e=require("node:path"),n=require("dotenv");exports.loadEnvironmentVariables=function(o,a){let t=(o.env??[]).map((e=>e.toString()));const r=o.cascadeNodeEnv?process.env.NODE_ENV||"development":o.cascadeEnv;"string"==typeof r&&(0===t.length&&t.push(".env"),t=t.flatMap((e=>r?[`${e}.${r}.local`,`${e}.local`,`${e}.${r}`,e]:[`${e}.local`,e]))),o.verbose&&console.info("Loading env files:",t);let l={};for(const o of t)l={...n.config({path:e.join(a,o)}).parsed,...l};return l},exports.removeNpmAndYarnEnvironmentVariables=function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const n of Object.keys(e)){const o=n.toUpperCase();(o.startsWith("NPM_")||o.startsWith("YARN_")||o.startsWith("BERRY_")||"PROJECT_CWD"===o||"INIT_CWD"===o)&&delete e[n]}},exports.yargsOptionsBuilderForEnv={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`)",type:"string"},"cascade-node-env":{description:'environment to load cascading .env files (e.g., `.env`, `.env.<NODE_ENV>`, `.env.local` and `.env.<NODE_ENV>.local`). If NODE_ENV is falsy, "development" is applied. Preferred over `cascade`.',type:"boolean"}};
1
+ "use strict";var e=require("node:path"),n=require("dotenv");exports.loadEnvironmentVariables=function(a,o){let t=(a.env??[]).map((e=>e.toString()));const r=a.cascadeEnv??(a.cascadeNodeEnv?process.env.NODE_ENV||"development":a.autoCascadeEnv?process.env.WB_ENV||process.env.APP_ENV||process.env.NODE_ENV||"development":void 0);"string"==typeof r&&(0===t.length&&t.push(".env"),t=t.flatMap((e=>r?[`${e}.${r}.local`,`${e}.local`,`${e}.${r}`,e]:[`${e}.local`,e]))),a.verbose&&console.info("Loading env files:",t);let s={};for(const a of t)s={...n.config({path:e.join(o,a)}).parsed,...s};return s},exports.removeNpmAndYarnEnvironmentVariables=function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const n of Object.keys(e)){const a=n.toUpperCase();(a.startsWith("NPM_")||a.startsWith("YARN_")||a.startsWith("BERRY_")||"PROJECT_CWD"===a||"INIT_CWD"===a)&&delete e[n]}},exports.yargsOptionsBuilderForEnv={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV>. If NODE_ENV is falsy, "development" is applied. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || APP_ENV || NODE_ENV>. If they are falsy, "development" is applied.',type:"boolean",default:!0}};
2
2
  //# sourceMappingURL=env.cjs.map
package/dist/env.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"env.cjs","sources":["../src/env.ts"],"sourcesContent":["import path from 'node:path';\n\nimport { config } from 'dotenv';\n\ninterface Options {\n env?: (string | number)[];\n cascadeEnv?: string;\n cascadeNodeEnv?: boolean;\n verbose?: boolean;\n}\n\nexport const yargsOptionsBuilderForEnv = {\n env: {\n description: '.env files to be loaded.',\n type: 'array',\n },\n 'cascade-env': {\n description:\n 'environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`)',\n type: 'string',\n },\n 'cascade-node-env': {\n description:\n 'environment to load cascading .env files (e.g., `.env`, `.env.<NODE_ENV>`, `.env.local` and `.env.<NODE_ENV>.local`). If NODE_ENV is falsy, \"development\" is applied. Preferred over `cascade`.',\n type: 'boolean',\n },\n} as const;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string> {\n let envPaths = (argv.env ?? []).map((envPath) => envPath.toString());\n const cascade = argv.cascadeNodeEnv ? process.env.NODE_ENV || 'development' : argv.cascadeEnv;\n if (typeof cascade === 'string') {\n if (envPaths.length === 0) envPaths.push('.env');\n envPaths = envPaths.flatMap((envPath) =>\n cascade\n ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n : [`${envPath}.local`, envPath]\n );\n }\n if (argv.verbose) {\n console.info('Loading env files:', envPaths);\n }\n\n let envVars = {};\n for (const envPath of envPaths) {\n envVars = { ...config({ path: path.join(cwd, envPath) }).parsed, ...envVars };\n }\n return envVars;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n // Remove npm & yarn environment variables from process.env\n if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n // Temporary directory in macOS\n .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n // Temporary directories in Linux\n .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n }\n for (const key of Object.keys(envVars)) {\n const upperKey = key.toUpperCase();\n if (\n upperKey.startsWith('NPM_') ||\n upperKey.startsWith('YARN_') ||\n upperKey.startsWith('BERRY_') ||\n upperKey === 'PROJECT_CWD' ||\n upperKey === 'INIT_CWD'\n ) {\n delete envVars[key];\n }\n }\n}\n"],"names":["argv","cwd","envPaths","env","map","envPath","toString","cascade","cascadeNodeEnv","process","NODE_ENV","cascadeEnv","length","push","flatMap","verbose","console","info","envVars","config","path","join","parsed","PATH","BERRY_BIN_FOLDER","replace","replaceAll","key","Object","keys","upperKey","toUpperCase","startsWith","description","type"],"mappings":"6FA+BO,SAAkCA,EAAeC,GACtD,IAAIC,GAAYF,EAAKG,KAAO,IAAIC,KAAKC,GAAYA,EAAQC,aACzD,MAAMC,EAAUP,EAAKQ,eAAiBC,QAAQN,IAAIO,UAAY,cAAgBV,EAAKW,WAC5D,iBAAZJ,IACe,IAApBL,EAASU,QAAcV,EAASW,KAAK,QACzCX,EAAWA,EAASY,SAAST,GAC3BE,EACI,CAAE,GAAEF,KAAWE,UAAkB,GAAEF,UAAkB,GAAEA,KAAWE,IAAWF,GAC7E,CAAE,GAAEA,UAAiBA,MAGzBL,EAAKe,SACPC,QAAQC,KAAK,qBAAsBf,GAGrC,IAAIgB,EAAU,CAAA,EACd,IAAK,MAAMb,KAAWH,EACpBgB,EAAU,IAAKC,SAAO,CAAEC,KAAMA,EAAKC,KAAKpB,EAAKI,KAAYiB,UAAWJ,GAEtE,OAAOA,CACT,+CAKO,SAA8CA,GAE/CA,EAAQK,MAAQL,EAAQM,mBAC1BN,EAAQK,KAAOL,EAAQK,KAAKE,QAAS,GAAEP,EAAQM,oBAAqB,IAEjEE,WAAW,mCAAoC,IAE/CA,WAAW,sBAAuB,IAClCA,WAAW,iBAAkB,KAElC,IAAK,MAAMC,KAAOC,OAAOC,KAAKX,GAAU,CACtC,MAAMY,EAAWH,EAAII,eAEnBD,EAASE,WAAW,SACpBF,EAASE,WAAW,UACpBF,EAASE,WAAW,WACP,gBAAbF,GACa,aAAbA,WAEOZ,EAAQS,EAEnB,CACF,oCAnEyC,CACvCxB,IAAK,CACH8B,YAAa,2BACbC,KAAM,SAER,cAAe,CACbD,YACE,6HACFC,KAAM,UAER,mBAAoB,CAClBD,YACE,kMACFC,KAAM"}
1
+ {"version":3,"file":"env.cjs","sources":["../src/env.ts"],"sourcesContent":["import path from 'node:path';\n\nimport { config } from 'dotenv';\n\ninterface Options {\n env?: (string | number)[];\n cascadeEnv?: string;\n cascadeNodeEnv?: boolean;\n autoCascadeEnv?: boolean;\n verbose?: boolean;\n}\n\nexport const yargsOptionsBuilderForEnv = {\n env: {\n description: '.env files to be loaded.',\n type: 'array',\n },\n 'cascade-env': {\n description:\n 'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n type: 'string',\n },\n 'cascade-node-env': {\n description:\n 'Same with --cascade-env=<NODE_ENV>. If NODE_ENV is falsy, \"development\" is applied. Preferred over `auto-cascade-env`.',\n type: 'boolean',\n },\n 'auto-cascade-env': {\n description:\n 'Same with --cascade-env=<WB_ENV || APP_ENV || NODE_ENV>. If they are falsy, \"development\" is applied.',\n type: 'boolean',\n default: true,\n },\n} as const;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string> {\n let envPaths = (argv.env ?? []).map((envPath) => envPath.toString());\n const cascade =\n argv.cascadeEnv ??\n (argv.cascadeNodeEnv\n ? process.env.NODE_ENV || 'development'\n : argv.autoCascadeEnv\n ? process.env.WB_ENV || process.env.APP_ENV || process.env.NODE_ENV || 'development'\n : undefined);\n if (typeof cascade === 'string') {\n if (envPaths.length === 0) envPaths.push('.env');\n envPaths = envPaths.flatMap((envPath) =>\n cascade\n ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n : [`${envPath}.local`, envPath]\n );\n }\n if (argv.verbose) {\n console.info('Loading env files:', envPaths);\n }\n\n let envVars = {};\n for (const envPath of envPaths) {\n envVars = { ...config({ path: path.join(cwd, envPath) }).parsed, ...envVars };\n }\n return envVars;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n // Remove npm & yarn environment variables from process.env\n if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n // Temporary directory in macOS\n .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n // Temporary directories in Linux\n .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n }\n for (const key of Object.keys(envVars)) {\n const upperKey = key.toUpperCase();\n if (\n upperKey.startsWith('NPM_') ||\n upperKey.startsWith('YARN_') ||\n upperKey.startsWith('BERRY_') ||\n upperKey === 'PROJECT_CWD' ||\n upperKey === 'INIT_CWD'\n ) {\n delete envVars[key];\n }\n }\n}\n"],"names":["argv","cwd","envPaths","env","map","envPath","toString","cascade","cascadeEnv","cascadeNodeEnv","process","NODE_ENV","autoCascadeEnv","WB_ENV","APP_ENV","undefined","length","push","flatMap","verbose","console","info","envVars","config","path","join","parsed","PATH","BERRY_BIN_FOLDER","replace","replaceAll","key","Object","keys","upperKey","toUpperCase","startsWith","description","type","default"],"mappings":"6FAsCO,SAAkCA,EAAeC,GACtD,IAAIC,GAAYF,EAAKG,KAAO,IAAIC,KAAKC,GAAYA,EAAQC,aACzD,MAAMC,EACJP,EAAKQ,aACJR,EAAKS,eACFC,QAAQP,IAAIQ,UAAY,cACxBX,EAAKY,eACLF,QAAQP,IAAIU,QAAUH,QAAQP,IAAIW,SAAWJ,QAAQP,IAAIQ,UAAY,mBACrEI,GACiB,iBAAZR,IACe,IAApBL,EAASc,QAAcd,EAASe,KAAK,QACzCf,EAAWA,EAASgB,SAASb,GAC3BE,EACI,CAAE,GAAEF,KAAWE,UAAkB,GAAEF,UAAkB,GAAEA,KAAWE,IAAWF,GAC7E,CAAE,GAAEA,UAAiBA,MAGzBL,EAAKmB,SACPC,QAAQC,KAAK,qBAAsBnB,GAGrC,IAAIoB,EAAU,CAAA,EACd,IAAK,MAAMjB,KAAWH,EACpBoB,EAAU,IAAKC,SAAO,CAAEC,KAAMA,EAAKC,KAAKxB,EAAKI,KAAYqB,UAAWJ,GAEtE,OAAOA,CACT,+CAKO,SAA8CA,GAE/CA,EAAQK,MAAQL,EAAQM,mBAC1BN,EAAQK,KAAOL,EAAQK,KAAKE,QAAS,GAAEP,EAAQM,oBAAqB,IAEjEE,WAAW,mCAAoC,IAE/CA,WAAW,sBAAuB,IAClCA,WAAW,iBAAkB,KAElC,IAAK,MAAMC,KAAOC,OAAOC,KAAKX,GAAU,CACtC,MAAMY,EAAWH,EAAII,eAEnBD,EAASE,WAAW,SACpBF,EAASE,WAAW,UACpBF,EAASE,WAAW,WACP,gBAAbF,GACa,aAAbA,WAEOZ,EAAQS,EAEnB,CACF,oCA/EyC,CACvC5B,IAAK,CACHkC,YAAa,2BACbC,KAAM,SAER,cAAe,CACbD,YACE,wLACFC,KAAM,UAER,mBAAoB,CAClBD,YACE,yHACFC,KAAM,WAER,mBAAoB,CAClBD,YACE,wGACFC,KAAM,UACNC,SAAS"}
package/dist/env.d.ts CHANGED
@@ -2,6 +2,7 @@ interface Options {
2
2
  env?: (string | number)[];
3
3
  cascadeEnv?: string;
4
4
  cascadeNodeEnv?: boolean;
5
+ autoCascadeEnv?: boolean;
5
6
  verbose?: boolean;
6
7
  }
7
8
  export declare const yargsOptionsBuilderForEnv: {
@@ -10,13 +11,18 @@ export declare const yargsOptionsBuilderForEnv: {
10
11
  readonly type: "array";
11
12
  };
12
13
  readonly 'cascade-env': {
13
- readonly description: "environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`)";
14
+ readonly description: "Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.";
14
15
  readonly type: "string";
15
16
  };
16
17
  readonly 'cascade-node-env': {
17
- readonly description: "environment to load cascading .env files (e.g., `.env`, `.env.<NODE_ENV>`, `.env.local` and `.env.<NODE_ENV>.local`). If NODE_ENV is falsy, \"development\" is applied. Preferred over `cascade`.";
18
+ readonly description: "Same with --cascade-env=<NODE_ENV>. If NODE_ENV is falsy, \"development\" is applied. Preferred over `auto-cascade-env`.";
18
19
  readonly type: "boolean";
19
20
  };
21
+ readonly 'auto-cascade-env': {
22
+ readonly description: "Same with --cascade-env=<WB_ENV || APP_ENV || NODE_ENV>. If they are falsy, \"development\" is applied.";
23
+ readonly type: "boolean";
24
+ readonly default: true;
25
+ };
20
26
  };
21
27
  /**
22
28
  * This function loads environment variables from `.env` files.
package/dist/env.js CHANGED
@@ -1,2 +1,2 @@
1
- import e from"node:path";import{config as n}from"dotenv";const o={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`)",type:"string"},"cascade-node-env":{description:'environment to load cascading .env files (e.g., `.env`, `.env.<NODE_ENV>`, `.env.local` and `.env.<NODE_ENV>.local`). If NODE_ENV is falsy, "development" is applied. Preferred over `cascade`.',type:"boolean"}};function t(o,t){let a=(o.env??[]).map((e=>e.toString()));const l=o.cascadeNodeEnv?process.env.NODE_ENV||"development":o.cascadeEnv;"string"==typeof l&&(0===a.length&&a.push(".env"),a=a.flatMap((e=>l?[`${e}.${l}.local`,`${e}.local`,`${e}.${l}`,e]:[`${e}.local`,e]))),o.verbose&&console.info("Loading env files:",a);let r={};for(const o of a)r={...n({path:e.join(t,o)}).parsed,...r};return r}function a(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const n of Object.keys(e)){const o=n.toUpperCase();(o.startsWith("NPM_")||o.startsWith("YARN_")||o.startsWith("BERRY_")||"PROJECT_CWD"===o||"INIT_CWD"===o)&&delete e[n]}}export{t as loadEnvironmentVariables,a as removeNpmAndYarnEnvironmentVariables,o as yargsOptionsBuilderForEnv};
1
+ import e from"node:path";import{config as n}from"dotenv";const a={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV>. If NODE_ENV is falsy, "development" is applied. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || APP_ENV || NODE_ENV>. If they are falsy, "development" is applied.',type:"boolean",default:!0}};function o(a,o){let t=(a.env??[]).map((e=>e.toString()));const s=a.cascadeEnv??(a.cascadeNodeEnv?process.env.NODE_ENV||"development":a.autoCascadeEnv?process.env.WB_ENV||process.env.APP_ENV||process.env.NODE_ENV||"development":void 0);"string"==typeof s&&(0===t.length&&t.push(".env"),t=t.flatMap((e=>s?[`${e}.${s}.local`,`${e}.local`,`${e}.${s}`,e]:[`${e}.local`,e]))),a.verbose&&console.info("Loading env files:",t);let c={};for(const a of t)c={...n({path:e.join(o,a)}).parsed,...c};return c}function t(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const n of Object.keys(e)){const a=n.toUpperCase();(a.startsWith("NPM_")||a.startsWith("YARN_")||a.startsWith("BERRY_")||"PROJECT_CWD"===a||"INIT_CWD"===a)&&delete e[n]}}export{o as loadEnvironmentVariables,t as removeNpmAndYarnEnvironmentVariables,a as yargsOptionsBuilderForEnv};
2
2
  //# sourceMappingURL=env.js.map
package/dist/env.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"env.js","sources":["../src/env.ts"],"sourcesContent":["import path from 'node:path';\n\nimport { config } from 'dotenv';\n\ninterface Options {\n env?: (string | number)[];\n cascadeEnv?: string;\n cascadeNodeEnv?: boolean;\n verbose?: boolean;\n}\n\nexport const yargsOptionsBuilderForEnv = {\n env: {\n description: '.env files to be loaded.',\n type: 'array',\n },\n 'cascade-env': {\n description:\n 'environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`)',\n type: 'string',\n },\n 'cascade-node-env': {\n description:\n 'environment to load cascading .env files (e.g., `.env`, `.env.<NODE_ENV>`, `.env.local` and `.env.<NODE_ENV>.local`). If NODE_ENV is falsy, \"development\" is applied. Preferred over `cascade`.',\n type: 'boolean',\n },\n} as const;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string> {\n let envPaths = (argv.env ?? []).map((envPath) => envPath.toString());\n const cascade = argv.cascadeNodeEnv ? process.env.NODE_ENV || 'development' : argv.cascadeEnv;\n if (typeof cascade === 'string') {\n if (envPaths.length === 0) envPaths.push('.env');\n envPaths = envPaths.flatMap((envPath) =>\n cascade\n ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n : [`${envPath}.local`, envPath]\n );\n }\n if (argv.verbose) {\n console.info('Loading env files:', envPaths);\n }\n\n let envVars = {};\n for (const envPath of envPaths) {\n envVars = { ...config({ path: path.join(cwd, envPath) }).parsed, ...envVars };\n }\n return envVars;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n // Remove npm & yarn environment variables from process.env\n if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n // Temporary directory in macOS\n .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n // Temporary directories in Linux\n .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n }\n for (const key of Object.keys(envVars)) {\n const upperKey = key.toUpperCase();\n if (\n upperKey.startsWith('NPM_') ||\n upperKey.startsWith('YARN_') ||\n upperKey.startsWith('BERRY_') ||\n upperKey === 'PROJECT_CWD' ||\n upperKey === 'INIT_CWD'\n ) {\n delete envVars[key];\n }\n }\n}\n"],"names":["yargsOptionsBuilderForEnv","env","description","type","loadEnvironmentVariables","argv","cwd","envPaths","map","envPath","toString","cascade","cascadeNodeEnv","process","NODE_ENV","cascadeEnv","length","push","flatMap","verbose","console","info","envVars","config","path","join","parsed","removeNpmAndYarnEnvironmentVariables","PATH","BERRY_BIN_FOLDER","replace","replaceAll","key","Object","keys","upperKey","toUpperCase","startsWith"],"mappings":"yDAWO,MAAMA,EAA4B,CACvCC,IAAK,CACHC,YAAa,2BACbC,KAAM,SAER,cAAe,CACbD,YACE,6HACFC,KAAM,UAER,mBAAoB,CAClBD,YACE,kMACFC,KAAM,YAOH,SAASC,EAAyBC,EAAeC,GACtD,IAAIC,GAAYF,EAAKJ,KAAO,IAAIO,KAAKC,GAAYA,EAAQC,aACzD,MAAMC,EAAUN,EAAKO,eAAiBC,QAAQZ,IAAIa,UAAY,cAAgBT,EAAKU,WAC5D,iBAAZJ,IACe,IAApBJ,EAASS,QAAcT,EAASU,KAAK,QACzCV,EAAWA,EAASW,SAAST,GAC3BE,EACI,CAAE,GAAEF,KAAWE,UAAkB,GAAEF,UAAkB,GAAEA,KAAWE,IAAWF,GAC7E,CAAE,GAAEA,UAAiBA,MAGzBJ,EAAKc,SACPC,QAAQC,KAAK,qBAAsBd,GAGrC,IAAIe,EAAU,CAAA,EACd,IAAK,MAAMb,KAAWF,EACpBe,EAAU,IAAKC,EAAO,CAAEC,KAAMA,EAAKC,KAAKnB,EAAKG,KAAYiB,UAAWJ,GAEtE,OAAOA,CACT,CAKO,SAASK,EAAqCL,GAE/CA,EAAQM,MAAQN,EAAQO,mBAC1BP,EAAQM,KAAON,EAAQM,KAAKE,QAAS,GAAER,EAAQO,oBAAqB,IAEjEE,WAAW,mCAAoC,IAE/CA,WAAW,sBAAuB,IAClCA,WAAW,iBAAkB,KAElC,IAAK,MAAMC,KAAOC,OAAOC,KAAKZ,GAAU,CACtC,MAAMa,EAAWH,EAAII,eAEnBD,EAASE,WAAW,SACpBF,EAASE,WAAW,UACpBF,EAASE,WAAW,WACP,gBAAbF,GACa,aAAbA,WAEOb,EAAQU,EAEnB,CACF"}
1
+ {"version":3,"file":"env.js","sources":["../src/env.ts"],"sourcesContent":["import path from 'node:path';\n\nimport { config } from 'dotenv';\n\ninterface Options {\n env?: (string | number)[];\n cascadeEnv?: string;\n cascadeNodeEnv?: boolean;\n autoCascadeEnv?: boolean;\n verbose?: boolean;\n}\n\nexport const yargsOptionsBuilderForEnv = {\n env: {\n description: '.env files to be loaded.',\n type: 'array',\n },\n 'cascade-env': {\n description:\n 'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n type: 'string',\n },\n 'cascade-node-env': {\n description:\n 'Same with --cascade-env=<NODE_ENV>. If NODE_ENV is falsy, \"development\" is applied. Preferred over `auto-cascade-env`.',\n type: 'boolean',\n },\n 'auto-cascade-env': {\n description:\n 'Same with --cascade-env=<WB_ENV || APP_ENV || NODE_ENV>. If they are falsy, \"development\" is applied.',\n type: 'boolean',\n default: true,\n },\n} as const;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string> {\n let envPaths = (argv.env ?? []).map((envPath) => envPath.toString());\n const cascade =\n argv.cascadeEnv ??\n (argv.cascadeNodeEnv\n ? process.env.NODE_ENV || 'development'\n : argv.autoCascadeEnv\n ? process.env.WB_ENV || process.env.APP_ENV || process.env.NODE_ENV || 'development'\n : undefined);\n if (typeof cascade === 'string') {\n if (envPaths.length === 0) envPaths.push('.env');\n envPaths = envPaths.flatMap((envPath) =>\n cascade\n ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n : [`${envPath}.local`, envPath]\n );\n }\n if (argv.verbose) {\n console.info('Loading env files:', envPaths);\n }\n\n let envVars = {};\n for (const envPath of envPaths) {\n envVars = { ...config({ path: path.join(cwd, envPath) }).parsed, ...envVars };\n }\n return envVars;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n // Remove npm & yarn environment variables from process.env\n if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n // Temporary directory in macOS\n .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n // Temporary directories in Linux\n .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n }\n for (const key of Object.keys(envVars)) {\n const upperKey = key.toUpperCase();\n if (\n upperKey.startsWith('NPM_') ||\n upperKey.startsWith('YARN_') ||\n upperKey.startsWith('BERRY_') ||\n upperKey === 'PROJECT_CWD' ||\n upperKey === 'INIT_CWD'\n ) {\n delete envVars[key];\n }\n }\n}\n"],"names":["yargsOptionsBuilderForEnv","env","description","type","default","loadEnvironmentVariables","argv","cwd","envPaths","map","envPath","toString","cascade","cascadeEnv","cascadeNodeEnv","process","NODE_ENV","autoCascadeEnv","WB_ENV","APP_ENV","undefined","length","push","flatMap","verbose","console","info","envVars","config","path","join","parsed","removeNpmAndYarnEnvironmentVariables","PATH","BERRY_BIN_FOLDER","replace","replaceAll","key","Object","keys","upperKey","toUpperCase","startsWith"],"mappings":"yDAYO,MAAMA,EAA4B,CACvCC,IAAK,CACHC,YAAa,2BACbC,KAAM,SAER,cAAe,CACbD,YACE,wLACFC,KAAM,UAER,mBAAoB,CAClBD,YACE,yHACFC,KAAM,WAER,mBAAoB,CAClBD,YACE,wGACFC,KAAM,UACNC,SAAS,IAON,SAASC,EAAyBC,EAAeC,GACtD,IAAIC,GAAYF,EAAKL,KAAO,IAAIQ,KAAKC,GAAYA,EAAQC,aACzD,MAAMC,EACJN,EAAKO,aACJP,EAAKQ,eACFC,QAAQd,IAAIe,UAAY,cACxBV,EAAKW,eACLF,QAAQd,IAAIiB,QAAUH,QAAQd,IAAIkB,SAAWJ,QAAQd,IAAIe,UAAY,mBACrEI,GACiB,iBAAZR,IACe,IAApBJ,EAASa,QAAcb,EAASc,KAAK,QACzCd,EAAWA,EAASe,SAASb,GAC3BE,EACI,CAAE,GAAEF,KAAWE,UAAkB,GAAEF,UAAkB,GAAEA,KAAWE,IAAWF,GAC7E,CAAE,GAAEA,UAAiBA,MAGzBJ,EAAKkB,SACPC,QAAQC,KAAK,qBAAsBlB,GAGrC,IAAImB,EAAU,CAAA,EACd,IAAK,MAAMjB,KAAWF,EACpBmB,EAAU,IAAKC,EAAO,CAAEC,KAAMA,EAAKC,KAAKvB,EAAKG,KAAYqB,UAAWJ,GAEtE,OAAOA,CACT,CAKO,SAASK,EAAqCL,GAE/CA,EAAQM,MAAQN,EAAQO,mBAC1BP,EAAQM,KAAON,EAAQM,KAAKE,QAAS,GAAER,EAAQO,oBAAqB,IAEjEE,WAAW,mCAAoC,IAE/CA,WAAW,sBAAuB,IAClCA,WAAW,iBAAkB,KAElC,IAAK,MAAMC,KAAOC,OAAOC,KAAKZ,GAAU,CACtC,MAAMa,EAAWH,EAAII,eAEnBD,EAASE,WAAW,SACpBF,EAASE,WAAW,UACpBF,EAASE,WAAW,WACP,gBAAbF,GACa,aAAbA,WAEOb,EAAQU,EAEnB,CACF"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@willbooster/shared-lib-node",
3
- "version": "2.8.5",
3
+ "version": "3.0.0",
4
4
  "license": "Apache-2.0",
5
5
  "author": "WillBooster Inc.",
6
6
  "sideEffects": false,
@@ -42,7 +42,7 @@
42
42
  "devDependencies": {
43
43
  "@types/eslint": "8.44.2",
44
44
  "@types/micromatch": "4.0.2",
45
- "@types/node": "18.17.15",
45
+ "@types/node": "18.17.16",
46
46
  "@typescript-eslint/eslint-plugin": "6.7.0",
47
47
  "@typescript-eslint/parser": "6.7.0",
48
48
  "@willbooster/eslint-config-ts": "10.5.0",