@mikeyt23/node-cli-utils 2.0.6 → 2.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,299 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.deleteDockerVolume = exports.dockerVolumeExists = exports.getDockerComposeVolumeName = exports.deleteDockerComposeVolume = exports.ensureDockerRunning = exports.isDockerRunning = exports.isDockerInstalled = exports.simpleSpawnDockerAsync = exports.spawnDockerCompose = exports.isValidDockerContainerName = exports.isValidDockerComposeProjectName = void 0;
7
+ const child_process_1 = require("child_process");
8
+ const node_fs_1 = __importDefault(require("node:fs"));
9
+ const path_1 = __importDefault(require("path"));
10
+ const NodeCliUtilsConfig_js_1 = require("./NodeCliUtilsConfig.js");
11
+ const generalUtils_js_1 = require("./generalUtils.js");
12
+ const generalUtilsInternal_js_1 = require("./generalUtilsInternal.js");
13
+ const dockerComposeCommandsThatSupportDetached = ['exec', 'logs', 'ps', 'restart', 'run', 'start', 'stop', 'up'];
14
+ /**
15
+ * Check if the string is a valid docker compose project name:
16
+ *
17
+ * - Must contain only lowercase letters, digits, dashes and underscores
18
+ * - Must start with a lowercase letter or digit
19
+ *
20
+ * See https://docs.docker.com/compose/environment-variables/envvars/#compose_project_name.
21
+ * @param projectName The string to validate
22
+ * @returns `true` if the string is a valid docker compose project name, `false` otherwise
23
+ */
24
+ function isValidDockerComposeProjectName(projectName) {
25
+ (0, generalUtils_js_1.requireString)('projectName', projectName);
26
+ // Ensure first char is a lowercase letter or digit
27
+ if (!/^[a-z0-9]/.test(projectName[0])) {
28
+ return false;
29
+ }
30
+ // Ensure the rest of the chars are only lowercase letters, digits, dashes and underscores
31
+ return /^[a-z0-9-_]+$/.test(projectName);
32
+ }
33
+ exports.isValidDockerComposeProjectName = isValidDockerComposeProjectName;
34
+ /**
35
+ * Check if the string is a valid docker container name:
36
+ *
37
+ * - Must start with a letter or digit
38
+ * - Contain only letters, digits, underscores and periods
39
+ * - Must not end with a period
40
+ * @param containerName The docker container name to validate.
41
+ * @returns `true` if valid, `false otherwise
42
+ */
43
+ function isValidDockerContainerName(containerName) {
44
+ return /[a-zA-Z0-9][a-zA-Z0-9_.-]+/.test(containerName) && !containerName.endsWith('.');
45
+ }
46
+ exports.isValidDockerContainerName = isValidDockerContainerName;
47
+ /**
48
+ * For docker compose commands, see https://docs.docker.com/compose/reference/. For available options for this wrapper function, see {@link DockerComposeOptions}.
49
+ *
50
+ * The current working directory will be the directory of the {@link dockerComposePath} unless specified in the options. This ensures relative paths in the
51
+ * docker compose file will be relative to itself by default.
52
+ *
53
+ * See {@link DockerComposeOptions.projectName} for info on where to locate your docker compose file and how to specify the docker project name.
54
+ * @param dockerComposePath Path to docker-compose.yml
55
+ * @param dockerComposeCommand The docker-compose command to run
56
+ * @param options {@link DockerComposeOptions} to use, including additional arguments to pass to the docker compose command and the project name
57
+ */
58
+ async function spawnDockerCompose(dockerComposePath, dockerComposeCommand, options) {
59
+ (0, generalUtils_js_1.requireValidPath)('dockerComposePath', dockerComposePath);
60
+ (0, generalUtils_js_1.requireString)('dockerComposeCommand', dockerComposeCommand);
61
+ if (options === null || options === void 0 ? void 0 : options.cwd) {
62
+ (0, generalUtils_js_1.requireValidPath)('cwd', options.cwd);
63
+ }
64
+ if (options === null || options === void 0 ? void 0 : options.altEnvFilePath) {
65
+ (0, generalUtils_js_1.requireValidPath)('altEnvFilePath', options.altEnvFilePath);
66
+ }
67
+ if ((options === null || options === void 0 ? void 0 : options.projectName) && !isValidDockerComposeProjectName(options.projectName)) {
68
+ throw new Error('Invalid docker compose project name specified for the projectName param. Project names must contain only lowercase letters, decimal digits, dashes, and underscores, and must begin with a lowercase letter or decimal digit.');
69
+ }
70
+ if ((options === null || options === void 0 ? void 0 : options.profile) && !/[a-zA-Z0-9][a-zA-Z0-9_.-]+/.test(options.profile)) {
71
+ throw new Error('Invalid profile option - must match regex: [a-zA-Z0-9][a-zA-Z0-9_.-]+');
72
+ }
73
+ if (!await isDockerRunning()) {
74
+ throw new Error('Docker is not running');
75
+ }
76
+ const defaultOptions = { args: [], attached: false, projectName: undefined, cwd: undefined };
77
+ const mergedOptions = { ...defaultOptions, ...options };
78
+ if (!options || options.useWslPrefix === undefined) {
79
+ mergedOptions.useWslPrefix = NodeCliUtilsConfig_js_1.config.useWslPrefixForDockerCommandsOnWindows;
80
+ }
81
+ const dockerComposeDir = path_1.default.dirname(dockerComposePath);
82
+ const dockerComposeFilename = path_1.default.basename(dockerComposePath);
83
+ if (!mergedOptions.cwd) {
84
+ mergedOptions.cwd = dockerComposeDir;
85
+ }
86
+ let dockerComposePathResolved = mergedOptions.cwd ? path_1.default.resolve(dockerComposePath) : dockerComposeFilename;
87
+ if (mergedOptions.useWslPrefix) {
88
+ dockerComposePathResolved = (0, generalUtils_js_1.toWslPath)(dockerComposePathResolved);
89
+ }
90
+ let spawnArgs = ['compose', '-f', dockerComposePathResolved];
91
+ if (mergedOptions.projectName) {
92
+ spawnArgs.push('--project-name', mergedOptions.projectName);
93
+ }
94
+ if (mergedOptions.profile) {
95
+ spawnArgs.push('--profile', mergedOptions.profile);
96
+ }
97
+ if (mergedOptions.altEnvFilePath) {
98
+ spawnArgs.push('--env-file', mergedOptions.useWslPrefix ? (0, generalUtils_js_1.toWslPath)(mergedOptions.altEnvFilePath) : mergedOptions.altEnvFilePath);
99
+ }
100
+ spawnArgs.push(dockerComposeCommand);
101
+ if (!mergedOptions.attached && dockerComposeCommandsThatSupportDetached.includes(dockerComposeCommand)) {
102
+ spawnArgs.push('--detach');
103
+ }
104
+ if (mergedOptions.args) {
105
+ spawnArgs = spawnArgs.concat(mergedOptions.args);
106
+ }
107
+ (0, generalUtils_js_1.trace)(`running command in ${mergedOptions.cwd}: docker ${spawnArgs.join(' ')}`);
108
+ const longRunning = dockerComposeCommandsThatSupportDetached.includes(dockerComposeCommand) && (options === null || options === void 0 ? void 0 : options.attached) === true;
109
+ (0, generalUtils_js_1.trace)(`docker compose command will be configured to use long running option: ${longRunning}`);
110
+ const spawnOptions = {
111
+ cwd: mergedOptions.cwd,
112
+ shell: (0, generalUtils_js_1.isPlatformWindows)(),
113
+ isLongRunning: longRunning
114
+ };
115
+ const spawnResult = mergedOptions.useWslPrefix ?
116
+ await (0, generalUtilsInternal_js_1.spawnAsyncInternal)('wsl', ['docker', ...spawnArgs], spawnOptions) :
117
+ await (0, generalUtilsInternal_js_1.spawnAsyncInternal)('docker', spawnArgs, spawnOptions);
118
+ if (spawnResult.code !== 0) {
119
+ throw new Error(`docker compose command failed with code ${spawnResult.code}`);
120
+ }
121
+ }
122
+ exports.spawnDockerCompose = spawnDockerCompose;
123
+ /**
124
+ * Similar to {@link simpleSpawnAsync} but meant for `docker` calls only. Determines whether to run `docker` or `wsl docker` based
125
+ * on platform being windows and config setting `useWslPrefixForDockerCommands`.
126
+ * @param args The args to be passed to the docker command.
127
+ */
128
+ async function simpleSpawnDockerAsync(args) {
129
+ const command = NodeCliUtilsConfig_js_1.config.useWslPrefixForDockerCommandsOnWindows ? 'wsl' : 'docker';
130
+ const spawnArgs = command === 'docker' ? args : ['docker', ...args];
131
+ return await (0, generalUtils_js_1.simpleSpawnAsync)(command, spawnArgs);
132
+ }
133
+ exports.simpleSpawnDockerAsync = simpleSpawnDockerAsync;
134
+ /**
135
+ * Uses {@link which} to determine if docker is installed. If the `which` call doesn't find docker and the platform
136
+ * is Windows, then this will check the output of `wsl docker --version` to see if just the engine is installed.
137
+ * @returns `true` if docker is installed, `false` otherwise
138
+ */
139
+ async function isDockerInstalled() {
140
+ if ((await (0, generalUtils_js_1.which)('docker')).location) {
141
+ return true;
142
+ }
143
+ if ((0, generalUtils_js_1.isPlatformWindows)()) {
144
+ const result = await (0, generalUtils_js_1.simpleSpawnAsync)('wsl', ['docker', '--version']);
145
+ return result.code === 0;
146
+ }
147
+ return false;
148
+ }
149
+ exports.isDockerInstalled = isDockerInstalled;
150
+ /**
151
+ * Runs the `docker info` command and looks for "error during connect" in the output to determine if docker is running. If you
152
+ * want to check if docker is installed, use {@link isDockerInstalled}.
153
+ * @returns `true` if docker is installed and running, `false` otherwise
154
+ */
155
+ async function isDockerRunning() {
156
+ try {
157
+ const result = (0, generalUtils_js_1.isPlatformWindows)() ?
158
+ await (0, generalUtils_js_1.simpleSpawnAsync)('wsl', ['docker', 'info']) :
159
+ await (0, generalUtils_js_1.simpleSpawnAsync)('docker', ['info']);
160
+ return result.code === 0 && !result.stdout.includes('error during connect');
161
+ }
162
+ catch (err) {
163
+ return false;
164
+ }
165
+ }
166
+ exports.isDockerRunning = isDockerRunning;
167
+ /**
168
+ * Attempt to start the docker service if it isn't running. Whether it's running is determined by a call to {@link isDockerRunning}.
169
+ *
170
+ * Notes on docker startup command:
171
+ * - May require entering a password
172
+ * - On Windows with Docker Desktop and from within powershell or cmd it will run in powershell: `Start-Process "C:\Program Files\Docker\Docker\Docker Desktop.exe" -NoNewWindow`
173
+ * - On Windows without Docker Desktop from within powershell or cmd it will run: `sudo service docker start`
174
+ * - On Linux (including WSL) it will run: `sudo systemctl start docker`
175
+ * - Not currently supported on Mac
176
+ * - If you're on Windows and have Docker Desktop but it is stopped and you're in a WSL shell, docker will appear as if it's not installed and this method will throw
177
+ *
178
+ * @throws An {@link Error} If docker is not detected on the system.
179
+ * @throws An {@link Error} if docker is detected as installed and not running but the OS is Mac.
180
+ */
181
+ async function ensureDockerRunning() {
182
+ if (!await isDockerInstalled()) {
183
+ throw new Error('Docker does not appear to be installed');
184
+ }
185
+ if (await isDockerRunning()) {
186
+ return;
187
+ }
188
+ let command;
189
+ let args = [];
190
+ const isWindows = (0, generalUtils_js_1.isPlatformWindows)();
191
+ const isLinux = (0, generalUtils_js_1.isPlatformLinux)();
192
+ const dockerDesktopPath = 'C:\\Program Files\\Docker\\Docker\\Docker Desktop.exe';
193
+ let useExec = false;
194
+ if (isWindows) {
195
+ if (node_fs_1.default.existsSync(dockerDesktopPath)) {
196
+ command = 'powershell';
197
+ args = (0, generalUtils_js_1.getPowershellHackArgs)(`Start-Process 'C:\\Program Files\\Docker\\Docker\\Docker Desktop.exe' -NoNewWindow`);
198
+ }
199
+ else {
200
+ command = 'C:\\windows\\system32\\wsl.exe -u root -e sh -c "service docker start"';
201
+ useExec = true;
202
+ }
203
+ }
204
+ else if (isLinux) {
205
+ command = 'sudo';
206
+ args = ['service', 'docker', 'start'];
207
+ }
208
+ else {
209
+ throw new Error('Starting docker within ensureDockerRunning is only supported on Windows and Linux - you will have to start docker manually');
210
+ }
211
+ if (useExec) {
212
+ try {
213
+ (0, child_process_1.execSync)(command, { stdio: 'inherit' });
214
+ }
215
+ catch (err) {
216
+ throw new generalUtils_js_1.ExtendedError('Unable to start docker', (0, generalUtils_js_1.getNormalizedError)(err));
217
+ }
218
+ }
219
+ else {
220
+ const result = await (0, generalUtils_js_1.spawnAsync)(command, args, { shell: isWindows });
221
+ if (result.code !== 0) {
222
+ throw new Error('Unable to start docker - see error above');
223
+ }
224
+ }
225
+ // Wait for docker to be up and ready before continuing
226
+ await (0, generalUtils_js_1.withRetryAsync)(generalUtilsInternal_js_1.throwIfDockerNotReady, 6, 3000, { initialDelayMilliseconds: 3000 });
227
+ }
228
+ exports.ensureDockerRunning = ensureDockerRunning;
229
+ /**
230
+ * The name of a docker volume to delete. Respects the config value `useWslPrefixForDockerCommands`.
231
+ * @param volumeName The name of the docker volume to delete.
232
+ * @throws An {@link ExtendedError} if the volume does not exist or the volume is in use.
233
+ */
234
+ async function deleteDockerComposeVolume(volumeName) {
235
+ (0, generalUtils_js_1.requireString)('volumeName', volumeName);
236
+ // Docker compose volume names will have the same character restrictions as docker compose project names
237
+ if (!isValidDockerComposeProjectName(volumeName)) {
238
+ throw new Error(`Invalid volume name: ${volumeName}`);
239
+ }
240
+ try {
241
+ const composeVolumeName = await getDockerComposeVolumeName(volumeName);
242
+ if (!composeVolumeName) {
243
+ (0, generalUtils_js_1.log)(`volume ${volumeName} not found in docker compose config - skipping`);
244
+ return;
245
+ }
246
+ if (!await dockerVolumeExists(composeVolumeName)) {
247
+ (0, generalUtils_js_1.log)(`docker compose volume ${composeVolumeName} does not appear to exist - skipping`);
248
+ return;
249
+ }
250
+ await deleteDockerVolume(composeVolumeName);
251
+ }
252
+ catch (err) {
253
+ throw new generalUtils_js_1.ExtendedError(`Error removing the volume ${volumeName}`, (0, generalUtils_js_1.getNormalizedError)(err));
254
+ }
255
+ }
256
+ exports.deleteDockerComposeVolume = deleteDockerComposeVolume;
257
+ /**
258
+ * This function will take the volume name as you defined it in `docker-compose.yml` and try getting the actual volume name that docker
259
+ * compose will use. This is needed because docker compose will prefix the volume name with the compose project name (directory name or env
260
+ * `COMPOSE_PROJECT_NAME` or `-p` passed to docker compose commands).
261
+ *
262
+ * This function respects the `useWslPrefixForDockerCommands` config option. See also: {@link deleteDockerComposeVolume}.
263
+ * @param volumeName The volume name as defined in the `docker-compose.yml` file.
264
+ * @returns The full name of the docker-compose-actualized docker volume.
265
+ */
266
+ async function getDockerComposeVolumeName(volumeName) {
267
+ var _a, _b;
268
+ const result = await simpleSpawnDockerAsync(['compose', 'config', '--format', 'json']);
269
+ const composeConfigJson = JSON.parse(result.stdout);
270
+ return (_b = (_a = composeConfigJson === null || composeConfigJson === void 0 ? void 0 : composeConfigJson.volumes) === null || _a === void 0 ? void 0 : _a[volumeName]) === null || _b === void 0 ? void 0 : _b.name;
271
+ }
272
+ exports.getDockerComposeVolumeName = getDockerComposeVolumeName;
273
+ /**
274
+ * Check if a docker volume exists based on inclusion of the specified `volumeName` in any of the output lines of `docker volume ls`.
275
+ *
276
+ * This function respects the `useWslPrefixForDockerCommands` config option. See also: {@link deleteDockerComposeVolume}.
277
+ * @param volumeName The docker volume name to check.
278
+ * @returns `true` if the docker volume exists, otherwise `false`.
279
+ */
280
+ async function dockerVolumeExists(volumeName) {
281
+ const result = await simpleSpawnDockerAsync(['volume', 'ls']);
282
+ return result.stdoutLines.filter(ln => ln.includes(volumeName)).length > 0;
283
+ }
284
+ exports.dockerVolumeExists = dockerVolumeExists;
285
+ /**
286
+ * This will attempt to delete a docker volume using the `docker volume rm` command.
287
+ *
288
+ * **Warning: ** there will be no prompt or confirmation before attempting to delete the volume.
289
+ *
290
+ * This function respects the `useWslPrefixForDockerCommands` config option. See also: {@link deleteDockerComposeVolume}.
291
+ * @param volumeName The name of the docker volume to delete.
292
+ * @throws An {@link Error} if the volume doesn't exist or is in use.
293
+ */
294
+ async function deleteDockerVolume(volumeName) {
295
+ (0, generalUtils_js_1.trace)(`deleting docker compose volume ${volumeName}`);
296
+ await simpleSpawnDockerAsync(['volume', 'rm', volumeName]);
297
+ }
298
+ exports.deleteDockerVolume = deleteDockerVolume;
299
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2VyVXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZG9ja2VyVXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsaURBQXdDO0FBQ3hDLHNEQUF3QjtBQUN4QixnREFBdUI7QUFDdkIsbUVBQWdEO0FBQ2hELHVEQUFnUTtBQUNoUSx1RUFBMkc7QUFPM0csTUFBTSx3Q0FBd0MsR0FBMkIsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUE7QUFFeEk7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsK0JBQStCLENBQUMsV0FBbUI7SUFDakUsSUFBQSwrQkFBYSxFQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsQ0FBQTtJQUV6QyxtREFBbUQ7SUFDbkQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7UUFDckMsT0FBTyxLQUFLLENBQUE7S0FDYjtJQUVELDBGQUEwRjtJQUMxRixPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUE7QUFDMUMsQ0FBQztBQVZELDBFQVVDO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDSCxTQUFnQiwwQkFBMEIsQ0FBQyxhQUFxQjtJQUM5RCxPQUFPLDRCQUE0QixDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUE7QUFDekYsQ0FBQztBQUZELGdFQUVDO0FBbUVEOzs7Ozs7Ozs7O0dBVUc7QUFDSSxLQUFLLFVBQVUsa0JBQWtCLENBQUMsaUJBQXlCLEVBQUUsb0JBQTBDLEVBQUUsT0FBdUM7SUFDckosSUFBQSxrQ0FBZ0IsRUFBQyxtQkFBbUIsRUFBRSxpQkFBaUIsQ0FBQyxDQUFBO0lBQ3hELElBQUEsK0JBQWEsRUFBQyxz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
@@ -1,4 +1,5 @@
1
1
  /// <reference types="node" />
