@willbooster/shared-lib-node 2.8.2 → 2.8.4
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.map +1 -0
- package/dist/{esm/env.d.ts → env.d.ts} +4 -4
- package/dist/env.js.map +1 -0
- package/dist/exists.cjs.map +1 -0
- package/dist/exists.d.ts +1 -0
- package/dist/exists.js.map +1 -0
- package/dist/hash.cjs.map +1 -0
- package/dist/{esm/hash.d.ts → hash.d.ts} +3 -4
- package/dist/hash.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/spawn.cjs.map +1 -0
- package/dist/spawn.d.ts +10 -0
- package/dist/spawn.js.map +1 -0
- package/package.json +14 -14
- package/dist/cjs/env.cjs.map +0 -1
- package/dist/cjs/env.d.cts +0 -29
- package/dist/cjs/exists.cjs.map +0 -1
- package/dist/cjs/exists.d.cts +0 -2
- package/dist/cjs/hash.cjs.map +0 -1
- package/dist/cjs/hash.d.cts +0 -22
- package/dist/cjs/index.d.cts +0 -4
- package/dist/cjs/spawn.cjs.map +0 -1
- package/dist/cjs/spawn.d.cts +0 -11
- package/dist/esm/env.js.map +0 -1
- package/dist/esm/exists.d.ts +0 -2
- package/dist/esm/exists.js.map +0 -1
- package/dist/esm/hash.js.map +0 -1
- package/dist/esm/index.d.ts +0 -4
- package/dist/esm/spawn.d.ts +0 -11
- package/dist/esm/spawn.js.map +0 -1
- /package/dist/{cjs/env.cjs → env.cjs} +0 -0
- /package/dist/{esm/env.js → env.js} +0 -0
- /package/dist/{cjs/exists.cjs → exists.cjs} +0 -0
- /package/dist/{esm/exists.js → exists.js} +0 -0
- /package/dist/{cjs/hash.cjs → hash.cjs} +0 -0
- /package/dist/{esm/hash.js → hash.js} +0 -0
- /package/dist/{cjs/index.cjs → index.cjs} +0 -0
- /package/dist/{cjs/index.cjs.map → index.cjs.map} +0 -0
- /package/dist/{esm/index.js → index.js} +0 -0
- /package/dist/{esm/index.js.map → index.js.map} +0 -0
- /package/dist/{cjs/spawn.cjs → spawn.cjs} +0 -0
- /package/dist/{esm/spawn.js → spawn.js} +0 -0
package/dist/env.cjs.map
ADDED
|
@@ -0,0 +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"}
|
|
@@ -4,7 +4,7 @@ interface Options {
|
|
|
4
4
|
cascadeNodeEnv?: boolean;
|
|
5
5
|
verbose?: boolean;
|
|
6
6
|
}
|
|
7
|
-
declare const yargsOptionsBuilderForEnv: {
|
|
7
|
+
export declare const yargsOptionsBuilderForEnv: {
|
|
8
8
|
readonly env: {
|
|
9
9
|
readonly description: ".env files to be loaded.";
|
|
10
10
|
readonly type: "array";
|
|
@@ -21,9 +21,9 @@ declare const yargsOptionsBuilderForEnv: {
|
|
|
21
21
|
/**
|
|
22
22
|
* This function loads environment variables from `.env` files.
|
|
23
23
|
* */
|
|
24
|
-
declare function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string>;
|
|
24
|
+
export declare function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string>;
|
|
25
25
|
/**
|
|
26
26
|
* This function removes environment variables related to npm and yarn from the given environment variables.
|
|
27
27
|
* */
|
|
28
|
-
declare function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void;
|
|
29
|
-
export {
|
|
28
|
+
export declare function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void;
|
|
29
|
+
export {};
|
package/dist/env.js.map
ADDED
|
@@ -0,0 +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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exists.cjs","sources":["../src/exists.ts"],"sourcesContent":["import fs from 'node:fs';\n\nexport function existsAsync(filePath: string): Promise<boolean> {\n return new Promise((resolve) => {\n fs.access(filePath, fs.constants.F_OK, (err) => {\n resolve(!err);\n });\n });\n}\n"],"names":["filePath","Promise","resolve","fs","access","constants","F_OK","err"],"mappings":"0DAEO,SAAqBA,GAC1B,OAAO,IAAIC,SAASC,IAClBC,EAAGC,OAAOJ,EAAUG,EAAGE,UAAUC,MAAOC,IACtCL,GAASK,EAAI,GACb,GAEN"}
|
package/dist/exists.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function existsAsync(filePath: string): Promise<boolean>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exists.js","sources":["../src/exists.ts"],"sourcesContent":["import fs from 'node:fs';\n\nexport function existsAsync(filePath: string): Promise<boolean> {\n return new Promise((resolve) => {\n fs.access(filePath, fs.constants.F_OK, (err) => {\n resolve(!err);\n });\n });\n}\n"],"names":["existsAsync","filePath","Promise","resolve","fs","access","constants","F_OK","err"],"mappings":"uBAEO,SAASA,EAAYC,GAC1B,OAAO,IAAIC,SAASC,IAClBC,EAAGC,OAAOJ,EAAUG,EAAGE,UAAUC,MAAOC,IACtCL,GAASK,EAAI,GACb,GAEN"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hash.cjs","sources":["../src/hash.ts"],"sourcesContent":["import crypto from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\n/**\n * Check whether seed command can be skipped or not and update hash file if needed.\n * Note that process.env.ALLOW_TO_SKIP_SEED should be set to '1' or 'true' to skip seed.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether seed command can be skipped.\n */\nexport async function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n if (process.env.ALLOW_TO_SKIP_SEED !== '1' && process.env.ALLOW_TO_SKIP_SEED !== 'true') return false;\n return !(await updateHashFromFiles(hashFilePath, ...paths));\n}\n\n/**\n * Update hash file if the hash is different from the current one.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether the hash file was updated.\n */\nexport async function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n let oldHash = '';\n try {\n oldHash = await fs.promises.readFile(hashFilePath, 'utf8');\n } catch {\n // do nothing\n }\n const newHash = await calculateHashFromFiles(...paths);\n if (oldHash === newHash) return false;\n\n await fs.promises.writeFile(hashFilePath, newHash, 'utf8');\n return true;\n}\n\n/**\n * Calculate hash from files.\n * @param paths Paths to the files or directories.\n * @returns Hash string.\n */\nexport async function calculateHashFromFiles(...paths: string[]): Promise<string> {\n const hash = crypto.createHash('sha512');\n for (const fileOrDirPath of paths.sort()) {\n const stat = await fs.promises.stat(fileOrDirPath);\n if (stat.isDirectory()) {\n // Get all files in the directory\n const dirents = await fs.promises.readdir(fileOrDirPath, { withFileTypes: true, recursive: true });\n for (const dirent of dirents.sort((d1, d2) => d1.name.localeCompare(d2.name))) {\n if (dirent.isFile()) {\n // Node.js 18.17.0 or later has `dirent.path`\n hash.update(\n await fs.promises.readFile(\n path.join((dirent as unknown as Record<'path', string>).path, dirent.name),\n 'utf8'\n )\n );\n }\n }\n } else if (stat.isFile()) {\n hash.update(await fs.promises.readFile(fileOrDirPath, 'utf8'));\n }\n }\n return hash.digest('hex');\n}\n"],"names":["async","updateHashFromFiles","hashFilePath","paths","oldHash","fs","promises","readFile","newHash","calculateHashFromFiles","writeFile","hash","crypto","createHash","fileOrDirPath","sort","stat","isDirectory","dirents","readdir","withFileTypes","recursive","dirent","d1","d2","name","localeCompare","isFile","update","path","join","digest","process","env","ALLOW_TO_SKIP_SEED"],"mappings":"sFAsBOA,eAAeC,EAAoBC,KAAyBC,GACjE,IAAIC,EAAU,GACd,IACEA,QAAgBC,EAAGC,SAASC,SAASL,EAAc,OACrD,CAAE,MACA,CAEF,MAAMM,QAAgBC,KAA0BN,GAChD,OAAIC,IAAYI,UAEVH,EAAGC,SAASI,UAAUR,EAAcM,EAAS,SAC5C,EACT,CAOOR,eAAeS,KAA0BN,GAC9C,MAAMQ,EAAOC,EAAOC,WAAW,UAC/B,IAAK,MAAMC,KAAiBX,EAAMY,OAAQ,CACxC,MAAMC,QAAaX,EAAGC,SAASU,KAAKF,GACpC,GAAIE,EAAKC,cAAe,CAEtB,MAAMC,QAAgBb,EAAGC,SAASa,QAAQL,EAAe,CAAEM,eAAe,EAAMC,WAAW,IAC3F,IAAK,MAAMC,KAAUJ,EAAQH,MAAK,CAACQ,EAAIC,IAAOD,EAAGE,KAAKC,cAAcF,EAAGC,QACjEH,EAAOK,UAEThB,EAAKiB,aACGvB,EAAGC,SAASC,SAChBsB,EAAKC,KAAMR,EAA6CO,KAAMP,EAAOG,MACrE,QAKV,MAAWT,EAAKW,UACdhB,EAAKiB,aAAavB,EAAGC,SAASC,SAASO,EAAe,QAE1D,CACA,OAAOH,EAAKoB,OAAO,MACrB,sDArDO/B,eAA2BE,KAAyBC,GACzD,OAAuC,MAAnC6B,QAAQC,IAAIC,oBAAiE,SAAnCF,QAAQC,IAAIC,4BAC3CjC,EAAoBC,KAAiBC,EACtD"}
|
|
@@ -5,18 +5,17 @@
|
|
|
5
5
|
* @param paths Paths to the files or directories.
|
|
6
6
|
* @returns Whether seed command can be skipped.
|
|
7
7
|
*/
|
|
8
|
-
declare function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
8
|
+
export declare function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
9
9
|
/**
|
|
10
10
|
* Update hash file if the hash is different from the current one.
|
|
11
11
|
* @param hashFilePath Path to the hash file.
|
|
12
12
|
* @param paths Paths to the files or directories.
|
|
13
13
|
* @returns Whether the hash file was updated.
|
|
14
14
|
*/
|
|
15
|
-
declare function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
15
|
+
export declare function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
16
16
|
/**
|
|
17
17
|
* Calculate hash from files.
|
|
18
18
|
* @param paths Paths to the files or directories.
|
|
19
19
|
* @returns Hash string.
|
|
20
20
|
*/
|
|
21
|
-
declare function calculateHashFromFiles(...paths: string[]): Promise<string>;
|
|
22
|
-
export { canSkipSeed, updateHashFromFiles, calculateHashFromFiles };
|
|
21
|
+
export declare function calculateHashFromFiles(...paths: string[]): Promise<string>;
|
package/dist/hash.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hash.js","sources":["../src/hash.ts"],"sourcesContent":["import crypto from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\n/**\n * Check whether seed command can be skipped or not and update hash file if needed.\n * Note that process.env.ALLOW_TO_SKIP_SEED should be set to '1' or 'true' to skip seed.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether seed command can be skipped.\n */\nexport async function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n if (process.env.ALLOW_TO_SKIP_SEED !== '1' && process.env.ALLOW_TO_SKIP_SEED !== 'true') return false;\n return !(await updateHashFromFiles(hashFilePath, ...paths));\n}\n\n/**\n * Update hash file if the hash is different from the current one.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether the hash file was updated.\n */\nexport async function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n let oldHash = '';\n try {\n oldHash = await fs.promises.readFile(hashFilePath, 'utf8');\n } catch {\n // do nothing\n }\n const newHash = await calculateHashFromFiles(...paths);\n if (oldHash === newHash) return false;\n\n await fs.promises.writeFile(hashFilePath, newHash, 'utf8');\n return true;\n}\n\n/**\n * Calculate hash from files.\n * @param paths Paths to the files or directories.\n * @returns Hash string.\n */\nexport async function calculateHashFromFiles(...paths: string[]): Promise<string> {\n const hash = crypto.createHash('sha512');\n for (const fileOrDirPath of paths.sort()) {\n const stat = await fs.promises.stat(fileOrDirPath);\n if (stat.isDirectory()) {\n // Get all files in the directory\n const dirents = await fs.promises.readdir(fileOrDirPath, { withFileTypes: true, recursive: true });\n for (const dirent of dirents.sort((d1, d2) => d1.name.localeCompare(d2.name))) {\n if (dirent.isFile()) {\n // Node.js 18.17.0 or later has `dirent.path`\n hash.update(\n await fs.promises.readFile(\n path.join((dirent as unknown as Record<'path', string>).path, dirent.name),\n 'utf8'\n )\n );\n }\n }\n } else if (stat.isFile()) {\n hash.update(await fs.promises.readFile(fileOrDirPath, 'utf8'));\n }\n }\n return hash.digest('hex');\n}\n"],"names":["async","canSkipSeed","hashFilePath","paths","process","env","ALLOW_TO_SKIP_SEED","updateHashFromFiles","oldHash","fs","promises","readFile","newHash","calculateHashFromFiles","writeFile","hash","crypto","createHash","fileOrDirPath","sort","stat","isDirectory","dirents","readdir","withFileTypes","recursive","dirent","d1","d2","name","localeCompare","isFile","update","path","join","digest"],"mappings":"2EAWOA,eAAeC,EAAYC,KAAyBC,GACzD,OAAuC,MAAnCC,QAAQC,IAAIC,oBAAiE,SAAnCF,QAAQC,IAAIC,4BAC3CC,EAAoBL,KAAiBC,EACtD,CAQOH,eAAeO,EAAoBL,KAAyBC,GACjE,IAAIK,EAAU,GACd,IACEA,QAAgBC,EAAGC,SAASC,SAAST,EAAc,OACrD,CAAE,MACA,CAEF,MAAMU,QAAgBC,KAA0BV,GAChD,OAAIK,IAAYI,UAEVH,EAAGC,SAASI,UAAUZ,EAAcU,EAAS,SAC5C,EACT,CAOOZ,eAAea,KAA0BV,GAC9C,MAAMY,EAAOC,EAAOC,WAAW,UAC/B,IAAK,MAAMC,KAAiBf,EAAMgB,OAAQ,CACxC,MAAMC,QAAaX,EAAGC,SAASU,KAAKF,GACpC,GAAIE,EAAKC,cAAe,CAEtB,MAAMC,QAAgBb,EAAGC,SAASa,QAAQL,EAAe,CAAEM,eAAe,EAAMC,WAAW,IAC3F,IAAK,MAAMC,KAAUJ,EAAQH,MAAK,CAACQ,EAAIC,IAAOD,EAAGE,KAAKC,cAAcF,EAAGC,QACjEH,EAAOK,UAEThB,EAAKiB,aACGvB,EAAGC,SAASC,SAChBsB,EAAKC,KAAMR,EAA6CO,KAAMP,EAAOG,MACrE,QAKV,MAAWT,EAAKW,UACdhB,EAAKiB,aAAavB,EAAGC,SAASC,SAASO,EAAe,QAE1D,CACA,OAAOH,EAAKoB,OAAO,MACrB"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { loadEnvironmentVariables, removeNpmAndYarnEnvironmentVariables, yargsOptionsBuilderForEnv } from './env.js';
|
|
2
|
+
export { existsAsync } from './exists.js';
|
|
3
|
+
export { calculateHashFromFiles, canSkipSeed, updateHashFromFiles } from './hash.js';
|
|
4
|
+
export { spawnAsync } from './spawn.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spawn.cjs","sources":["../src/spawn.ts"],"sourcesContent":["import type {\n SpawnOptions,\n SpawnOptionsWithoutStdio,\n SpawnOptionsWithStdioTuple,\n SpawnSyncReturns,\n StdioNull,\n StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\nexport type SpawnAsyncOptions = (\n | SpawnOptionsWithoutStdio\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n | SpawnOptions\n) & {\n input?: string;\n mergeOutAndError?: boolean;\n killOnExit?: boolean;\n verbose?: boolean;\n};\n\nexport async function spawnAsync(\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n return new Promise((resolve, reject) => {\n try {\n const proc = spawn(command, args ?? [], options ?? {});\n let stdout = '';\n let stderr = '';\n\n if (options?.input) {\n proc.stdin?.write(options.input);\n proc.stdin?.end();\n }\n proc.stdout?.on('data', (data) => {\n stdout += data;\n });\n proc.stderr?.on('data', (data) => {\n if (options?.mergeOutAndError) {\n stdout += data;\n } else {\n stderr += data;\n }\n });\n\n let stopped = false;\n const stopProcess = (): void => {\n if (stopped || !proc.pid) return;\n\n stopped = true;\n if (options?.verbose) {\n console.info(`treeKill(${proc.pid})`);\n }\n treeKill(proc.pid);\n };\n if (options?.killOnExit) {\n process.on('beforeExit', stopProcess);\n process.on('SIGINT', stopProcess);\n }\n\n proc.on('error', (error) => {\n process.removeListener('exit', stopProcess);\n proc.removeAllListeners('close');\n reject(error);\n });\n proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n process.removeListener('exit', stopProcess);\n if (proc.pid === undefined) {\n reject(new Error('Process has no pid.'));\n } else {\n resolve({\n pid: proc.pid,\n stdout,\n stderr,\n status: code,\n signal,\n });\n }\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"names":["async","command","args","options","Promise","resolve","reject","proc","spawn","stdout","stderr","input","stdin","write","end","on","data","mergeOutAndError","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","process","error","removeListener","removeAllListeners","code","signal","undefined","Error","status"],"mappings":"2FAgCOA,eACLC,EACAC,EACAC,GAEA,OAAO,IAAIC,SAAQ,CAACC,EAASC,KAC3B,IACE,MAAMC,EAAOC,EAAAA,MAAMP,EAASC,GAAQ,GAAIC,GAAW,CAAA,GACnD,IAAIM,EAAS,GACTC,EAAS,GAETP,GAASQ,QACXJ,EAAKK,OAAOC,MAAMV,EAAQQ,OAC1BJ,EAAKK,OAAOE,OAEdP,EAAKE,QAAQM,GAAG,QAASC,IACvBP,GAAUO,CAAI,IAEhBT,EAAKG,QAAQK,GAAG,QAASC,IACnBb,GAASc,iBACXR,GAAUO,EAEVN,GAAUM,CACZ,IAGF,IAAIE,GAAU,EACd,MAAMC,EAAcA,MACdD,GAAYX,EAAKa,MAErBF,GAAU,EACNf,GAASkB,SACXC,QAAQC,KAAM,YAAWhB,EAAKa,QAEhCI,EAASjB,EAAKa,KAAI,EAEhBjB,GAASsB,aACXC,QAAQX,GAAG,aAAcI,GACzBO,QAAQX,GAAG,SAAUI,IAGvBZ,EAAKQ,GAAG,SAAUY,IAChBD,QAAQE,eAAe,OAAQT,GAC/BZ,EAAKsB,mBAAmB,SACxBvB,EAAOqB,EAAM,IAEfpB,EAAKQ,GAAG,SAAS,CAACe,EAAqBC,KACrCL,QAAQE,eAAe,OAAQT,QACda,IAAbzB,EAAKa,IACPd,EAAO,IAAI2B,MAAM,wBAEjB5B,EAAQ,CACNe,IAAKb,EAAKa,IACVX,SACAC,SACAwB,OAAQJ,EACRC,UAEJ,GAEH,CAAC,MAAOJ,GACPrB,EAAOqB,EACT,IAEJ"}
|
package/dist/spawn.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
import type { SpawnOptions, SpawnOptionsWithoutStdio, SpawnOptionsWithStdioTuple, SpawnSyncReturns, StdioNull, StdioPipe } from 'node:child_process';
|
|
3
|
+
export type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;
|
|
4
|
+
export type SpawnAsyncOptions = (SpawnOptionsWithoutStdio | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull> | SpawnOptions) & {
|
|
5
|
+
input?: string;
|
|
6
|
+
mergeOutAndError?: boolean;
|
|
7
|
+
killOnExit?: boolean;
|
|
8
|
+
verbose?: boolean;
|
|
9
|
+
};
|
|
10
|
+
export declare function spawnAsync(command: string, args?: ReadonlyArray<string>, options?: SpawnAsyncOptions): Promise<SpawnAsyncReturns>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spawn.js","sources":["../src/spawn.ts"],"sourcesContent":["import type {\n SpawnOptions,\n SpawnOptionsWithoutStdio,\n SpawnOptionsWithStdioTuple,\n SpawnSyncReturns,\n StdioNull,\n StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\nexport type SpawnAsyncOptions = (\n | SpawnOptionsWithoutStdio\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n | SpawnOptions\n) & {\n input?: string;\n mergeOutAndError?: boolean;\n killOnExit?: boolean;\n verbose?: boolean;\n};\n\nexport async function spawnAsync(\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n return new Promise((resolve, reject) => {\n try {\n const proc = spawn(command, args ?? [], options ?? {});\n let stdout = '';\n let stderr = '';\n\n if (options?.input) {\n proc.stdin?.write(options.input);\n proc.stdin?.end();\n }\n proc.stdout?.on('data', (data) => {\n stdout += data;\n });\n proc.stderr?.on('data', (data) => {\n if (options?.mergeOutAndError) {\n stdout += data;\n } else {\n stderr += data;\n }\n });\n\n let stopped = false;\n const stopProcess = (): void => {\n if (stopped || !proc.pid) return;\n\n stopped = true;\n if (options?.verbose) {\n console.info(`treeKill(${proc.pid})`);\n }\n treeKill(proc.pid);\n };\n if (options?.killOnExit) {\n process.on('beforeExit', stopProcess);\n process.on('SIGINT', stopProcess);\n }\n\n proc.on('error', (error) => {\n process.removeListener('exit', stopProcess);\n proc.removeAllListeners('close');\n reject(error);\n });\n proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n process.removeListener('exit', stopProcess);\n if (proc.pid === undefined) {\n reject(new Error('Process has no pid.'));\n } else {\n resolve({\n pid: proc.pid,\n stdout,\n stderr,\n status: code,\n signal,\n });\n }\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"names":["async","spawnAsync","command","args","options","Promise","resolve","reject","proc","spawn","stdout","stderr","input","stdin","write","end","on","data","mergeOutAndError","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","process","error","removeListener","removeAllListeners","code","signal","undefined","Error","status"],"mappings":"oEAgCOA,eAAeC,EACpBC,EACAC,EACAC,GAEA,OAAO,IAAIC,SAAQ,CAACC,EAASC,KAC3B,IACE,MAAMC,EAAOC,EAAMP,EAASC,GAAQ,GAAIC,GAAW,CAAA,GACnD,IAAIM,EAAS,GACTC,EAAS,GAETP,GAASQ,QACXJ,EAAKK,OAAOC,MAAMV,EAAQQ,OAC1BJ,EAAKK,OAAOE,OAEdP,EAAKE,QAAQM,GAAG,QAASC,IACvBP,GAAUO,CAAI,IAEhBT,EAAKG,QAAQK,GAAG,QAASC,IACnBb,GAASc,iBACXR,GAAUO,EAEVN,GAAUM,CACZ,IAGF,IAAIE,GAAU,EACd,MAAMC,EAAcA,MACdD,GAAYX,EAAKa,MAErBF,GAAU,EACNf,GAASkB,SACXC,QAAQC,KAAM,YAAWhB,EAAKa,QAEhCI,EAASjB,EAAKa,KAAI,EAEhBjB,GAASsB,aACXC,QAAQX,GAAG,aAAcI,GACzBO,QAAQX,GAAG,SAAUI,IAGvBZ,EAAKQ,GAAG,SAAUY,IAChBD,QAAQE,eAAe,OAAQT,GAC/BZ,EAAKsB,mBAAmB,SACxBvB,EAAOqB,EAAM,IAEfpB,EAAKQ,GAAG,SAAS,CAACe,EAAqBC,KACrCL,QAAQE,eAAe,OAAQT,QACda,IAAbzB,EAAKa,IACPd,EAAO,IAAI2B,MAAM,wBAEjB5B,EAAQ,CACNe,IAAKb,EAAKa,IACVX,SACAC,SACAwB,OAAQJ,EACRC,UAEJ,GAEH,CAAC,MAAOJ,GACPrB,EAAOqB,EACT,IAEJ"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@willbooster/shared-lib-node",
|
|
3
|
-
"version": "2.8.
|
|
3
|
+
"version": "2.8.4",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"author": "WillBooster Inc.",
|
|
6
6
|
"sideEffects": false,
|
|
@@ -8,8 +8,8 @@
|
|
|
8
8
|
"exports": {
|
|
9
9
|
".": {
|
|
10
10
|
"require": "./dist/cjs/index.cjs",
|
|
11
|
-
"import": "./dist/
|
|
12
|
-
"types": "./dist/
|
|
11
|
+
"import": "./dist/index.js",
|
|
12
|
+
"types": "./dist/index.d.ts"
|
|
13
13
|
},
|
|
14
14
|
"./src": {
|
|
15
15
|
"require": "./src/index.ts",
|
|
@@ -18,8 +18,8 @@
|
|
|
18
18
|
}
|
|
19
19
|
},
|
|
20
20
|
"main": "dist/cjs/index.cjs",
|
|
21
|
-
"module": "dist/
|
|
22
|
-
"types": "dist/
|
|
21
|
+
"module": "dist/index.js",
|
|
22
|
+
"types": "dist/index.d.ts",
|
|
23
23
|
"files": [
|
|
24
24
|
"bin/",
|
|
25
25
|
"dist/"
|
|
@@ -42,13 +42,13 @@
|
|
|
42
42
|
"devDependencies": {
|
|
43
43
|
"@types/eslint": "8.44.2",
|
|
44
44
|
"@types/micromatch": "4.0.2",
|
|
45
|
-
"@types/node": "18.17.
|
|
46
|
-
"@typescript-eslint/eslint-plugin": "6.
|
|
47
|
-
"@typescript-eslint/parser": "6.
|
|
48
|
-
"@willbooster/eslint-config-ts": "10.
|
|
45
|
+
"@types/node": "18.17.12",
|
|
46
|
+
"@typescript-eslint/eslint-plugin": "6.7.0",
|
|
47
|
+
"@typescript-eslint/parser": "6.7.0",
|
|
48
|
+
"@willbooster/eslint-config-ts": "10.5.0",
|
|
49
49
|
"@willbooster/prettier-config": "9.1.1",
|
|
50
|
-
"build-ts": "
|
|
51
|
-
"eslint": "8.
|
|
50
|
+
"build-ts": "9.1.4",
|
|
51
|
+
"eslint": "8.49.0",
|
|
52
52
|
"eslint-config-prettier": "9.0.0",
|
|
53
53
|
"eslint-import-resolver-typescript": "3.6.0",
|
|
54
54
|
"eslint-plugin-import": "2.28.1",
|
|
@@ -57,10 +57,10 @@
|
|
|
57
57
|
"eslint-plugin-unicorn": "48.0.1",
|
|
58
58
|
"lint-staged": "14.0.1",
|
|
59
59
|
"micromatch": "4.0.5",
|
|
60
|
-
"prettier": "3.0.
|
|
60
|
+
"prettier": "3.0.3",
|
|
61
61
|
"sort-package-json": "2.5.1",
|
|
62
|
-
"typescript": "5.
|
|
63
|
-
"vitest": "0.34.
|
|
62
|
+
"typescript": "5.2.2",
|
|
63
|
+
"vitest": "0.34.4"
|
|
64
64
|
},
|
|
65
65
|
"publishConfig": {
|
|
66
66
|
"access": "public"
|
package/dist/cjs/env.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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"}
|
package/dist/cjs/env.d.cts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
interface Options {
|
|
2
|
-
env?: (string | number)[];
|
|
3
|
-
cascadeEnv?: string;
|
|
4
|
-
cascadeNodeEnv?: boolean;
|
|
5
|
-
verbose?: boolean;
|
|
6
|
-
}
|
|
7
|
-
declare const yargsOptionsBuilderForEnv: {
|
|
8
|
-
readonly env: {
|
|
9
|
-
readonly description: ".env files to be loaded.";
|
|
10
|
-
readonly type: "array";
|
|
11
|
-
};
|
|
12
|
-
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 type: "string";
|
|
15
|
-
};
|
|
16
|
-
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 type: "boolean";
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
/**
|
|
22
|
-
* This function loads environment variables from `.env` files.
|
|
23
|
-
* */
|
|
24
|
-
declare function loadEnvironmentVariables(argv: Options, cwd: string): Record<string, string>;
|
|
25
|
-
/**
|
|
26
|
-
* This function removes environment variables related to npm and yarn from the given environment variables.
|
|
27
|
-
* */
|
|
28
|
-
declare function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void;
|
|
29
|
-
export { yargsOptionsBuilderForEnv, loadEnvironmentVariables, removeNpmAndYarnEnvironmentVariables };
|
package/dist/cjs/exists.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"exists.cjs","sources":["../../src/exists.ts"],"sourcesContent":["import fs from 'node:fs';\n\nexport function existsAsync(filePath: string): Promise<boolean> {\n return new Promise((resolve) => {\n fs.access(filePath, fs.constants.F_OK, (err) => {\n resolve(!err);\n });\n });\n}\n"],"names":["filePath","Promise","resolve","fs","access","constants","F_OK","err"],"mappings":"0DAEO,SAAqBA,GAC1B,OAAO,IAAIC,SAASC,IAClBC,EAAGC,OAAOJ,EAAUG,EAAGE,UAAUC,MAAOC,IACtCL,GAASK,EAAI,GACb,GAEN"}
|
package/dist/cjs/exists.d.cts
DELETED
package/dist/cjs/hash.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hash.cjs","sources":["../../src/hash.ts"],"sourcesContent":["import crypto from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\n/**\n * Check whether seed command can be skipped or not and update hash file if needed.\n * Note that process.env.ALLOW_TO_SKIP_SEED should be set to '1' or 'true' to skip seed.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether seed command can be skipped.\n */\nexport async function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n if (process.env.ALLOW_TO_SKIP_SEED !== '1' && process.env.ALLOW_TO_SKIP_SEED !== 'true') return false;\n return !(await updateHashFromFiles(hashFilePath, ...paths));\n}\n\n/**\n * Update hash file if the hash is different from the current one.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether the hash file was updated.\n */\nexport async function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n let oldHash = '';\n try {\n oldHash = await fs.promises.readFile(hashFilePath, 'utf8');\n } catch {\n // do nothing\n }\n const newHash = await calculateHashFromFiles(...paths);\n if (oldHash === newHash) return false;\n\n await fs.promises.writeFile(hashFilePath, newHash, 'utf8');\n return true;\n}\n\n/**\n * Calculate hash from files.\n * @param paths Paths to the files or directories.\n * @returns Hash string.\n */\nexport async function calculateHashFromFiles(...paths: string[]): Promise<string> {\n const hash = crypto.createHash('sha512');\n for (const fileOrDirPath of paths.sort()) {\n const stat = await fs.promises.stat(fileOrDirPath);\n if (stat.isDirectory()) {\n // Get all files in the directory\n const dirents = await fs.promises.readdir(fileOrDirPath, { withFileTypes: true, recursive: true });\n for (const dirent of dirents.sort((d1, d2) => d1.name.localeCompare(d2.name))) {\n if (dirent.isFile()) {\n // Node.js 18.17.0 or later has `dirent.path`\n hash.update(\n await fs.promises.readFile(\n path.join((dirent as unknown as Record<'path', string>).path, dirent.name),\n 'utf8'\n )\n );\n }\n }\n } else if (stat.isFile()) {\n hash.update(await fs.promises.readFile(fileOrDirPath, 'utf8'));\n }\n }\n return hash.digest('hex');\n}\n"],"names":["async","updateHashFromFiles","hashFilePath","paths","oldHash","fs","promises","readFile","newHash","calculateHashFromFiles","writeFile","hash","crypto","createHash","fileOrDirPath","sort","stat","isDirectory","dirents","readdir","withFileTypes","recursive","dirent","d1","d2","name","localeCompare","isFile","update","path","join","digest","process","env","ALLOW_TO_SKIP_SEED"],"mappings":"sFAsBOA,eAAeC,EAAoBC,KAAyBC,GACjE,IAAIC,EAAU,GACd,IACEA,QAAgBC,EAAGC,SAASC,SAASL,EAAc,OACrD,CAAE,MACA,CAEF,MAAMM,QAAgBC,KAA0BN,GAChD,OAAIC,IAAYI,UAEVH,EAAGC,SAASI,UAAUR,EAAcM,EAAS,SAC5C,EACT,CAOOR,eAAeS,KAA0BN,GAC9C,MAAMQ,EAAOC,EAAOC,WAAW,UAC/B,IAAK,MAAMC,KAAiBX,EAAMY,OAAQ,CACxC,MAAMC,QAAaX,EAAGC,SAASU,KAAKF,GACpC,GAAIE,EAAKC,cAAe,CAEtB,MAAMC,QAAgBb,EAAGC,SAASa,QAAQL,EAAe,CAAEM,eAAe,EAAMC,WAAW,IAC3F,IAAK,MAAMC,KAAUJ,EAAQH,MAAK,CAACQ,EAAIC,IAAOD,EAAGE,KAAKC,cAAcF,EAAGC,QACjEH,EAAOK,UAEThB,EAAKiB,aACGvB,EAAGC,SAASC,SAChBsB,EAAKC,KAAMR,EAA6CO,KAAMP,EAAOG,MACrE,QAKV,MAAWT,EAAKW,UACdhB,EAAKiB,aAAavB,EAAGC,SAASC,SAASO,EAAe,QAE1D,CACA,OAAOH,EAAKoB,OAAO,MACrB,sDArDO/B,eAA2BE,KAAyBC,GACzD,OAAuC,MAAnC6B,QAAQC,IAAIC,oBAAiE,SAAnCF,QAAQC,IAAIC,4BAC3CjC,EAAoBC,KAAiBC,EACtD"}
|
package/dist/cjs/hash.d.cts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Check whether seed command can be skipped or not and update hash file if needed.
|
|
3
|
-
* Note that process.env.ALLOW_TO_SKIP_SEED should be set to '1' or 'true' to skip seed.
|
|
4
|
-
* @param hashFilePath Path to the hash file.
|
|
5
|
-
* @param paths Paths to the files or directories.
|
|
6
|
-
* @returns Whether seed command can be skipped.
|
|
7
|
-
*/
|
|
8
|
-
declare function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
9
|
-
/**
|
|
10
|
-
* Update hash file if the hash is different from the current one.
|
|
11
|
-
* @param hashFilePath Path to the hash file.
|
|
12
|
-
* @param paths Paths to the files or directories.
|
|
13
|
-
* @returns Whether the hash file was updated.
|
|
14
|
-
*/
|
|
15
|
-
declare function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean>;
|
|
16
|
-
/**
|
|
17
|
-
* Calculate hash from files.
|
|
18
|
-
* @param paths Paths to the files or directories.
|
|
19
|
-
* @returns Hash string.
|
|
20
|
-
*/
|
|
21
|
-
declare function calculateHashFromFiles(...paths: string[]): Promise<string>;
|
|
22
|
-
export { canSkipSeed, updateHashFromFiles, calculateHashFromFiles };
|
package/dist/cjs/index.d.cts
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
export { loadEnvironmentVariables, removeNpmAndYarnEnvironmentVariables, yargsOptionsBuilderForEnv } from "./env.js";
|
|
2
|
-
export { existsAsync } from "./exists.js";
|
|
3
|
-
export { calculateHashFromFiles, canSkipSeed, updateHashFromFiles } from "./hash.js";
|
|
4
|
-
export { spawnAsync } from "./spawn.js";
|
package/dist/cjs/spawn.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.cjs","sources":["../../src/spawn.ts"],"sourcesContent":["import type {\n SpawnOptions,\n SpawnOptionsWithoutStdio,\n SpawnOptionsWithStdioTuple,\n SpawnSyncReturns,\n StdioNull,\n StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\nexport type SpawnAsyncOptions = (\n | SpawnOptionsWithoutStdio\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n | SpawnOptions\n) & {\n input?: string;\n mergeOutAndError?: boolean;\n killOnExit?: boolean;\n verbose?: boolean;\n};\n\nexport async function spawnAsync(\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n return new Promise((resolve, reject) => {\n try {\n const proc = spawn(command, args ?? [], options ?? {});\n let stdout = '';\n let stderr = '';\n\n if (options?.input) {\n proc.stdin?.write(options.input);\n proc.stdin?.end();\n }\n proc.stdout?.on('data', (data) => {\n stdout += data;\n });\n proc.stderr?.on('data', (data) => {\n if (options?.mergeOutAndError) {\n stdout += data;\n } else {\n stderr += data;\n }\n });\n\n let stopped = false;\n const stopProcess = (): void => {\n if (stopped || !proc.pid) return;\n\n stopped = true;\n if (options?.verbose) {\n console.info(`treeKill(${proc.pid})`);\n }\n treeKill(proc.pid);\n };\n if (options?.killOnExit) {\n process.on('beforeExit', stopProcess);\n process.on('SIGINT', stopProcess);\n }\n\n proc.on('error', (error) => {\n process.removeListener('exit', stopProcess);\n proc.removeAllListeners('close');\n reject(error);\n });\n proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n process.removeListener('exit', stopProcess);\n if (proc.pid === undefined) {\n reject(new Error('Process has no pid.'));\n } else {\n resolve({\n pid: proc.pid,\n stdout,\n stderr,\n status: code,\n signal,\n });\n }\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"names":["async","command","args","options","Promise","resolve","reject","proc","spawn","stdout","stderr","input","stdin","write","end","on","data","mergeOutAndError","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","process","error","removeListener","removeAllListeners","code","signal","undefined","Error","status"],"mappings":"2FAgCOA,eACLC,EACAC,EACAC,GAEA,OAAO,IAAIC,SAAQ,CAACC,EAASC,KAC3B,IACE,MAAMC,EAAOC,EAAAA,MAAMP,EAASC,GAAQ,GAAIC,GAAW,CAAA,GACnD,IAAIM,EAAS,GACTC,EAAS,GAETP,GAASQ,QACXJ,EAAKK,OAAOC,MAAMV,EAAQQ,OAC1BJ,EAAKK,OAAOE,OAEdP,EAAKE,QAAQM,GAAG,QAASC,IACvBP,GAAUO,CAAI,IAEhBT,EAAKG,QAAQK,GAAG,QAASC,IACnBb,GAASc,iBACXR,GAAUO,EAEVN,GAAUM,CACZ,IAGF,IAAIE,GAAU,EACd,MAAMC,EAAcA,MACdD,GAAYX,EAAKa,MAErBF,GAAU,EACNf,GAASkB,SACXC,QAAQC,KAAM,YAAWhB,EAAKa,QAEhCI,EAASjB,EAAKa,KAAI,EAEhBjB,GAASsB,aACXC,QAAQX,GAAG,aAAcI,GACzBO,QAAQX,GAAG,SAAUI,IAGvBZ,EAAKQ,GAAG,SAAUY,IAChBD,QAAQE,eAAe,OAAQT,GAC/BZ,EAAKsB,mBAAmB,SACxBvB,EAAOqB,EAAM,IAEfpB,EAAKQ,GAAG,SAAS,CAACe,EAAqBC,KACrCL,QAAQE,eAAe,OAAQT,QACda,IAAbzB,EAAKa,IACPd,EAAO,IAAI2B,MAAM,wBAEjB5B,EAAQ,CACNe,IAAKb,EAAKa,IACVX,SACAC,SACAwB,OAAQJ,EACRC,UAEJ,GAEH,CAAC,MAAOJ,GACPrB,EAAOqB,EACT,IAEJ"}
|
package/dist/cjs/spawn.d.cts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { SpawnOptions, SpawnOptionsWithoutStdio, SpawnOptionsWithStdioTuple, SpawnSyncReturns, StdioNull, StdioPipe } from 'node:child_process';
|
|
3
|
-
type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;
|
|
4
|
-
type SpawnAsyncOptions = (SpawnOptionsWithoutStdio | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull> | SpawnOptions) & {
|
|
5
|
-
input?: string;
|
|
6
|
-
mergeOutAndError?: boolean;
|
|
7
|
-
killOnExit?: boolean;
|
|
8
|
-
verbose?: boolean;
|
|
9
|
-
};
|
|
10
|
-
declare function spawnAsync(command: string, args?: ReadonlyArray<string>, options?: SpawnAsyncOptions): Promise<SpawnAsyncReturns>;
|
|
11
|
-
export { SpawnAsyncReturns, SpawnAsyncOptions, spawnAsync };
|
package/dist/esm/env.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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"}
|
package/dist/esm/exists.d.ts
DELETED
package/dist/esm/exists.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"exists.js","sources":["../../src/exists.ts"],"sourcesContent":["import fs from 'node:fs';\n\nexport function existsAsync(filePath: string): Promise<boolean> {\n return new Promise((resolve) => {\n fs.access(filePath, fs.constants.F_OK, (err) => {\n resolve(!err);\n });\n });\n}\n"],"names":["existsAsync","filePath","Promise","resolve","fs","access","constants","F_OK","err"],"mappings":"uBAEO,SAASA,EAAYC,GAC1B,OAAO,IAAIC,SAASC,IAClBC,EAAGC,OAAOJ,EAAUG,EAAGE,UAAUC,MAAOC,IACtCL,GAASK,EAAI,GACb,GAEN"}
|
package/dist/esm/hash.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hash.js","sources":["../../src/hash.ts"],"sourcesContent":["import crypto from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\n/**\n * Check whether seed command can be skipped or not and update hash file if needed.\n * Note that process.env.ALLOW_TO_SKIP_SEED should be set to '1' or 'true' to skip seed.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether seed command can be skipped.\n */\nexport async function canSkipSeed(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n if (process.env.ALLOW_TO_SKIP_SEED !== '1' && process.env.ALLOW_TO_SKIP_SEED !== 'true') return false;\n return !(await updateHashFromFiles(hashFilePath, ...paths));\n}\n\n/**\n * Update hash file if the hash is different from the current one.\n * @param hashFilePath Path to the hash file.\n * @param paths Paths to the files or directories.\n * @returns Whether the hash file was updated.\n */\nexport async function updateHashFromFiles(hashFilePath: string, ...paths: string[]): Promise<boolean> {\n let oldHash = '';\n try {\n oldHash = await fs.promises.readFile(hashFilePath, 'utf8');\n } catch {\n // do nothing\n }\n const newHash = await calculateHashFromFiles(...paths);\n if (oldHash === newHash) return false;\n\n await fs.promises.writeFile(hashFilePath, newHash, 'utf8');\n return true;\n}\n\n/**\n * Calculate hash from files.\n * @param paths Paths to the files or directories.\n * @returns Hash string.\n */\nexport async function calculateHashFromFiles(...paths: string[]): Promise<string> {\n const hash = crypto.createHash('sha512');\n for (const fileOrDirPath of paths.sort()) {\n const stat = await fs.promises.stat(fileOrDirPath);\n if (stat.isDirectory()) {\n // Get all files in the directory\n const dirents = await fs.promises.readdir(fileOrDirPath, { withFileTypes: true, recursive: true });\n for (const dirent of dirents.sort((d1, d2) => d1.name.localeCompare(d2.name))) {\n if (dirent.isFile()) {\n // Node.js 18.17.0 or later has `dirent.path`\n hash.update(\n await fs.promises.readFile(\n path.join((dirent as unknown as Record<'path', string>).path, dirent.name),\n 'utf8'\n )\n );\n }\n }\n } else if (stat.isFile()) {\n hash.update(await fs.promises.readFile(fileOrDirPath, 'utf8'));\n }\n }\n return hash.digest('hex');\n}\n"],"names":["async","canSkipSeed","hashFilePath","paths","process","env","ALLOW_TO_SKIP_SEED","updateHashFromFiles","oldHash","fs","promises","readFile","newHash","calculateHashFromFiles","writeFile","hash","crypto","createHash","fileOrDirPath","sort","stat","isDirectory","dirents","readdir","withFileTypes","recursive","dirent","d1","d2","name","localeCompare","isFile","update","path","join","digest"],"mappings":"2EAWOA,eAAeC,EAAYC,KAAyBC,GACzD,OAAuC,MAAnCC,QAAQC,IAAIC,oBAAiE,SAAnCF,QAAQC,IAAIC,4BAC3CC,EAAoBL,KAAiBC,EACtD,CAQOH,eAAeO,EAAoBL,KAAyBC,GACjE,IAAIK,EAAU,GACd,IACEA,QAAgBC,EAAGC,SAASC,SAAST,EAAc,OACrD,CAAE,MACA,CAEF,MAAMU,QAAgBC,KAA0BV,GAChD,OAAIK,IAAYI,UAEVH,EAAGC,SAASI,UAAUZ,EAAcU,EAAS,SAC5C,EACT,CAOOZ,eAAea,KAA0BV,GAC9C,MAAMY,EAAOC,EAAOC,WAAW,UAC/B,IAAK,MAAMC,KAAiBf,EAAMgB,OAAQ,CACxC,MAAMC,QAAaX,EAAGC,SAASU,KAAKF,GACpC,GAAIE,EAAKC,cAAe,CAEtB,MAAMC,QAAgBb,EAAGC,SAASa,QAAQL,EAAe,CAAEM,eAAe,EAAMC,WAAW,IAC3F,IAAK,MAAMC,KAAUJ,EAAQH,MAAK,CAACQ,EAAIC,IAAOD,EAAGE,KAAKC,cAAcF,EAAGC,QACjEH,EAAOK,UAEThB,EAAKiB,aACGvB,EAAGC,SAASC,SAChBsB,EAAKC,KAAMR,EAA6CO,KAAMP,EAAOG,MACrE,QAKV,MAAWT,EAAKW,UACdhB,EAAKiB,aAAavB,EAAGC,SAASC,SAASO,EAAe,QAE1D,CACA,OAAOH,EAAKoB,OAAO,MACrB"}
|
package/dist/esm/index.d.ts
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
export { loadEnvironmentVariables, removeNpmAndYarnEnvironmentVariables, yargsOptionsBuilderForEnv } from "./env.js";
|
|
2
|
-
export { existsAsync } from "./exists.js";
|
|
3
|
-
export { calculateHashFromFiles, canSkipSeed, updateHashFromFiles } from "./hash.js";
|
|
4
|
-
export { spawnAsync } from "./spawn.js";
|
package/dist/esm/spawn.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { SpawnOptions, SpawnOptionsWithoutStdio, SpawnOptionsWithStdioTuple, SpawnSyncReturns, StdioNull, StdioPipe } from 'node:child_process';
|
|
3
|
-
type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;
|
|
4
|
-
type SpawnAsyncOptions = (SpawnOptionsWithoutStdio | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe> | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe> | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull> | SpawnOptions) & {
|
|
5
|
-
input?: string;
|
|
6
|
-
mergeOutAndError?: boolean;
|
|
7
|
-
killOnExit?: boolean;
|
|
8
|
-
verbose?: boolean;
|
|
9
|
-
};
|
|
10
|
-
declare function spawnAsync(command: string, args?: ReadonlyArray<string>, options?: SpawnAsyncOptions): Promise<SpawnAsyncReturns>;
|
|
11
|
-
export { SpawnAsyncReturns, SpawnAsyncOptions, spawnAsync };
|
package/dist/esm/spawn.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.js","sources":["../../src/spawn.ts"],"sourcesContent":["import type {\n SpawnOptions,\n SpawnOptionsWithoutStdio,\n SpawnOptionsWithStdioTuple,\n SpawnSyncReturns,\n StdioNull,\n StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\nexport type SpawnAsyncOptions = (\n | SpawnOptionsWithoutStdio\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n | SpawnOptions\n) & {\n input?: string;\n mergeOutAndError?: boolean;\n killOnExit?: boolean;\n verbose?: boolean;\n};\n\nexport async function spawnAsync(\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n return new Promise((resolve, reject) => {\n try {\n const proc = spawn(command, args ?? [], options ?? {});\n let stdout = '';\n let stderr = '';\n\n if (options?.input) {\n proc.stdin?.write(options.input);\n proc.stdin?.end();\n }\n proc.stdout?.on('data', (data) => {\n stdout += data;\n });\n proc.stderr?.on('data', (data) => {\n if (options?.mergeOutAndError) {\n stdout += data;\n } else {\n stderr += data;\n }\n });\n\n let stopped = false;\n const stopProcess = (): void => {\n if (stopped || !proc.pid) return;\n\n stopped = true;\n if (options?.verbose) {\n console.info(`treeKill(${proc.pid})`);\n }\n treeKill(proc.pid);\n };\n if (options?.killOnExit) {\n process.on('beforeExit', stopProcess);\n process.on('SIGINT', stopProcess);\n }\n\n proc.on('error', (error) => {\n process.removeListener('exit', stopProcess);\n proc.removeAllListeners('close');\n reject(error);\n });\n proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n process.removeListener('exit', stopProcess);\n if (proc.pid === undefined) {\n reject(new Error('Process has no pid.'));\n } else {\n resolve({\n pid: proc.pid,\n stdout,\n stderr,\n status: code,\n signal,\n });\n }\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"names":["async","spawnAsync","command","args","options","Promise","resolve","reject","proc","spawn","stdout","stderr","input","stdin","write","end","on","data","mergeOutAndError","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","process","error","removeListener","removeAllListeners","code","signal","undefined","Error","status"],"mappings":"oEAgCOA,eAAeC,EACpBC,EACAC,EACAC,GAEA,OAAO,IAAIC,SAAQ,CAACC,EAASC,KAC3B,IACE,MAAMC,EAAOC,EAAMP,EAASC,GAAQ,GAAIC,GAAW,CAAA,GACnD,IAAIM,EAAS,GACTC,EAAS,GAETP,GAASQ,QACXJ,EAAKK,OAAOC,MAAMV,EAAQQ,OAC1BJ,EAAKK,OAAOE,OAEdP,EAAKE,QAAQM,GAAG,QAASC,IACvBP,GAAUO,CAAI,IAEhBT,EAAKG,QAAQK,GAAG,QAASC,IACnBb,GAASc,iBACXR,GAAUO,EAEVN,GAAUM,CACZ,IAGF,IAAIE,GAAU,EACd,MAAMC,EAAcA,MACdD,GAAYX,EAAKa,MAErBF,GAAU,EACNf,GAASkB,SACXC,QAAQC,KAAM,YAAWhB,EAAKa,QAEhCI,EAASjB,EAAKa,KAAI,EAEhBjB,GAASsB,aACXC,QAAQX,GAAG,aAAcI,GACzBO,QAAQX,GAAG,SAAUI,IAGvBZ,EAAKQ,GAAG,SAAUY,IAChBD,QAAQE,eAAe,OAAQT,GAC/BZ,EAAKsB,mBAAmB,SACxBvB,EAAOqB,EAAM,IAEfpB,EAAKQ,GAAG,SAAS,CAACe,EAAqBC,KACrCL,QAAQE,eAAe,OAAQT,QACda,IAAbzB,EAAKa,IACPd,EAAO,IAAI2B,MAAM,wBAEjB5B,EAAQ,CACNe,IAAKb,EAAKa,IACVX,SACAC,SACAwB,OAAQJ,EACRC,UAEJ,GAEH,CAAC,MAAOJ,GACPrB,EAAOqB,EACT,IAEJ"}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|