@mikeyt23/node-cli-utils 2.0.5 → 2.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +6 -6
- package/README.md +11 -10
- package/dist/cjs/DependencyChecker.d.ts.map +1 -1
- package/dist/cjs/DependencyChecker.js +3 -2
- package/dist/cjs/NodeCliUtilsConfig.d.ts +3 -7
- package/dist/cjs/NodeCliUtilsConfig.d.ts.map +1 -1
- package/dist/cjs/NodeCliUtilsConfig.js +7 -10
- package/dist/cjs/certUtils.js +22 -22
- package/dist/cjs/dbMigrationUtils.js +21 -21
- package/dist/cjs/dockerUtils.d.ts +164 -0
- package/dist/cjs/dockerUtils.d.ts.map +1 -0
- package/dist/cjs/dockerUtils.js +299 -0
- package/dist/cjs/generalUtils.d.ts +55 -110
- package/dist/cjs/generalUtils.d.ts.map +1 -1
- package/dist/cjs/generalUtils.js +63 -196
- package/dist/cjs/generalUtilsInternal.js +2 -2
- package/dist/cjs/package.json +5 -5
- package/dist/esm/DependencyChecker.d.ts.map +1 -1
- package/dist/esm/DependencyChecker.js +3 -2
- package/dist/esm/NodeCliUtilsConfig.d.ts +3 -7
- package/dist/esm/NodeCliUtilsConfig.d.ts.map +1 -1
- package/dist/esm/NodeCliUtilsConfig.js +7 -10
- package/dist/esm/certUtils.js +22 -22
- package/dist/esm/dbMigrationUtils.js +21 -21
- package/dist/esm/dockerUtils.d.ts +164 -0
- package/dist/esm/dockerUtils.d.ts.map +1 -0
- package/dist/esm/dockerUtils.js +281 -0
- package/dist/esm/generalUtils.d.ts +55 -110
- package/dist/esm/generalUtils.d.ts.map +1 -1
- package/dist/esm/generalUtils.js +60 -190
- package/dist/esm/generalUtilsInternal.js +2 -2
- package/package.json +25 -2
|
@@ -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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
|
|
@@ -83,10 +83,6 @@ export interface WhichResult {
|
|
|
83
83
|
additionalLocations: string[] | undefined;
|
|
84
84
|
error: Error | undefined;
|
|
85
85
|
}
|
|
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
86
|
/**
|
|
91
87
|
* Sleeps for the specified number of milliseconds.
|
|
92
88
|
* @param ms The number of milliseconds to sleep
|
|
@@ -178,84 +174,6 @@ export declare function requireString(paramName: string, paramValue: string): vo
|
|
|
178
174
|
* @param paramValue The value of the parameter
|
|
179
175
|
*/
|
|
180
176
|
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
177
|
/**
|
|
260
178
|
* Splits a string into lines, removing `\n` and `\r` characters. Does not return empty lines. Also see {@link stringToLines}.
|
|
261
179
|
* @param str String to split into lines
|
|
@@ -360,33 +278,6 @@ export declare function which(commandName: string): Promise<WhichResult>;
|
|
|
360
278
|
* @returns The location of the command, any additional locations, and an error if one occurred
|
|
361
279
|
*/
|
|
362
280
|
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
281
|
/**
|
|
391
282
|
* Uses built-in NodeJS readline to ask a question and return the user's answer.
|
|
392
283
|
* @param query The question to ask
|
|
@@ -589,7 +480,8 @@ export declare enum Emoji {
|
|
|
589
480
|
NoEntry = "\u26D4",
|
|
590
481
|
Stop = "\uD83D\uDED1",
|
|
591
482
|
Certificate = "\uD83D\uDCDC",
|
|
592
|
-
Key = "\uD83D\uDD11"
|
|
483
|
+
Key = "\uD83D\uDD11",
|
|
484
|
+
Scull = "\u2620\uFE0F"
|
|
593
485
|
}
|
|
594
486
|
/**
|
|
595
487
|
* Converts a windows path to a WSL path (Windows Subsystem for Linux) if it's an absolute path, otherwise returns it unchanged.
|
|
@@ -604,7 +496,60 @@ export declare enum Emoji {
|
|
|
604
496
|
* @returns The wsl equivalent path.
|
|
605
497
|
*/
|
|
606
498
|
export declare function toWslPath(winPath: string, wrapInQuotesIfSpaces?: boolean): string;
|
|
499
|
+
/**
|
|
500
|
+
* Serialize a class instance. Ignore properties with underscore prefix and include getters. Useful for overriding the `toJSON` function of
|
|
501
|
+
* a class so that calls to `JSON.stringify()` will generate more appropriate JSON.
|
|
502
|
+
*
|
|
503
|
+
* @example
|
|
504
|
+
* ```
|
|
505
|
+
* class MyClass {
|
|
506
|
+
* //...
|
|
507
|
+
* toJSON = () => classToJson(this)
|
|
508
|
+
* //...
|
|
509
|
+
* }
|
|
510
|
+
* ```
|
|
511
|
+
* @param instance A class instance, usually `this` if `classToJson` is being used as a class method.
|
|
512
|
+
* @returns Json serialization of the class instance.
|
|
513
|
+
*/
|
|
607
514
|
export declare function classToJson(instance: object): {
|
|
608
515
|
[key: string]: unknown;
|
|
609
516
|
};
|
|
517
|
+
/**
|
|
518
|
+
* Get's the value for the CLI param at process.argv[`argvIndex`] and throws the specified optional `errorMessage`
|
|
519
|
+
* or a default error message if the CLI arg is missing.
|
|
520
|
+
*
|
|
521
|
+
* Notes on common index position values:
|
|
522
|
+
*
|
|
523
|
+
* - `0`: NodeJS path
|
|
524
|
+
* - `1`: Script path
|
|
525
|
+
* - `2`: First script param - for `swig` this will be the task name
|
|
526
|
+
* @param errorMessage
|
|
527
|
+
* @returns
|
|
528
|
+
*/
|
|
529
|
+
export declare function getRequiredCliParam(argvIndex: number, errorMessage?: string): string;
|
|
530
|
+
type AsyncBooleanFunc = () => Promise<boolean>;
|
|
531
|
+
type AsyncFunc<T> = () => Promise<T>;
|
|
532
|
+
/**
|
|
533
|
+
* Executes an asynchronous function conditionally.
|
|
534
|
+
*
|
|
535
|
+
* @overload
|
|
536
|
+
* @template T The type of value that the `asyncFunc` returns.
|
|
537
|
+
* @param condition A boolean that determines if the `asyncFunc` should be executed.
|
|
538
|
+
* @param asyncFunc The async function to execute if the condition is true.
|
|
539
|
+
* @param logEnabled Optional. Determines whether to enable logging. Defaults to `false`.
|
|
540
|
+
* @returns Returns a Promise resolving to the value returned by `asyncFunc` if the condition is true, otherwise returns `undefined`.
|
|
541
|
+
*/
|
|
542
|
+
export declare function conditionallyAsync<T>(condition: boolean, asyncFunc: AsyncFunc<T>, logEnabled?: boolean): Promise<T | undefined>;
|
|
543
|
+
/**
|
|
544
|
+
* Executes an asynchronous function conditionally.
|
|
545
|
+
*
|
|
546
|
+
* @overload
|
|
547
|
+
* @template T The type of value that the `asyncFunc` returns.
|
|
548
|
+
* @param conditionAsyncFunc An async function that returns a boolean that determines whether `asyncFunc` should be executed.
|
|
549
|
+
* @param asyncFunc The async function to execute if the condition is true.
|
|
550
|
+
* @param logEnabled Optional. Determines whether to enable logging. Defaults to `false`.
|
|
551
|
+
* @returns Returns a Promise resolving to the value returned by `asyncFunc` if the condition is true, otherwise returns `undefined`.
|
|
552
|
+
*/
|
|
553
|
+
export declare function conditionallyAsync<T>(conditionAsyncFunc: AsyncBooleanFunc, asyncFunc: AsyncFunc<T>, logEnabled?: boolean): Promise<T | undefined>;
|
|
554
|
+
export {};
|
|
610
555
|
//# sourceMappingURL=generalUtils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generalUtils.d.ts","sourceRoot":"","sources":["../../src/generalUtils.ts"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"generalUtils.d.ts","sourceRoot":"","sources":["../../src/generalUtils.ts"],"names":[],"mappings":"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"}
|