2
+ /// <reference types="node" />
2
3
  import { SpawnOptions } from 'node:child_process';
3
4
  /**
4
5
  * Just a wrapper for console.log() to type less.
@@ -83,10 +84,6 @@ export interface WhichResult {
83
84
  additionalLocations: string[] | undefined;
84
85
  error: Error | undefined;
85
86
  }
86
- /**
87
- * Type guard for command passed to {@link spawnDockerCompose}.
88
- */
89
- export type DockerComposeCommand = 'build' | 'config' | 'cp' | 'create' | 'down' | 'events' | 'exec' | 'images' | 'kill' | 'logs' | 'ls' | 'pause' | 'port' | 'ps' | 'pull' | 'push' | 'restart' | 'rm' | 'run' | 'start' | 'stop' | 'top' | 'unpause' | 'up' | 'version';
90
87
  /**
91
88
  * Sleeps for the specified number of milliseconds.
92
89
  * @param ms The number of milliseconds to sleep
@@ -178,84 +175,6 @@ export declare function requireString(paramName: string, paramValue: string): vo
178
175
  * @param paramValue The value of the parameter
179
176
  */
180
177
  export declare function requireValidPath(paramName: string, paramValue: string): void;
181
- /**
182
- * Project names must contain only lowercase letters, decimal digits, dashes, and underscores, and must begin with a lowercase letter or decimal digit.
183
- *
184
- * See https://docs.docker.com/compose/environment-variables/envvars/#compose_project_name.
185
- * @param projectName The string to validate
186
- * @returns `true` if it's a valid docker compose project name and `false` otherwise
187
- */
188
- export declare function isDockerComposeProjectNameValid(projectName: string): boolean;
189
- /**
190
- * Options for {@link spawnDockerCompose}.
191
- * @param projectName
192
- * Note that there are other better options such as using the environment variable `COMPOSE_PROJECT_NAME`. See https://docs.docker.com/compose/environment-variables/envvars/#compose_project_name.
193
- * @param attached Default: false. All commands that support the detached option wil use it unless attached is specified as true (-d support: exec, logs, ps, restart, run, start, stop, up)
194
- * @param useDockerComposeFileDirectoryAsCwd Default: false. If true, the docker compose command will be run in the directory containing the docker compose file.
195
- */
196
- export interface DockerComposeOptions {
197
- /** Additional arguments to pass to the docker-compose command. */
198
- args: string[];
199
- /**
200
- * Defaults to `false`. Controls whether or not the `--detach` option is passed. Note that this only applies to
201
- * some commands (exec, logs, ps, restart, run, start, stop, up).
202
- */
203
- attached: boolean;
204
- /**
205
- * If not provided, it will default to using the directory that the docker-compose.yml is located in.
206
- * Specifies what current working directory to use with the spawn command.
207
- *
208
- * **Important:**: this only affects the current working directory of the spawned process itself. The docker command will still only pull in env values from a `.env`
209
- * file in the same directory as the docker-compose.yml, NOT the cwd passed here. If a different `.env` file path is needed, use the {@link altEnvFilePath} option. If
210
- * you use the {@link altEnvFilePath} option with a relative path, ensure that it is relative to the current working directory passed with this option.
211
- */
212
- cwd?: string;
213
- /**
214
- * Optional. If provided, projectName will be passed as the `--project-name` param to `docker compose` so that generated containers will use it as a prefix
215
- * instead of the default, which is the directory name where the docker-compose.yml is located.
216
- *
217
- * Alternate approaches for setting the docker compose project name:
218
- *
219
- * - Locate your docker-compose.yml file in the root of your project so that docker will use that directory name for prefixing generated containers
220
- * - OR, locate your docker-compose.yml in a sub-directory named appropriately for use as a prefix for generated containers
221
- * - OR, put a `.env` file in the same directory as your docker-compose.yml
222
- * with the entry `COMPOSE_PROJECT_NAME=your-project-name`
223
- *
224
- * Additional note on docker compose project names form the official docker compose docs: "Project names must contain only lowercase letters, decimal digits,
225
- * dashes, and underscores, and must begin with a lowercase letter or decimal digit". See https://docs.docker.com/compose/environment-variables/envvars/#compose_project_name.
226
- *
227
- */
228
- projectName?: string;
229
- /**
230
- * Optional. If provided, profile is passed to docker compose along with `--profile` param. Must match this regex: `[a-zA-Z0-9][a-zA-Z0-9_.-]+`.
231
- *
232
- * See https://docs.docker.com/compose/profiles/.
233
- */
234
- profile?: string;
235
- /**
236
- * The option `useWslPrefix` set to `true` can be used If Docker Desktop is not installed on Windows and docker commands need to execute via wsl.
237
- */
238
- useWslPrefix?: boolean;
239
- /**
240
- * Specify an alternative env file. This is useful since docker will normally only use a `.env` file in the same directory as the docker-compose.yml file,
241
- * regardless of the current working directory of the running command. This path will be passed to docker compose using the `--env-file` option.
242
- *
243
- * **Important:** if using a relative path, be sure pass the appropriate value for {@link cwd} to this method so that the relative path can correctly be resolved.
244
- */
245
- altEnvFilePath?: string;
246
- }
247
- /**
248
- * For docker compose commands, see https://docs.docker.com/compose/reference/. For available options for this wrapper function, see {@link DockerComposeOptions}.
249
- *
250
- * The current working directory will be the directory of the {@link dockerComposePath} unless specified in the options. This ensures relative paths in the
251
- * docker compose file will be relative to itself by default.
252
- *
253
- * See {@link DockerComposeOptions.projectName} for info on where to locate your docker compose file and how to specify the docker project name.
254
- * @param dockerComposePath Path to docker-compose.yml
255
- * @param dockerComposeCommand The docker-compose command to run
256
- * @param options {@link DockerComposeOptions} to use, including additional arguments to pass to the docker compose command and the project name
257
- */
258
- export declare function spawnDockerCompose(dockerComposePath: string, dockerComposeCommand: DockerComposeCommand, options?: Partial<DockerComposeOptions>): Promise<void>;
259
178
  /**
260
179
  * Splits a string into lines, removing `\n` and `\r` characters. Does not return empty lines. Also see {@link stringToLines}.
261
180
  * @param str String to split into lines
@@ -360,33 +279,6 @@ export declare function which(commandName: string): Promise<WhichResult>;
360
279
  * @returns The location of the command, any additional locations, and an error if one occurred
361
280
  */
