@scandipwa/magento-scripts 2.0.0-alpha.8 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/commands/cli.js +18 -1
- package/lib/commands/logs.js +28 -2
- package/lib/commands/start.js +24 -3
- package/lib/commands/status.js +9 -1
- package/lib/config/config.js +20 -2
- package/lib/config/dependencies-for-platforms.js +1 -1
- package/lib/config/docker.js +94 -54
- package/lib/config/get-project-configuration.js +5 -0
- package/lib/config/index.js +10 -3
- package/lib/config/php/versions/php-7.2.js +1 -0
- package/lib/config/php/versions/php-7.3.js +1 -0
- package/lib/config/php/versions/php-7.4.js +1 -0
- package/lib/config/php/versions/php-8.1.js +1 -0
- package/lib/config/php-config.js +4 -3
- package/lib/config/port-config.js +3 -1
- package/lib/config/services/composer/versions/composer-1.js +13 -0
- package/lib/config/services/composer/versions/composer-2.js +8 -0
- package/lib/config/services/composer/versions/index.js +4 -0
- package/lib/config/services/maildev/index.js +7 -0
- package/lib/config/services/nginx/versions/index.js +3 -0
- package/lib/config/services/nginx/versions/nginx-1.18.js +11 -0
- package/lib/config/{ssl-terminator → services/ssl-terminator}/index.js +3 -0
- package/lib/config/templates/magentorc.template +12 -5
- package/lib/config/templates/nginx.fastcgi_params.template +29 -0
- package/lib/config/templates/php-debug.template.ini +31 -0
- package/lib/config/templates/php-fpm.template.conf +1 -2
- package/lib/config/templates/php.template.ini +5 -201
- package/lib/config/templates/ssl-terminator.template.conf +2 -0
- package/lib/config/templates/varnish.template.vcl +20 -13
- package/lib/config/varnish/varnish-6-0.js +4 -0
- package/lib/config/varnish/varnish-6-6.js +4 -0
- package/lib/config/varnish/varnish-7-0.js +4 -0
- package/lib/config/versions/magento-2.2.10.js +41 -0
- package/lib/config/versions/magento-2.3.0.js +8 -10
- package/lib/config/versions/magento-2.3.1.js +8 -10
- package/lib/config/versions/magento-2.3.2-p1.js +8 -10
- package/lib/config/versions/magento-2.3.2-p2.js +8 -10
- package/lib/config/versions/magento-2.3.2.js +8 -10
- package/lib/config/versions/magento-2.3.3-p1.js +8 -10
- package/lib/config/versions/magento-2.3.3.js +8 -10
- package/lib/config/versions/magento-2.3.4-p1.js +8 -10
- package/lib/config/versions/magento-2.3.4-p2.js +8 -10
- package/lib/config/versions/magento-2.3.4.js +8 -10
- package/lib/config/versions/magento-2.3.5-p1.js +8 -10
- package/lib/config/versions/magento-2.3.5-p2.js +8 -10
- package/lib/config/versions/magento-2.3.5.js +8 -10
- package/lib/config/versions/magento-2.3.6-p1.js +8 -10
- package/lib/config/versions/magento-2.3.6.js +8 -10
- package/lib/config/versions/magento-2.3.7-p1.js +8 -10
- package/lib/config/versions/magento-2.3.7-p2.js +8 -10
- package/lib/config/versions/magento-2.3.7-p3.js +8 -10
- package/lib/config/versions/magento-2.3.7-p4.js +8 -10
- package/lib/config/versions/magento-2.3.7.js +8 -10
- package/lib/config/versions/magento-2.4.0-p1.js +8 -10
- package/lib/config/versions/magento-2.4.0.js +8 -10
- package/lib/config/versions/magento-2.4.1-p1.js +8 -10
- package/lib/config/versions/magento-2.4.1.js +8 -10
- package/lib/config/versions/magento-2.4.2-p1.js +8 -10
- package/lib/config/versions/magento-2.4.2-p2.js +8 -10
- package/lib/config/versions/magento-2.4.2.js +8 -10
- package/lib/config/versions/magento-2.4.3-p1.js +8 -10
- package/lib/config/versions/magento-2.4.3-p2.js +8 -10
- package/lib/config/versions/magento-2.4.3-p3.js +8 -10
- package/lib/config/versions/magento-2.4.3.js +8 -10
- package/lib/config/versions/magento-2.4.4-p1.js +8 -10
- package/lib/config/versions/magento-2.4.4.js +8 -10
- package/lib/config/versions/magento-2.4.5.js +8 -10
- package/lib/tasks/cli/create-bashrc-config.js +4 -2
- package/lib/tasks/composer/local-auth-json.js +1 -1
- package/lib/tasks/database/connect-to-database.js +6 -3
- package/lib/tasks/database/create-magento-database.js +5 -2
- package/lib/tasks/database/create-magento-user.js +50 -0
- package/lib/tasks/database/default-magento-database.js +3 -0
- package/lib/tasks/database/default-magento-user.js +7 -0
- package/lib/tasks/database/import-dump-to-database.js +3 -2
- package/lib/tasks/docker/api.d.ts +25 -1
- package/lib/tasks/docker/api.js +31 -1
- package/lib/tasks/docker/containers/container-api.d.ts +21 -0
- package/lib/tasks/docker/containers/container-api.js +82 -17
- package/lib/tasks/docker/containers/tasks.js +44 -13
- package/lib/tasks/docker/convert-composer-home-to-composer-cache-volume.js +52 -0
- package/lib/tasks/docker/convert-mysql-to-mariadb.js +2 -2
- package/lib/tasks/docker/image/image-api.d.ts +44 -0
- package/lib/tasks/docker/image/image-api.js +30 -2
- package/lib/tasks/docker/index.js +6 -1
- package/lib/tasks/docker/project-image-builder.js +37 -14
- package/lib/tasks/docker/system/index.js +5 -0
- package/lib/tasks/docker/system/system-api.d.ts +71 -0
- package/lib/tasks/docker/system/system-api.js +29 -0
- package/lib/tasks/docker/volume/index.js +2 -1
- package/lib/tasks/docker/volume/tasks.js +67 -9
- package/lib/tasks/docker/volume/volume-api.d.ts +40 -0
- package/lib/tasks/docker/volume/volume-api.js +54 -1
- package/lib/tasks/execute.js +11 -9
- package/lib/tasks/file-system/create-nginx-config.js +3 -5
- package/lib/tasks/file-system/create-php-config.js +2 -23
- package/lib/tasks/file-system/create-php-debug-config.js +45 -0
- package/lib/tasks/file-system/create-php-fpm-config.js +2 -4
- package/lib/tasks/file-system/create-phpstorm-config/exclude-folder-config.js +13 -3
- package/lib/tasks/file-system/create-phpstorm-config/index.js +2 -1
- package/lib/tasks/file-system/create-ssl-terminator-config.js +23 -8
- package/lib/tasks/file-system/create-varnish-config.js +4 -7
- package/lib/tasks/file-system/create-vscode-config.js +2 -1
- package/lib/tasks/file-system/index.js +3 -2
- package/lib/tasks/magento/setup-magento/configure-elasticsearch.js +2 -4
- package/lib/tasks/magento/setup-magento/flush-redis-config.js +3 -6
- package/lib/tasks/magento/setup-magento/index.js +2 -0
- package/lib/tasks/magento/setup-magento/install-magento.js +8 -13
- package/lib/tasks/magento/setup-magento/set-base-url.js +2 -1
- package/lib/tasks/magento/setup-magento/set-mail-config.js +22 -0
- package/lib/tasks/magento/setup-magento/varnish-config.js +4 -9
- package/lib/tasks/magento/setup-magento/waiting-for-varnish.js +15 -16
- package/lib/tasks/php/php-container.js +1 -1
- package/lib/tasks/php/update-env-php.js +3 -5
- package/lib/tasks/{prefix → project-config}/index.js +6 -6
- package/lib/tasks/requirements/composer-credentials.js +7 -3
- package/lib/tasks/requirements/docker/context.js +88 -0
- package/lib/tasks/requirements/docker/index.js +111 -19
- package/lib/tasks/requirements/docker/install.js +21 -7
- package/lib/tasks/requirements/docker/permissions.js +2 -11
- package/lib/tasks/requirements/docker/running-status.js +94 -24
- package/lib/tasks/requirements/docker/version.js +1 -0
- package/lib/tasks/requirements/index.js +0 -2
- package/lib/tasks/requirements/php-version.js +4 -2
- package/lib/tasks/start.js +27 -8
- package/lib/tasks/status/index.js +60 -21
- package/lib/tasks/stop.js +2 -0
- package/lib/tasks/theme/retrieve-theme-data.js +12 -2
- package/lib/util/config-file-validator.js +17 -3
- package/lib/util/execute-in-container.js +35 -5
- package/lib/util/instance-metadata.js +14 -2
- package/lib/util/systemctl.js +62 -13
- package/package.json +2 -2
- package/typings/context.d.ts +11 -0
- package/typings/index.d.ts +46 -1
- package/lib/tasks/requirements/dependency/arch.js +0 -50
- package/lib/tasks/requirements/dependency/centos.js +0 -36
- package/lib/tasks/requirements/dependency/fedora.js +0 -36
- package/lib/tasks/requirements/dependency/index.js +0 -33
- package/lib/tasks/requirements/dependency/mac.js +0 -124
- package/lib/tasks/requirements/dependency/ubuntu.js +0 -83
|
@@ -5,7 +5,6 @@ const { volumeApi, createVolumes } = require('./volume');
|
|
|
5
5
|
const { execAsyncSpawn } = require('../../util/exec-async-command');
|
|
6
6
|
const { containerApi, stopContainers, pullImages } = require('./containers');
|
|
7
7
|
const { importDumpToDatabase, connectToDatabase } = require('../database');
|
|
8
|
-
const { setPrefix } = require('../prefix');
|
|
9
8
|
const getProjectConfiguration = require('../../config/get-project-configuration');
|
|
10
9
|
const { getAvailablePorts, getCachedPorts } = require('../../config/get-port-config');
|
|
11
10
|
const { saveConfiguration } = require('../../config/save-config');
|
|
@@ -21,6 +20,7 @@ const KnownError = require('../../errors/known-error');
|
|
|
21
20
|
const { createCacheFolder } = require('../cache');
|
|
22
21
|
const { getSystemConfigTask } = require('../../config/system-config');
|
|
23
22
|
const sleep = require('../../util/sleep');
|
|
23
|
+
const { setProjectConfigTask } = require('../project-config');
|
|
24
24
|
|
|
25
25
|
/**
|
|
26
26
|
* @type {() => import('listr2').ListrTask<import('../../../typings/context').ListrContext>}
|
|
@@ -203,7 +203,7 @@ Please wait, this will take some time and do not restart the MySQL container unt
|
|
|
203
203
|
getSystemConfigTask(),
|
|
204
204
|
getCachedPorts(),
|
|
205
205
|
stopContainers(),
|
|
206
|
-
|
|
206
|
+
setProjectConfigTask(),
|
|
207
207
|
getProjectConfiguration(),
|
|
208
208
|
// get fresh ports
|
|
209
209
|
getAvailablePorts(),
|
|
@@ -32,3 +32,47 @@ export function ls(
|
|
|
32
32
|
options?: ImagesLsOptions<true>,
|
|
33
33
|
execOptions?: ExecAsyncSpawnOptions<false>
|
|
34
34
|
): Promise<ImagesLsResult[]>
|
|
35
|
+
|
|
36
|
+
export interface ImagesInspectOptions<T extends boolean = false> {
|
|
37
|
+
image: string
|
|
38
|
+
format?: string
|
|
39
|
+
formatToJSON?: T
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export interface ImagesInspectResult {
|
|
43
|
+
Id: string
|
|
44
|
+
RepoTags: string[]
|
|
45
|
+
RepoDigests: string[]
|
|
46
|
+
Parent: string
|
|
47
|
+
Comment: string
|
|
48
|
+
Created: string
|
|
49
|
+
Container: string
|
|
50
|
+
ContainerConfig: unknown
|
|
51
|
+
DockerVersion: string
|
|
52
|
+
Author: string
|
|
53
|
+
Config: {
|
|
54
|
+
Env: string[],
|
|
55
|
+
Cmd: string[]
|
|
56
|
+
WorkingDir: string
|
|
57
|
+
Entrypoint: string[]
|
|
58
|
+
StopSignal: string
|
|
59
|
+
}
|
|
60
|
+
Architecture: string
|
|
61
|
+
Os: string
|
|
62
|
+
Size: number
|
|
63
|
+
VirtualSize: number
|
|
64
|
+
GraphDriver: unknown
|
|
65
|
+
RootFs: unknown
|
|
66
|
+
Metadata: Record<string, unknown>
|
|
67
|
+
CreatedTime: number
|
|
68
|
+
Container: Record<string, unknown>
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export function inspect(
|
|
72
|
+
options?: ImagesInspectOptions,
|
|
73
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
74
|
+
): Promise<string>
|
|
75
|
+
export function inspect(
|
|
76
|
+
options?: ImagesInspectOptions<true>,
|
|
77
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
78
|
+
): Promise<ImagesInspectResult>
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
const { execAsyncSpawn } = require('../../../util/exec-async-command');
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
5
4
|
* @param {import('./image-api').ImagesLsOptions} options
|
|
6
5
|
* @param {import('../../../util/exec-async-command').ExecAsyncSpawnOptions} execOptions
|
|
7
6
|
*/
|
|
@@ -44,6 +43,35 @@ const ls = async (options, execOptions = {}) => {
|
|
|
44
43
|
return execAsyncSpawn(`docker image ls ${args}`, execOptions);
|
|
45
44
|
};
|
|
46
45
|
|
|
46
|
+
/**
|
|
47
|
+
* @param {import('./image-api').ImagesInspectOptions} options
|
|
48
|
+
* @param {import('../../../util/exec-async-command').ExecAsyncSpawnOptions} execOptions
|
|
49
|
+
*/
|
|
50
|
+
const inspect = async (options, execOptions = {}) => {
|
|
51
|
+
const {
|
|
52
|
+
image,
|
|
53
|
+
format,
|
|
54
|
+
formatToJSON = false
|
|
55
|
+
} = options;
|
|
56
|
+
|
|
57
|
+
const formatArg = !formatToJSON && format
|
|
58
|
+
? `--format=${format}`
|
|
59
|
+
: formatToJSON && '--format=\'{{json .}}\'';
|
|
60
|
+
|
|
61
|
+
const args = [
|
|
62
|
+
formatArg,
|
|
63
|
+
image
|
|
64
|
+
].filter(Boolean).join(' ');
|
|
65
|
+
|
|
66
|
+
if (formatToJSON) {
|
|
67
|
+
const result = await execAsyncSpawn(`docker image inspect ${args}`, execOptions);
|
|
68
|
+
return JSON.parse(result);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
return execAsyncSpawn(`docker image inspect ${args}`, execOptions);
|
|
72
|
+
};
|
|
73
|
+
|
|
47
74
|
module.exports = {
|
|
48
|
-
ls
|
|
75
|
+
ls,
|
|
76
|
+
inspect
|
|
49
77
|
};
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
const containers = require('./containers');
|
|
2
2
|
const network = require('./network');
|
|
3
|
+
const volume = require('./volume');
|
|
4
|
+
const dockerApi = require('./api');
|
|
3
5
|
|
|
4
6
|
/**
|
|
5
7
|
* @type {() => import('listr2').ListrTask<import('../../../typings/context').ListrContext>}
|
|
@@ -19,13 +21,16 @@ const startServices = () => ({
|
|
|
19
21
|
* @type {() => import('listr2').ListrTask<import('../../../typings/context').ListrContext>}
|
|
20
22
|
*/
|
|
21
23
|
const stopServices = () => ({
|
|
24
|
+
title: 'Stopping Docker services',
|
|
22
25
|
task: (ctx, task) => task.newListr([
|
|
23
26
|
containers.stopContainers(),
|
|
27
|
+
volume.removeLocalVolumes(),
|
|
24
28
|
network.tasks.removeNetwork()
|
|
25
29
|
])
|
|
26
30
|
});
|
|
27
31
|
|
|
28
32
|
module.exports = {
|
|
29
33
|
startServices,
|
|
30
|
-
stopServices
|
|
34
|
+
stopServices,
|
|
35
|
+
dockerApi
|
|
31
36
|
};
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
const path = require('path');
|
|
2
|
+
const os = require('os');
|
|
1
3
|
const { DockerFileBuilder } = require('../../util/dockerfile-builder');
|
|
2
|
-
const semver = require('semver');
|
|
3
4
|
const { execAsyncSpawn } = require('../../util/exec-async-command');
|
|
4
5
|
const KnownError = require('../../errors/known-error');
|
|
5
6
|
const { runContainerImage } = require('../../util/run-container-image');
|
|
7
|
+
const { imageApi } = require('./image');
|
|
6
8
|
|
|
7
9
|
/**
|
|
8
10
|
* Get enabled extensions list with versions
|
|
@@ -27,15 +29,15 @@ const getEnabledExtensionsFromImage = async (imageWithTag) => {
|
|
|
27
29
|
.reduce((acc, [name, version]) => ({ ...acc, [name]: version }), {});
|
|
28
30
|
};
|
|
29
31
|
|
|
30
|
-
const addExtensionToBuilder = (builder, ctx) => ([extensionName, extensionInstructions]) => {
|
|
32
|
+
const addExtensionToBuilder = (builder, ctx) => async ([extensionName, extensionInstructions]) => {
|
|
31
33
|
const { command, ...extensionInstructionsWithoutCommand } = extensionInstructions;
|
|
32
34
|
let runCommand = '';
|
|
33
35
|
if (typeof command === 'string') {
|
|
34
36
|
runCommand += ` ${command}`;
|
|
35
|
-
} else if (typeof command === 'function') {
|
|
36
|
-
runCommand += ` ${command({ ...extensionInstructionsWithoutCommand, ctx })}`;
|
|
37
|
+
} else if (typeof command === 'function' || command instanceof Promise) {
|
|
38
|
+
runCommand += ` ${await Promise.resolve(command({ ...extensionInstructionsWithoutCommand, ctx }))}`;
|
|
37
39
|
} else {
|
|
38
|
-
runCommand += ` docker-php-ext-install ${extensionInstructionsWithoutCommand.name}`;
|
|
40
|
+
runCommand += ` docker-php-ext-install ${extensionInstructionsWithoutCommand.name || extensionName}`;
|
|
39
41
|
}
|
|
40
42
|
builder
|
|
41
43
|
.comment(`extension ${extensionName} installation command`)
|
|
@@ -49,6 +51,7 @@ const addExtensionToBuilder = (builder, ctx) => ([extensionName, extensionInstru
|
|
|
49
51
|
const buildDockerFileInstructions = async (ctx, { image, tag }) => {
|
|
50
52
|
const { composer } = ctx.config.overridenConfiguration.configuration;
|
|
51
53
|
const existingPHPExtensions = await getEnabledExtensionsFromImage(`${image}:${tag}`);
|
|
54
|
+
const imageDetails = await imageApi.inspect({ image: `${image}:${tag}`, formatToJSON: true });
|
|
52
55
|
|
|
53
56
|
const missingExtensions = Object.entries(
|
|
54
57
|
ctx.config.overridenConfiguration.configuration.php.extensions
|
|
@@ -68,10 +71,6 @@ const buildDockerFileInstructions = async (ctx, { image, tag }) => {
|
|
|
68
71
|
.comment('project image')
|
|
69
72
|
.from({ image, tag });
|
|
70
73
|
|
|
71
|
-
// install bash and patch in image
|
|
72
|
-
dockerFileInstructions
|
|
73
|
-
.run('apk add --no-cache bash patch');
|
|
74
|
-
|
|
75
74
|
if (missingExtensions.length > 0) {
|
|
76
75
|
const allDependencies = missingExtensions.map(
|
|
77
76
|
([_extensionName, extensionInstructions]) => (extensionInstructions.dependencies || [])
|
|
@@ -79,7 +78,9 @@ const buildDockerFileInstructions = async (ctx, { image, tag }) => {
|
|
|
79
78
|
.reduce((acc, val) => acc.concat(val.filter((ex) => !acc.includes(ex))), []);
|
|
80
79
|
|
|
81
80
|
dockerFileInstructions.run(`apk add --no-cache ${allDependencies.join(' ')}`);
|
|
82
|
-
|
|
81
|
+
for (const missingExtensionInstructions of missingExtensions) {
|
|
82
|
+
await addExtensionToBuilder(dockerFileInstructions, ctx)(missingExtensionInstructions);
|
|
83
|
+
}
|
|
83
84
|
}
|
|
84
85
|
|
|
85
86
|
const composerVersion = /^\d$/.test(composer.version)
|
|
@@ -92,17 +93,39 @@ const buildDockerFileInstructions = async (ctx, { image, tag }) => {
|
|
|
92
93
|
.comment('make composer executable')
|
|
93
94
|
.run('chmod +x ./composer')
|
|
94
95
|
.comment('move composer to bin directory')
|
|
95
|
-
.run('mv composer /usr/local/bin/composer')
|
|
96
|
+
.run('mv composer /usr/local/bin/composer')
|
|
97
|
+
.run('mkdir -p /composer/home/cache')
|
|
98
|
+
.env({
|
|
99
|
+
COMPOSER_HOME: '/composer/home',
|
|
100
|
+
COMPOSER_CACHE_DIR: '/composer/home/cache'
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
if (composer.plugins && Object.values(composer.plugins).length > 0) {
|
|
104
|
+
for (const [pluginName, pluginOptions] of Object.entries(composer.plugins)) {
|
|
105
|
+
if (pluginOptions.enabled) {
|
|
106
|
+
dockerFileInstructions
|
|
107
|
+
.comment(`install ${pluginName} composer global package`)
|
|
108
|
+
// eslint-disable-next-line max-len
|
|
109
|
+
.run(`composer global require ${pluginName}${ pluginOptions.options ? ` ${pluginOptions.options}` : '' }${ pluginOptions.options ? ` ${pluginOptions.options}` : ''}`);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
96
113
|
|
|
97
|
-
if (
|
|
114
|
+
if (!ctx.isDockerDesktop) {
|
|
98
115
|
dockerFileInstructions
|
|
99
|
-
.
|
|
100
|
-
.run('composer global require hirak/prestissimo');
|
|
116
|
+
.run(`chown -R ${os.userInfo().uid}:${os.userInfo().gid} /composer/home`);
|
|
101
117
|
}
|
|
102
118
|
|
|
103
119
|
dockerFileInstructions
|
|
104
120
|
.workDir(ctx.config.baseConfig.containerMagentoDir);
|
|
105
121
|
|
|
122
|
+
const imagePathEnv = imageDetails.Config.Env.find((env) => env.startsWith('PATH'));
|
|
123
|
+
|
|
124
|
+
dockerFileInstructions
|
|
125
|
+
.env({
|
|
126
|
+
PATH: `${ imagePathEnv.split('=').pop() }:${ path.join(ctx.config.baseConfig.containerMagentoDir, 'bin') }`
|
|
127
|
+
});
|
|
128
|
+
|
|
106
129
|
return dockerFileInstructions;
|
|
107
130
|
};
|
|
108
131
|
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { ExecAsyncSpawnOptions } from '../../../util/exec-async-command';
|
|
2
|
+
|
|
3
|
+
export interface SystemDFOptions<T extends boolean = false> {
|
|
4
|
+
format?: string
|
|
5
|
+
formatToJSON?: T
|
|
6
|
+
verbose?: boolean
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface SystemDFResult {
|
|
10
|
+
Images: {
|
|
11
|
+
Containers: string
|
|
12
|
+
CreatedAt: string
|
|
13
|
+
CreatedSince: string
|
|
14
|
+
Digest: string
|
|
15
|
+
ID: string
|
|
16
|
+
Repository: string
|
|
17
|
+
SharedSize: string
|
|
18
|
+
Size: string
|
|
19
|
+
Tag: string
|
|
20
|
+
UniqueSize: string
|
|
21
|
+
VirtualSize: string
|
|
22
|
+
}[]
|
|
23
|
+
Containers: {
|
|
24
|
+
Command: string
|
|
25
|
+
CreatedAt: string
|
|
26
|
+
ID: string
|
|
27
|
+
Image: string
|
|
28
|
+
Labels: string
|
|
29
|
+
LocalVolumes: string
|
|
30
|
+
Mounts: string
|
|
31
|
+
Names: string
|
|
32
|
+
Networks: string
|
|
33
|
+
Ports: StreamPipeOptions
|
|
34
|
+
RunningFor: string
|
|
35
|
+
Size: string
|
|
36
|
+
State: string
|
|
37
|
+
Status: string
|
|
38
|
+
}[]
|
|
39
|
+
Volumes: {
|
|
40
|
+
Driver: string
|
|
41
|
+
Labels: string
|
|
42
|
+
Links: string
|
|
43
|
+
Mountpoint: string
|
|
44
|
+
Name: string
|
|
45
|
+
Scope: string
|
|
46
|
+
Size: string
|
|
47
|
+
}[]
|
|
48
|
+
BuildCache: {
|
|
49
|
+
CacheType: string
|
|
50
|
+
CreatedAt: string
|
|
51
|
+
CreatedSince: string
|
|
52
|
+
Description: string
|
|
53
|
+
ID: string
|
|
54
|
+
InUse: string
|
|
55
|
+
LastUsedAt: string
|
|
56
|
+
LastUsedSince: string
|
|
57
|
+
Parent: string
|
|
58
|
+
Shared: string
|
|
59
|
+
Size: string
|
|
60
|
+
UsageCount: string
|
|
61
|
+
}[]
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export function df(
|
|
65
|
+
options?: SystemDFOptions,
|
|
66
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
67
|
+
): Promise<string>
|
|
68
|
+
export function df(
|
|
69
|
+
options?: SystemDFOptions<true>,
|
|
70
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
71
|
+
): Promise<SystemDFResult>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
const { execAsyncSpawn } = require('../../../util/exec-async-command');
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @param {import('./system-api').SystemDFOptions} options
|
|
5
|
+
* @param {import('../../../util/exec-async-command').ExecAsyncSpawnOptions} execOptions
|
|
6
|
+
*/
|
|
7
|
+
const df = async (options, execOptions = {}) => {
|
|
8
|
+
const {
|
|
9
|
+
format,
|
|
10
|
+
formatToJSON,
|
|
11
|
+
verbose
|
|
12
|
+
} = options;
|
|
13
|
+
|
|
14
|
+
const formatArg = !formatToJSON && format
|
|
15
|
+
? `--format=${format}`
|
|
16
|
+
: formatToJSON && '--format=\'{{json .}}\'';
|
|
17
|
+
const verboseArg = verbose && '--verbose';
|
|
18
|
+
|
|
19
|
+
const args = [
|
|
20
|
+
formatArg,
|
|
21
|
+
verboseArg
|
|
22
|
+
].filter(Boolean).join(' ');
|
|
23
|
+
|
|
24
|
+
return execAsyncSpawn(`docker system df ${args}`, execOptions);
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
module.exports = {
|
|
28
|
+
df
|
|
29
|
+
};
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
const volumeApi = require('./volume-api');
|
|
2
|
-
const { createVolumes, removeVolumes } = require('./tasks');
|
|
2
|
+
const { createVolumes, removeVolumes, removeLocalVolumes } = require('./tasks');
|
|
3
3
|
|
|
4
4
|
module.exports = {
|
|
5
5
|
createVolumes,
|
|
6
6
|
removeVolumes,
|
|
7
|
+
removeLocalVolumes,
|
|
7
8
|
volumeApi
|
|
8
9
|
};
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
const
|
|
2
|
-
const
|
|
1
|
+
const fs = require('fs');
|
|
2
|
+
const pathExists = require('../../../util/path-exists');
|
|
3
|
+
const { containerApi } = require('../containers');
|
|
4
|
+
const volumeApi = require('./volume-api');
|
|
3
5
|
|
|
4
6
|
/**
|
|
5
7
|
* @type {() => import('listr2').ListrTask<import('../../../../typings/context').ListrContext>}
|
|
@@ -7,10 +9,12 @@ const { create } = require('./volume-api');
|
|
|
7
9
|
const createVolumes = () => ({
|
|
8
10
|
title: 'Creating volumes',
|
|
9
11
|
task: async ({ config: { docker } }, task) => {
|
|
10
|
-
const volumeList =
|
|
12
|
+
const volumeList = await volumeApi.ls({
|
|
13
|
+
formatToJSON: true
|
|
14
|
+
});
|
|
11
15
|
|
|
12
16
|
const missingVolumes = Object.values(docker.volumes).filter(
|
|
13
|
-
({ name }) => !volumeList.
|
|
17
|
+
({ name }) => !volumeList.some((v) => v.Name === name)
|
|
14
18
|
);
|
|
15
19
|
|
|
16
20
|
if (missingVolumes.length === 0) {
|
|
@@ -18,7 +22,15 @@ const createVolumes = () => ({
|
|
|
18
22
|
return;
|
|
19
23
|
}
|
|
20
24
|
|
|
21
|
-
await Promise.all(missingVolumes.map((volume) =>
|
|
25
|
+
await Promise.all(missingVolumes.map(async (volume) => {
|
|
26
|
+
if (volume.opt && volume.opt.device && !await pathExists(volume.opt.device)) {
|
|
27
|
+
await fs.promises.mkdir(volume.opt.device, {
|
|
28
|
+
recursive: true
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}));
|
|
32
|
+
|
|
33
|
+
await Promise.all(missingVolumes.map((volume) => volumeApi.create(volume)));
|
|
22
34
|
}
|
|
23
35
|
});
|
|
24
36
|
|
|
@@ -28,10 +40,12 @@ const createVolumes = () => ({
|
|
|
28
40
|
const removeVolumes = () => ({
|
|
29
41
|
title: 'Removing volumes',
|
|
30
42
|
task: async ({ config: { docker } }, task) => {
|
|
31
|
-
const volumeList =
|
|
43
|
+
const volumeList = await volumeApi.ls({
|
|
44
|
+
formatToJSON: true
|
|
45
|
+
});
|
|
32
46
|
|
|
33
47
|
const deployedVolumes = Object.values(docker.volumes).filter(
|
|
34
|
-
({ name }) => volumeList.
|
|
48
|
+
({ name }) => volumeList.some((v) => v.Name === name)
|
|
35
49
|
);
|
|
36
50
|
|
|
37
51
|
if (deployedVolumes.length === 0) {
|
|
@@ -39,11 +53,55 @@ const removeVolumes = () => ({
|
|
|
39
53
|
return;
|
|
40
54
|
}
|
|
41
55
|
|
|
42
|
-
await
|
|
56
|
+
await volumeApi.rm({
|
|
57
|
+
volumes: deployedVolumes.map(({ name }) => name)
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* @type {() => import('listr2').ListrTask<import('../../../../typings/context').ListrContext>}
|
|
64
|
+
*/
|
|
65
|
+
const removeLocalVolumes = () => ({
|
|
66
|
+
title: 'Removing local volumes',
|
|
67
|
+
task: async (ctx, task) => {
|
|
68
|
+
const volumeList = await volumeApi.ls({
|
|
69
|
+
formatToJSON: true
|
|
70
|
+
});
|
|
71
|
+
const { volumes } = ctx.config.docker;
|
|
72
|
+
|
|
73
|
+
const localVolumes = Object.values(volumes).filter(
|
|
74
|
+
(volume) => volume.opt && volume.opt.device
|
|
75
|
+
);
|
|
76
|
+
|
|
77
|
+
const existingLocalVolumes = localVolumes.filter(
|
|
78
|
+
(volume) => volumeList.some((v) => v.Name === volume.name)
|
|
79
|
+
);
|
|
80
|
+
|
|
81
|
+
if (existingLocalVolumes.length > 0) {
|
|
82
|
+
const existingLocalVolumesDetails = await Promise.all(
|
|
83
|
+
existingLocalVolumes.map((v) => volumeApi.inspect({ volume: v.name, formatToJSON: true }))
|
|
84
|
+
);
|
|
85
|
+
|
|
86
|
+
await Promise.all(existingLocalVolumesDetails.map(async (v) => {
|
|
87
|
+
if (v.Containers && Object.entries(v.Containers).length > 0) {
|
|
88
|
+
await Promise.all(Object.values(v.Containers).map(async (c) => {
|
|
89
|
+
await containerApi.stop([c.Name]);
|
|
90
|
+
await containerApi.rm([c.Name]);
|
|
91
|
+
}));
|
|
92
|
+
}
|
|
93
|
+
}));
|
|
94
|
+
await volumeApi.rm({
|
|
95
|
+
volumes: existingLocalVolumes.map((volume) => volume.name)
|
|
96
|
+
});
|
|
97
|
+
} else {
|
|
98
|
+
task.skip();
|
|
99
|
+
}
|
|
43
100
|
}
|
|
44
101
|
});
|
|
45
102
|
|
|
46
103
|
module.exports = {
|
|
47
104
|
createVolumes,
|
|
48
|
-
removeVolumes
|
|
105
|
+
removeVolumes,
|
|
106
|
+
removeLocalVolumes
|
|
49
107
|
};
|
|
@@ -37,3 +37,43 @@ export function create(
|
|
|
37
37
|
options?: VolumeCreateOptions,
|
|
38
38
|
execOptions?: ExecAsyncSpawnOptions<false>
|
|
39
39
|
): Promise<string>
|
|
40
|
+
|
|
41
|
+
export interface VolumeRmOptions {
|
|
42
|
+
force?: boolean
|
|
43
|
+
volumes: string[]
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export function rm(
|
|
47
|
+
options?: VolumeRmOptions,
|
|
48
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
49
|
+
): Promise<string>
|
|
50
|
+
|
|
51
|
+
export interface VolumeInspectOptions<T extends boolean = false> {
|
|
52
|
+
volume: string
|
|
53
|
+
format?: string
|
|
54
|
+
formatToJSON?: T
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export interface VolumeInspectResult {
|
|
58
|
+
CreatedAt: string
|
|
59
|
+
Driver: string
|
|
60
|
+
Labels: unknown
|
|
61
|
+
Mountpoint: string
|
|
62
|
+
Name: string
|
|
63
|
+
Options: unknown
|
|
64
|
+
Scope: string
|
|
65
|
+
CreatedTime: number
|
|
66
|
+
Containers: Record<string, {
|
|
67
|
+
Name: string
|
|
68
|
+
Destination: string
|
|
69
|
+
}>
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
export function inspect(
|
|
73
|
+
options?: VolumeInspectOptions,
|
|
74
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
75
|
+
): Promise<string>
|
|
76
|
+
export function inspect(
|
|
77
|
+
options?: VolumeInspectOptions<true>,
|
|
78
|
+
execOptions?: ExecAsyncSpawnOptions<false>
|
|
79
|
+
): Promise<VolumeInspectResult>
|
|
@@ -60,7 +60,60 @@ const ls = async (options, execOptions = {}) => {
|
|
|
60
60
|
return execAsyncSpawn(`docker volume ls ${args}`, execOptions);
|
|
61
61
|
};
|
|
62
62
|
|
|
63
|
+
/**
|
|
64
|
+
* @param {import('./volume-api').VolumeRmOptions} options
|
|
65
|
+
* @param {import('../../../util/exec-async-command').ExecAsyncSpawnOptions} execOptions
|
|
66
|
+
*/
|
|
67
|
+
const rm = async (options, execOptions = {}) => {
|
|
68
|
+
const {
|
|
69
|
+
force,
|
|
70
|
+
volumes
|
|
71
|
+
} = options;
|
|
72
|
+
|
|
73
|
+
const forceArg = force && '--force';
|
|
74
|
+
|
|
75
|
+
const command = [
|
|
76
|
+
'docker',
|
|
77
|
+
'volume',
|
|
78
|
+
'rm',
|
|
79
|
+
forceArg,
|
|
80
|
+
...volumes
|
|
81
|
+
].filter(Boolean).join(' ');
|
|
82
|
+
|
|
83
|
+
return execAsyncSpawn(command, execOptions);
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* @param {import('./volume-api').VolumeInspectOptions} options
|
|
88
|
+
* @param {import('../../../util/exec-async-command').ExecAsyncSpawnOptions} execOptions
|
|
89
|
+
*/
|
|
90
|
+
const inspect = async (options, execOptions = {}) => {
|
|
91
|
+
const {
|
|
92
|
+
volume,
|
|
93
|
+
format,
|
|
94
|
+
formatToJSON = false
|
|
95
|
+
} = options;
|
|
96
|
+
|
|
97
|
+
const formatArg = !formatToJSON && format
|
|
98
|
+
? `--format=${format}`
|
|
99
|
+
: formatToJSON && '--format=\'{{json .}}\'';
|
|
100
|
+
|
|
101
|
+
const args = [
|
|
102
|
+
formatArg,
|
|
103
|
+
volume
|
|
104
|
+
].filter(Boolean).join(' ');
|
|
105
|
+
|
|
106
|
+
if (formatToJSON) {
|
|
107
|
+
const result = await execAsyncSpawn(`docker volume inspect ${args}`, execOptions);
|
|
108
|
+
return JSON.parse(result);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return execAsyncSpawn(`docker volume inspect ${args}`, execOptions);
|
|
112
|
+
};
|
|
113
|
+
|
|
63
114
|
module.exports = {
|
|
64
115
|
create,
|
|
65
|
-
ls
|
|
116
|
+
ls,
|
|
117
|
+
rm,
|
|
118
|
+
inspect
|
|
66
119
|
};
|
package/lib/tasks/execute.js
CHANGED
|
@@ -5,9 +5,9 @@ const getMagentoVersionConfig = require('../config/get-magento-version-config');
|
|
|
5
5
|
const checkConfigurationFile = require('../config/check-configuration-file');
|
|
6
6
|
const getProjectConfiguration = require('../config/get-project-configuration');
|
|
7
7
|
const { getCachedPorts } = require('../config/get-port-config');
|
|
8
|
-
const executeInContainer = require('../util/execute-in-container');
|
|
8
|
+
const { executeInContainer, runInContainer } = require('../util/execute-in-container');
|
|
9
9
|
const { containerApi } = require('./docker/containers');
|
|
10
|
-
const
|
|
10
|
+
const dockerNetwork = require('./docker/network');
|
|
11
11
|
const KnownError = require('../errors/known-error');
|
|
12
12
|
|
|
13
13
|
/**
|
|
@@ -21,7 +21,8 @@ const executeTask = async (argv) => {
|
|
|
21
21
|
getMagentoVersionConfig(),
|
|
22
22
|
checkConfigurationFile(),
|
|
23
23
|
getProjectConfiguration(),
|
|
24
|
-
getCachedPorts()
|
|
24
|
+
getCachedPorts(),
|
|
25
|
+
dockerNetwork.tasks.createNetwork()
|
|
25
26
|
], {
|
|
26
27
|
concurrent: false,
|
|
27
28
|
exitOnError: true,
|
|
@@ -68,7 +69,8 @@ const executeTask = async (argv) => {
|
|
|
68
69
|
logger.logN(`Executing container ${logger.style.misc(container._)} (command: ${logger.style.command(argv.commands.join(' '))})`);
|
|
69
70
|
const result = await executeInContainer({
|
|
70
71
|
containerName: container.name,
|
|
71
|
-
commands: argv.commands
|
|
72
|
+
commands: argv.commands,
|
|
73
|
+
user: container.user
|
|
72
74
|
});
|
|
73
75
|
|
|
74
76
|
return result;
|
|
@@ -76,12 +78,12 @@ const executeTask = async (argv) => {
|
|
|
76
78
|
|
|
77
79
|
if (container.name.endsWith('php')) {
|
|
78
80
|
logger.logN(`Starting container ${logger.style.misc(container._)} with command: ${logger.style.command(argv.commands.join(' '))}`);
|
|
79
|
-
const result = await
|
|
80
|
-
ctx,
|
|
81
|
-
argv.commands.join(' '),
|
|
81
|
+
const result = await runInContainer(
|
|
82
82
|
{
|
|
83
|
-
|
|
84
|
-
|
|
83
|
+
...container,
|
|
84
|
+
name: `${container.name}_exec-${Date.now()}`
|
|
85
|
+
},
|
|
86
|
+
argv.commands
|
|
85
87
|
);
|
|
86
88
|
|
|
87
89
|
return result;
|
|
@@ -14,7 +14,7 @@ const createNginxConfig = () => ({
|
|
|
14
14
|
overridenConfiguration,
|
|
15
15
|
baseConfig
|
|
16
16
|
},
|
|
17
|
-
|
|
17
|
+
isDockerDesktop
|
|
18
18
|
} = ctx;
|
|
19
19
|
|
|
20
20
|
const {
|
|
@@ -23,10 +23,8 @@ const createNginxConfig = () => ({
|
|
|
23
23
|
}
|
|
24
24
|
} = overridenConfiguration;
|
|
25
25
|
|
|
26
|
-
const
|
|
27
|
-
const
|
|
28
|
-
const hostMachine = isNativeLinux ? '127.0.0.1' : 'host.docker.internal';
|
|
29
|
-
const hostPort = isNativeLinux ? ports.app : 80;
|
|
26
|
+
const hostMachine = !isDockerDesktop ? '127.0.0.1' : 'host.docker.internal';
|
|
27
|
+
const hostPort = !isDockerDesktop ? ports.app : 80;
|
|
30
28
|
|
|
31
29
|
try {
|
|
32
30
|
await setConfigFile({
|