362
281
  export declare function whichSync(commandName: string): WhichResult;
363
- /**
364
- * Uses {@link which} to determine if docker is installed. If the `which` call doesn't find docker and the platform
365
- * is Windows, then this will check the output of `wsl docker --version` to see if just the engine is installed.
366
- * @returns `true` if docker is installed, `false` otherwise
367
- */
368
- export declare function isDockerInstalled(): Promise<boolean>;
369
- /**
370
- * Runs the `docker info` command and looks for "error during connect" in the output to determine if docker is running. If you
371
- * want to check if docker is installed, use {@link isDockerInstalled}.
372
- * @returns `true` if docker is installed and running, `false` otherwise
373
- */
374
- export declare function isDockerRunning(): Promise<boolean>;
375
- /**
376
- * Attempt to start the docker service if it isn't running. Whether it's running is determined by a call to {@link isDockerRunning}.
377
- *
378
- * Notes on docker startup command:
379
- * - May require entering a password
380
- * - On Windows with Docker Desktop and from within powershell or cmd it will run in powershell: `Start-Process "C:\Program Files\Docker\Docker\Docker Desktop.exe" -NoNewWindow`
381
- * - On Windows without Docker Desktop from within powershell or cmd it will run: `sudo service docker start`
382
- * - On Linux (including WSL) it will run: `sudo systemctl start docker`
383
- * - Not currently supported on Mac
384
- * - If you're on Windows and have Docker Desktop but it is stopped and you're in a WSL shell, docker will appear as if it's not installed and this method will throw
385
- *
386
- * @throws An {@link Error} If docker is not detected on the system.
387
- * @throws An {@link Error} if docker is detected as installed and not running but the OS is Mac.
388
- */
389
- export declare function ensureDockerRunning(): Promise<void>;
390
282
  /**
391
283
  * Uses built-in NodeJS readline to ask a question and return the user's answer.
392
284
  * @param query The question to ask
@@ -589,7 +481,8 @@ export declare enum Emoji {
589
481
  NoEntry = "\u26D4",
590
482
  Stop = "\uD83D\uDED1",
591
483
  Certificate = "\uD83D\uDCDC",
592
- Key = "\uD83D\uDD11"
484
+ Key = "\uD83D\uDD11",
485
+ Scull = "\u2620\uFE0F"
593
486
  }
594
487
  /**
595
488
  * Converts a windows path to a WSL path (Windows Subsystem for Linux) if it's an absolute path, otherwise returns it unchanged.
@@ -604,7 +497,70 @@ export declare enum Emoji {
604
497
  * @returns The wsl equivalent path.
605
498
  */
606
499
  export declare function toWslPath(winPath: string, wrapInQuotesIfSpaces?: boolean): string;
500
+ /**
501
+ * Serialize a class instance. Ignore properties with underscore prefix and include getters. Useful for overriding the `toJSON` function of
502
+ * a class so that calls to `JSON.stringify()` will generate more appropriate JSON.
503
+ *
504
+ * @example
505
+ * ```
506
+ * class MyClass {
507
+ * //...
508
+ * toJSON = () => classToJson(this)
509
+ * //...
510
+ * }
511
+ * ```
512
+ * @param instance A class instance, usually `this` if `classToJson` is being used as a class method.
513
+ * @returns Json serialization of the class instance.
514
+ */
607
515
  export declare function classToJson(instance: object): {
608
516
  [key: string]: unknown;
609
517
  };
518
+ /**
519
+ * Get's the value for the CLI param at process.argv[`argvIndex`] and throws the specified optional `errorMessage`
520
+ * or a default error message if the CLI arg is missing.
521
+ *
522
+ * Notes on common index position values:
523
+ *
524
+ * - `0`: NodeJS path
525
+ * - `1`: Script path
526
+ * - `2`: First script param - for `swig` this will be the task name
527
+ * @param errorMessage
528
+ * @returns
529
+ */
530
+ export declare function getRequiredCliParam(argvIndex: number, errorMessage?: string): string;
531
+ type AsyncBooleanFunc = () => Promise<boolean>;
532
+ type AsyncFunc<T> = () => Promise<T>;
533
+ /**
534
+ * Executes an asynchronous function conditionally.
535
+ *
536
+ * @overload
537
+ * @template T The type of value that the `asyncFunc` returns.
538
+ * @param condition A boolean that determines if the `asyncFunc` should be executed.
539
+ * @param asyncFunc The async function to execute if the condition is true.
540
+ * @param logEnabled Optional. Determines whether to enable logging. Defaults to `false`.
541
+ * @returns Returns a Promise resolving to the value returned by `asyncFunc` if the condition is true, otherwise returns `undefined`.
542
+ */
543
+ export declare function conditionallyAsync<T>(condition: boolean, asyncFunc: AsyncFunc<T>, logEnabled?: boolean): Promise<T | undefined>;
544
+ /**
545
+ * Executes an asynchronous function conditionally.
546
+ *
547
+ * @overload
548
+ * @template T The type of value that the `asyncFunc` returns.
549
+ * @param conditionAsyncFunc An async function that returns a boolean that determines whether `asyncFunc` should be executed.
550
+ * @param asyncFunc The async function to execute if the condition is true.
551
+ * @param logEnabled Optional. Determines whether to enable logging. Defaults to `false`.
552
+ * @returns Returns a Promise resolving to the value returned by `asyncFunc` if the condition is true, otherwise returns `undefined`.
553
+ */
554
+ export declare function conditionallyAsync<T>(conditionAsyncFunc: AsyncBooleanFunc, asyncFunc: AsyncFunc<T>, logEnabled?: boolean): Promise<T | undefined>;
555
+ /**
556
+ * Type guard function to check if an Error is a `NodeJS.ErrnoException`.
557
+ * @param err The Error object to check.
558
+ * @returns `true` if it's a NodeJS.ErrnoException and `false` otherwise.
559
+ */
560
+ export declare function isErrnoException(err: unknown): err is NodeJS.ErrnoException;
561
+ /**
562
+ * Return `true` if `err` is a `NodeJS.ErrnoException` and has a `code` property equal to `ENOENT`.
563
+ */
564
+ export declare function isErrorEnoent(err: unknown): boolean;
565
+ export {};
610
566
  //# sourceMappingURL=generalUtils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"generalUtils.d.ts","sourceRoot":"","sources":["../../src/generalUtils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"generalUtils.d.ts","sourceRoot":"","sources":["../../src/generalUtils.ts"],"names":[],"mappings":"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"}