From ffe16df3037dfa6d5fcc181206d699ea723c377d Mon Sep 17 00:00:00 2001
From: Paul O'Connor <465717+pauloconnor@users.noreply.github.com>
Date: Wed, 6 Dec 2023 14:40:14 +0000
Subject: [PATCH] Fix: Make docker-compose cwd aware
---
.github/workflows/main.yml | 7 +-
action.yml | 4 +
main.js | 1 +
node_modules/.package-lock.json | 6 +-
node_modules/.yarn-integrity | 171 ++++++
.../eslint-utils/node_modules/.bin/eslint | 1 +
.../acorn-jsx/node_modules/.bin/acorn | 1 +
.../cross-spawn/node_modules/.bin/node-which | 1 +
node_modules/docker-compose/CHANGELOG.md | 14 +
.../community-samples/readme.md | 22 -
.../docker-compose/dist/src/index.d.ts | 137 -----
node_modules/docker-compose/dist/src/index.js | 488 ---------------
.../docker-compose/dist/src/map-ports.d.ts | 11 -
.../docker-compose/dist/src/map-ports.js | 27 -
.../docker-compose/dist/src/v2-map-ports.d.ts | 11 -
.../docker-compose/dist/src/v2-map-ports.js | 27 -
node_modules/docker-compose/dist/src/v2.d.ts | 137 -----
node_modules/docker-compose/dist/src/v2.js | 494 ---------------
node_modules/docker-compose/dist/v2.d.ts | 31 +-
node_modules/docker-compose/dist/v2.js | 34 +-
node_modules/docker-compose/package.json | 13 +-
node_modules/docker-compose/readme.md | 22 +-
node_modules/docker-compose/src/index.ts | 565 -----------------
node_modules/docker-compose/src/map-ports.ts | 38 --
.../docker-compose/src/v2-map-ports.ts | 38 --
node_modules/docker-compose/src/v2.ts | 575 ------------------
node_modules/docker-compose/tsconfig.json | 3 +-
.../node_modules/.bin/eslint | 1 +
.../node_modules/.bin/prettier | 1 +
node_modules/espree/node_modules/.bin/acorn | 1 +
package-lock.json | 14 +-
package.json | 2 +-
post.js | 1 +
utils.js | 2 +-
34 files changed, 289 insertions(+), 2612 deletions(-)
create mode 100644 node_modules/.yarn-integrity
create mode 120000 node_modules/@eslint-community/eslint-utils/node_modules/.bin/eslint
create mode 120000 node_modules/acorn-jsx/node_modules/.bin/acorn
create mode 120000 node_modules/cross-spawn/node_modules/.bin/node-which
delete mode 100644 node_modules/docker-compose/community-samples/readme.md
delete mode 100644 node_modules/docker-compose/dist/src/index.d.ts
delete mode 100644 node_modules/docker-compose/dist/src/index.js
delete mode 100644 node_modules/docker-compose/dist/src/map-ports.d.ts
delete mode 100644 node_modules/docker-compose/dist/src/map-ports.js
delete mode 100644 node_modules/docker-compose/dist/src/v2-map-ports.d.ts
delete mode 100644 node_modules/docker-compose/dist/src/v2-map-ports.js
delete mode 100644 node_modules/docker-compose/dist/src/v2.d.ts
delete mode 100644 node_modules/docker-compose/dist/src/v2.js
delete mode 100644 node_modules/docker-compose/src/index.ts
delete mode 100644 node_modules/docker-compose/src/map-ports.ts
delete mode 100644 node_modules/docker-compose/src/v2-map-ports.ts
delete mode 100644 node_modules/docker-compose/src/v2.ts
create mode 120000 node_modules/eslint-plugin-prettier/node_modules/.bin/eslint
create mode 120000 node_modules/eslint-plugin-prettier/node_modules/.bin/prettier
create mode 120000 node_modules/espree/node_modules/.bin/acorn
diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml
index d73b94a..1629983 100644
--- a/.github/workflows/main.yml
+++ b/.github/workflows/main.yml
@@ -16,22 +16,26 @@ jobs:
- run: npm install
- uses: ./
with:
- compose-file: "./docker/docker-compose.yml"
+ compose-file: "${{ github.workspace }}/docker/docker-compose.yml"
+ cwd: "${{ github.workspace }}"
services: |
helloworld2
helloworld3
- uses: ./
with:
compose-file: "./docker/docker-compose.yml"
+ cwd: "${{ github.workspace }}"
down-flags: "--volumes"
- uses: ./
with:
compose-file: "./docker/docker-compose.yml"
compose-flags: "--profile profile-1"
+ cwd: "${{ github.workspace }}"
down-flags: "--volumes"
- uses: ./
with:
compose-file: "./docker/docker-compose-with-env.yml"
+ cwd: "${{ github.workspace }}"
env:
IMAGE_NAME: hello-world
- uses: ./
@@ -39,6 +43,7 @@ jobs:
compose-file: |
./docker/docker-compose.yml
./docker/docker-compose.ci.yml
+ cwd: "${{ github.workspace }}"
services: |
helloworld2
helloworld4
diff --git a/action.yml b/action.yml
index 41469ba..60441d4 100644
--- a/action.yml
+++ b/action.yml
@@ -9,6 +9,10 @@ inputs:
description: "additional options to pass to `docker-compose` command"
required: false
default: ""
+ cwd: # id of input
+ description: "Current working directory"
+ required: false
+ default: ""
down-flags: # id of input
description: "additional options to pass to `docker-compose down` command"
required: false
diff --git a/main.js b/main.js
index da08d76..c87bc42 100644
--- a/main.js
+++ b/main.js
@@ -20,6 +20,7 @@ try {
const options = {
config: composeFiles,
+ cwd: core.getInput("cwd"),
log: true,
composeOptions: utils.parseFlags(core.getInput("compose-flags")),
commandOptions: utils.parseFlags(core.getInput("up-flags")),
diff --git a/node_modules/.package-lock.json b/node_modules/.package-lock.json
index 59edfd4..d63dfb3 100644
--- a/node_modules/.package-lock.json
+++ b/node_modules/.package-lock.json
@@ -454,9 +454,9 @@
"integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ=="
},
"node_modules/docker-compose": {
- "version": "0.24.1",
- "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.1.tgz",
- "integrity": "sha512-CVphzCi0Hmw/0CHlAzgiwhLsJjFRqnvpBYMYbf63bz6MON69ElgrfrgQTmgPtEjbifjgaptu3+Gea62vI+9jiA==",
+ "version": "0.24.3",
+ "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.3.tgz",
+ "integrity": "sha512-x3/QN3AIOMe7j2c8f/jcycizMft7dl8MluoB9OGPAYCyKHHiPUFqI9GjCcsU0kYy24vYKMCcfR6+5ZaEyQlrxg==",
"dependencies": {
"yaml": "^2.2.2"
},
diff --git a/node_modules/.yarn-integrity b/node_modules/.yarn-integrity
new file mode 100644
index 0000000..f254f1e
--- /dev/null
+++ b/node_modules/.yarn-integrity
@@ -0,0 +1,171 @@
+{
+ "systemParams": "darwin-arm64-93",
+ "modulesFolders": [
+ "node_modules"
+ ],
+ "flags": [],
+ "linkedModules": [],
+ "topLevelPatterns": [
+ "@actions/core@^1.8.2",
+ "@actions/github@^4.0.0",
+ "docker-compose@^0.24.3",
+ "eslint-config-prettier@^8.5.0",
+ "eslint-plugin-prettier@^4.2.1",
+ "eslint@^8.24.0",
+ "prettier@^2.7.1"
+ ],
+ "lockfileEntries": {
+ "@aashutoshrathi/word-wrap@^1.2.3": "https://registry.yarnpkg.com/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz#bd9154aec9983f77b3a034ecaa015c2e4201f6cf",
+ "@actions/core@^1.8.2": "https://registry.yarnpkg.com/@actions/core/-/core-1.10.1.tgz#61108e7ac40acae95ee36da074fa5850ca4ced8a",
+ "@actions/github@^4.0.0": "https://registry.yarnpkg.com/@actions/github/-/github-4.0.0.tgz#d520483151a2bf5d2dc9cd0f20f9ac3a2e458816",
+ "@actions/http-client@^1.0.8": "https://registry.yarnpkg.com/@actions/http-client/-/http-client-1.0.11.tgz#c58b12e9aa8b159ee39e7dd6cbd0e91d905633c0",
+ "@actions/http-client@^2.0.1": "https://registry.yarnpkg.com/@actions/http-client/-/http-client-2.2.0.tgz#f8239f375be6185fcd07765efdcf0031ad5df1a0",
+ "@eslint-community/eslint-utils@^4.2.0": "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59",
+ "@eslint-community/regexpp@^4.6.1": "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63",
+ "@eslint/eslintrc@^2.1.4": "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.1.4.tgz#388a269f0f25c1b6adc317b5a2c55714894c70ad",
+ "@eslint/js@8.55.0": "https://registry.yarnpkg.com/@eslint/js/-/js-8.55.0.tgz#b721d52060f369aa259cf97392403cb9ce892ec6",
+ "@fastify/busboy@^2.0.0": "https://registry.yarnpkg.com/@fastify/busboy/-/busboy-2.1.0.tgz#0709e9f4cb252351c609c6e6d8d6779a8d25edff",
+ "@humanwhocodes/config-array@^0.11.13": "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.13.tgz#075dc9684f40a531d9b26b0822153c1e832ee297",
+ "@humanwhocodes/module-importer@^1.0.1": "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c",
+ "@humanwhocodes/object-schema@^2.0.1": "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz#e5211452df060fa8522b55c7b3c0c4d1981cb044",
+ "@nodelib/fs.scandir@2.1.5": "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5",
+ "@nodelib/fs.stat@2.0.5": "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b",
+ "@nodelib/fs.walk@^1.2.8": "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a",
+ "@octokit/auth-token@^2.4.4": "https://registry.yarnpkg.com/@octokit/auth-token/-/auth-token-2.5.0.tgz#27c37ea26c205f28443402477ffd261311f21e36",
+ "@octokit/core@^3.0.0": "https://registry.yarnpkg.com/@octokit/core/-/core-3.6.0.tgz#3376cb9f3008d9b3d110370d90e0a1fcd5fe6085",
+ "@octokit/endpoint@^6.0.1": "https://registry.yarnpkg.com/@octokit/endpoint/-/endpoint-6.0.12.tgz#3b4d47a4b0e79b1027fb8d75d4221928b2d05658",
+ "@octokit/graphql@^4.5.8": "https://registry.yarnpkg.com/@octokit/graphql/-/graphql-4.8.0.tgz#664d9b11c0e12112cbf78e10f49a05959aa22cc3",
+ "@octokit/openapi-types@^12.11.0": "https://registry.yarnpkg.com/@octokit/openapi-types/-/openapi-types-12.11.0.tgz#da5638d64f2b919bca89ce6602d059f1b52d3ef0",
+ "@octokit/plugin-paginate-rest@^2.2.3": "https://registry.yarnpkg.com/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-2.21.3.tgz#7f12532797775640dbb8224da577da7dc210c87e",
+ "@octokit/plugin-rest-endpoint-methods@^4.0.0": "https://registry.yarnpkg.com/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-4.15.1.tgz#91a064bee99d0ffcef74a04357e1cf15c27d1cd0",
+ "@octokit/request-error@^2.0.5": "https://registry.yarnpkg.com/@octokit/request-error/-/request-error-2.1.0.tgz#9e150357831bfc788d13a4fd4b1913d60c74d677",
+ "@octokit/request-error@^2.1.0": "https://registry.yarnpkg.com/@octokit/request-error/-/request-error-2.1.0.tgz#9e150357831bfc788d13a4fd4b1913d60c74d677",
+ "@octokit/request@^5.6.0": "https://registry.yarnpkg.com/@octokit/request/-/request-5.6.3.tgz#19a022515a5bba965ac06c9d1334514eb50c48b0",
+ "@octokit/request@^5.6.3": "https://registry.yarnpkg.com/@octokit/request/-/request-5.6.3.tgz#19a022515a5bba965ac06c9d1334514eb50c48b0",
+ "@octokit/types@^6.0.3": "https://registry.yarnpkg.com/@octokit/types/-/types-6.41.0.tgz#e58ef78d78596d2fb7df9c6259802464b5f84a04",
+ "@octokit/types@^6.13.0": "https://registry.yarnpkg.com/@octokit/types/-/types-6.41.0.tgz#e58ef78d78596d2fb7df9c6259802464b5f84a04",
+ "@octokit/types@^6.16.1": "https://registry.yarnpkg.com/@octokit/types/-/types-6.41.0.tgz#e58ef78d78596d2fb7df9c6259802464b5f84a04",
+ "@octokit/types@^6.40.0": "https://registry.yarnpkg.com/@octokit/types/-/types-6.41.0.tgz#e58ef78d78596d2fb7df9c6259802464b5f84a04",
+ "@ungap/structured-clone@^1.2.0": "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406",
+ "acorn-jsx@^5.3.2": "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937",
+ "acorn@^8.9.0": "https://registry.yarnpkg.com/acorn/-/acorn-8.11.2.tgz#ca0d78b51895be5390a5903c5b3bdcdaf78ae40b",
+ "ajv@^6.12.4": "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4",
+ "ansi-regex@^5.0.1": "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304",
+ "ansi-styles@^4.1.0": "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937",
+ "argparse@^2.0.1": "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38",
+ "balanced-match@^1.0.0": "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee",
+ "before-after-hook@^2.2.0": "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.3.tgz#c51e809c81a4e354084422b9b26bad88249c517c",
+ "brace-expansion@^1.1.7": "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd",
+ "callsites@^3.0.0": "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73",
+ "chalk@^4.0.0": "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01",
+ "color-convert@^2.0.1": "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3",
+ "color-name@~1.1.4": "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2",
+ "concat-map@0.0.1": "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b",
+ "cross-spawn@^7.0.2": "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6",
+ "debug@^4.1.1": "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865",
+ "debug@^4.3.2": "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865",
+ "deep-is@^0.1.3": "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831",
+ "deprecation@^2.0.0": "https://registry.yarnpkg.com/deprecation/-/deprecation-2.3.1.tgz#6368cbdb40abf3373b525ac87e4a260c3a700919",
+ "deprecation@^2.3.1": "https://registry.yarnpkg.com/deprecation/-/deprecation-2.3.1.tgz#6368cbdb40abf3373b525ac87e4a260c3a700919",
+ "docker-compose@^0.24.3": "https://registry.yarnpkg.com/docker-compose/-/docker-compose-0.24.3.tgz#298d7bb4aaf37b3b45d0e4ef55c7f58ccc39cca9",
+ "doctrine@^3.0.0": "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961",
+ "escape-string-regexp@^4.0.0": "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34",
+ "eslint-config-prettier@^8.5.0": "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.10.0.tgz#3a06a662130807e2502fc3ff8b4143d8a0658e11",
+ "eslint-plugin-prettier@^4.2.1": "https://registry.yarnpkg.com/eslint-plugin-prettier/-/eslint-plugin-prettier-4.2.1.tgz#651cbb88b1dab98bfd42f017a12fa6b2d993f94b",
+ "eslint-scope@^7.2.2": "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.2.2.tgz#deb4f92563390f32006894af62a22dba1c46423f",
+ "eslint-visitor-keys@^3.3.0": "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800",
+ "eslint-visitor-keys@^3.4.1": "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800",
+ "eslint-visitor-keys@^3.4.3": "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800",
+ "eslint@^8.24.0": "https://registry.yarnpkg.com/eslint/-/eslint-8.55.0.tgz#078cb7b847d66f2c254ea1794fa395bf8e7e03f8",
+ "espree@^9.6.0": "https://registry.yarnpkg.com/espree/-/espree-9.6.1.tgz#a2a17b8e434690a5432f2f8018ce71d331a48c6f",
+ "espree@^9.6.1": "https://registry.yarnpkg.com/espree/-/espree-9.6.1.tgz#a2a17b8e434690a5432f2f8018ce71d331a48c6f",
+ "esquery@^1.4.2": "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b",
+ "esrecurse@^4.3.0": "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921",
+ "estraverse@^5.1.0": "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123",
+ "estraverse@^5.2.0": "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123",
+ "esutils@^2.0.2": "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64",
+ "fast-deep-equal@^3.1.1": "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525",
+ "fast-deep-equal@^3.1.3": "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525",
+ "fast-diff@^1.1.2": "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.3.0.tgz#ece407fa550a64d638536cd727e129c61616e0f0",
+ "fast-json-stable-stringify@^2.0.0": "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633",
+ "fast-levenshtein@^2.0.6": "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917",
+ "fastq@^1.6.0": "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a",
+ "file-entry-cache@^6.0.1": "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027",
+ "find-up@^5.0.0": "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc",
+ "flat-cache@^3.0.4": "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.2.0.tgz#2c0c2d5040c99b1632771a9d105725c0115363ee",
+ "flatted@^3.2.9": "https://registry.yarnpkg.com/flatted/-/flatted-3.2.9.tgz#7eb4c67ca1ba34232ca9d2d93e9886e611ad7daf",
+ "fs.realpath@^1.0.0": "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f",
+ "glob-parent@^6.0.2": "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3",
+ "glob@^7.1.3": "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b",
+ "globals@^13.19.0": "https://registry.yarnpkg.com/globals/-/globals-13.23.0.tgz#ef31673c926a0976e1f61dab4dca57e0c0a8af02",
+ "graphemer@^1.4.0": "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6",
+ "has-flag@^4.0.0": "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b",
+ "ignore@^5.2.0": "https://registry.yarnpkg.com/ignore/-/ignore-5.3.0.tgz#67418ae40d34d6999c95ff56016759c718c82f78",
+ "import-fresh@^3.2.1": "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b",
+ "imurmurhash@^0.1.4": "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea",
+ "inflight@^1.0.4": "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9",
+ "inherits@2": "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c",
+ "is-extglob@^2.1.1": "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2",
+ "is-glob@^4.0.0": "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084",
+ "is-glob@^4.0.3": "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084",
+ "is-path-inside@^3.0.3": "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283",
+ "is-plain-object@^5.0.0": "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-5.0.0.tgz#4427f50ab3429e9025ea7d52e9043a9ef4159344",
+ "isexe@^2.0.0": "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10",
+ "js-yaml@^4.1.0": "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602",
+ "json-buffer@3.0.1": "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13",
+ "json-schema-traverse@^0.4.1": "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660",
+ "json-stable-stringify-without-jsonify@^1.0.1": "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651",
+ "keyv@^4.5.3": "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93",
+ "levn@^0.4.1": "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade",
+ "locate-path@^6.0.0": "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286",
+ "lodash.merge@^4.6.2": "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a",
+ "minimatch@^3.0.5": "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b",
+ "minimatch@^3.1.1": "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b",
+ "minimatch@^3.1.2": "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b",
+ "ms@2.1.2": "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009",
+ "natural-compare@^1.4.0": "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7",
+ "node-fetch@^2.6.7": "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d",
+ "once@^1.3.0": "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1",
+ "once@^1.4.0": "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1",
+ "optionator@^0.9.3": "https://registry.yarnpkg.com/optionator/-/optionator-0.9.3.tgz#007397d44ed1872fdc6ed31360190f81814e2c64",
+ "p-limit@^3.0.2": "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b",
+ "p-locate@^5.0.0": "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834",
+ "parent-module@^1.0.0": "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2",
+ "path-exists@^4.0.0": "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3",
+ "path-is-absolute@^1.0.0": "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f",
+ "path-key@^3.1.0": "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375",
+ "prelude-ls@^1.2.1": "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396",
+ "prettier-linter-helpers@^1.0.0": "https://registry.yarnpkg.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz#d23d41fe1375646de2d0104d3454a3008802cf7b",
+ "prettier@^2.7.1": "https://registry.yarnpkg.com/prettier/-/prettier-2.8.8.tgz#e8c5d7e98a4305ffe3de2e1fc4aca1a71c28b1da",
+ "punycode@^2.1.0": "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5",
+ "queue-microtask@^1.2.2": "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243",
+ "resolve-from@^4.0.0": "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6",
+ "reusify@^1.0.4": "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76",
+ "rimraf@^3.0.2": "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a",
+ "run-parallel@^1.1.9": "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee",
+ "shebang-command@^2.0.0": "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea",
+ "shebang-regex@^3.0.0": "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172",
+ "strip-ansi@^6.0.1": "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9",
+ "strip-json-comments@^3.1.1": "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006",
+ "supports-color@^7.1.0": "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da",
+ "text-table@^0.2.0": "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4",
+ "tr46@~0.0.3": "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a",
+ "tunnel@0.0.6": "https://registry.yarnpkg.com/tunnel/-/tunnel-0.0.6.tgz#72f1314b34a5b192db012324df2cc587ca47f92c",
+ "tunnel@^0.0.6": "https://registry.yarnpkg.com/tunnel/-/tunnel-0.0.6.tgz#72f1314b34a5b192db012324df2cc587ca47f92c",
+ "type-check@^0.4.0": "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1",
+ "type-check@~0.4.0": "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1",
+ "type-fest@^0.20.2": "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4",
+ "undici@^5.25.4": "https://registry.yarnpkg.com/undici/-/undici-5.28.2.tgz#fea200eac65fc7ecaff80a023d1a0543423b4c91",
+ "universal-user-agent@^6.0.0": "https://registry.yarnpkg.com/universal-user-agent/-/universal-user-agent-6.0.1.tgz#15f20f55da3c930c57bddbf1734c6654d5fd35aa",
+ "uri-js@^4.2.2": "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e",
+ "uuid@^8.3.2": "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2",
+ "webidl-conversions@^3.0.0": "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871",
+ "whatwg-url@^5.0.0": "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d",
+ "which@^2.0.1": "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1",
+ "wrappy@1": "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f",
+ "yaml@^2.2.2": "https://registry.yarnpkg.com/yaml/-/yaml-2.3.4.tgz#53fc1d514be80aabf386dc6001eb29bf3b7523b2",
+ "yocto-queue@^0.1.0": "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b"
+ },
+ "files": [],
+ "artifacts": {}
+}
\ No newline at end of file
diff --git a/node_modules/@eslint-community/eslint-utils/node_modules/.bin/eslint b/node_modules/@eslint-community/eslint-utils/node_modules/.bin/eslint
new file mode 120000
index 0000000..da97b4e
--- /dev/null
+++ b/node_modules/@eslint-community/eslint-utils/node_modules/.bin/eslint
@@ -0,0 +1 @@
+../../../../eslint/bin/eslint.js
\ No newline at end of file
diff --git a/node_modules/acorn-jsx/node_modules/.bin/acorn b/node_modules/acorn-jsx/node_modules/.bin/acorn
new file mode 120000
index 0000000..fa65fee
--- /dev/null
+++ b/node_modules/acorn-jsx/node_modules/.bin/acorn
@@ -0,0 +1 @@
+../../../acorn/bin/acorn
\ No newline at end of file
diff --git a/node_modules/cross-spawn/node_modules/.bin/node-which b/node_modules/cross-spawn/node_modules/.bin/node-which
new file mode 120000
index 0000000..c7bc814
--- /dev/null
+++ b/node_modules/cross-spawn/node_modules/.bin/node-which
@@ -0,0 +1 @@
+../../../which/bin/node-which
\ No newline at end of file
diff --git a/node_modules/docker-compose/CHANGELOG.md b/node_modules/docker-compose/CHANGELOG.md
index 671250f..c1e89a1 100644
--- a/node_modules/docker-compose/CHANGELOG.md
+++ b/node_modules/docker-compose/CHANGELOG.md
@@ -2,6 +2,20 @@
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
+### [0.24.3](https://github.com/PDMLab/docker-compose/compare/v0.24.2...v0.24.3) (2023-10-30)
+
+
+### Features
+
+* ps supports json format ([4498eb4](https://github.com/PDMLab/docker-compose/commit/4498eb481c52f852247342b495ff66c5b465f895))
+
+### [0.24.2](https://github.com/PDMLab/docker-compose/compare/v0.24.1...v0.24.2) (2023-07-27)
+
+
+### Bug Fixes
+
+* **ci:** shadow ci command using yarn ([bf0d1b6](https://github.com/PDMLab/docker-compose/commit/bf0d1b6a7ebc80b0ac158bbffc277b3c118545df))
+
### [0.24.1](https://github.com/PDMLab/docker-compose/compare/v0.24.0...v0.24.1) (2023-05-14)
diff --git a/node_modules/docker-compose/community-samples/readme.md b/node_modules/docker-compose/community-samples/readme.md
deleted file mode 100644
index 9b3699f..0000000
--- a/node_modules/docker-compose/community-samples/readme.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Community Samples
-
-This file refers to the community samples for the usage of this module in CI/CD environments like GitLab CI, Jenkins, Azure DevOps and so on.
-
-If you want to contribute your use case, please see [#44][i44] for further details.
-
-## CI/CD environments
-
-### Azure DevOps
--
-
-### CircleCI
--
-
-### GitLab CI
--
-
-### Jenkins
--
-
-
-[i44]: https://github.com/PDMLab/docker-compose/issues/44
diff --git a/node_modules/docker-compose/dist/src/index.d.ts b/node_modules/docker-compose/dist/src/index.d.ts
deleted file mode 100644
index 93255d6..0000000
--- a/node_modules/docker-compose/dist/src/index.d.ts
+++ /dev/null
@@ -1,137 +0,0 @@
-///
-export interface IDockerComposeOptions {
- cwd?: string;
- executablePath?: string;
- config?: string | string[];
- configAsString?: string;
- log?: boolean;
- composeOptions?: string[] | (string | string[])[];
- commandOptions?: string[] | (string | string[])[];
- env?: NodeJS.ProcessEnv;
- callback?: (chunk: Buffer, streamSource?: 'stdout' | 'stderr') => void;
-}
-export type DockerComposePortResult = {
- address: string;
- port: number;
-};
-export type DockerComposeVersionResult = {
- version: string;
-};
-export type DockerComposeConfigResult = {
- config: {
- version: Record;
- services: Record>;
- volumes: Record;
- };
-};
-export type DockerComposeConfigServicesResult = {
- services: string[];
-};
-export type DockerComposeConfigVolumesResult = {
- volumes: string[];
-};
-export interface IDockerComposeLogOptions extends IDockerComposeOptions {
- follow?: boolean;
-}
-export interface IDockerComposeBuildOptions extends IDockerComposeOptions {
- parallel?: boolean;
-}
-export interface IDockerComposePushOptions extends IDockerComposeOptions {
- ignorePushFailures?: boolean;
-}
-export interface IDockerComposeResult {
- exitCode: number | null;
- out: string;
- err: string;
-}
-export type TypedDockerComposeResult = {
- exitCode: number | null;
- out: string;
- err: string;
- data: T;
-};
-export type DockerComposePsResult = {
- services: Array<{
- name: string;
- command: string;
- state: string;
- ports: Array<{
- mapped?: {
- address: string;
- port: number;
- };
- exposed: {
- port: number;
- protocol: string;
- };
- }>;
- }>;
-};
-export declare const mapPsOutput: (output: string, options?: IDockerComposeOptions) => DockerComposePsResult;
-/**
- * Executes docker-compose command with common options
- */
-export declare const execCompose: (command: any, args: any, options?: IDockerComposeOptions) => Promise;
-export declare const upAll: (options?: IDockerComposeOptions) => Promise;
-export declare const upMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const upOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const down: (options?: IDockerComposeOptions) => Promise;
-export declare const stop: (options?: IDockerComposeOptions) => Promise;
-export declare const stopOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const stopMany: (options?: IDockerComposeOptions, ...services: string[]) => Promise;
-export declare const pauseOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const unpauseOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const kill: (options?: IDockerComposeOptions) => Promise;
-export declare const rm: (options?: IDockerComposeOptions, ...services: string[]) => Promise;
-export declare const exec: (container: string, command: string | string[], options?: IDockerComposeOptions) => Promise;
-export declare const run: (container: string, command: string | string[], options?: IDockerComposeOptions) => Promise;
-export declare const buildAll: (options?: IDockerComposeBuildOptions) => Promise;
-export declare const buildMany: (services: string[], options?: IDockerComposeBuildOptions) => Promise;
-export declare const buildOne: (service: string, options?: IDockerComposeBuildOptions) => Promise;
-export declare const pullAll: (options?: IDockerComposeOptions) => Promise;
-export declare const pullMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const pullOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const config: (options?: IDockerComposeOptions) => Promise>;
-export declare const configServices: (options?: IDockerComposeOptions) => Promise>;
-export declare const configVolumes: (options?: IDockerComposeOptions) => Promise>;
-export declare const ps: (options?: IDockerComposeOptions) => Promise>;
-export declare const push: (options?: IDockerComposePushOptions) => Promise;
-export declare const restartAll: (options?: IDockerComposeOptions) => Promise;
-export declare const restartMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const restartOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const logs: (services: string | string[], options?: IDockerComposeLogOptions) => Promise;
-export declare const port: (service: string, containerPort: string | number, options?: IDockerComposeOptions) => Promise>;
-export declare const version: (options?: IDockerComposeOptions) => Promise>;
-declare const _default: {
- upAll: (options?: IDockerComposeOptions | undefined) => Promise;
- upMany: (services: string[], options?: IDockerComposeOptions | undefined) => Promise;
- upOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- down: (options?: IDockerComposeOptions | undefined) => Promise;
- stop: (options?: IDockerComposeOptions | undefined) => Promise;
- stopOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- stopMany: (options?: IDockerComposeOptions | undefined, ...services: string[]) => Promise;
- pauseOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- unpauseOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- kill: (options?: IDockerComposeOptions | undefined) => Promise;
- rm: (options?: IDockerComposeOptions | undefined, ...services: string[]) => Promise;
- exec: (container: string, command: string | string[], options?: IDockerComposeOptions | undefined) => Promise;
- run: (container: string, command: string | string[], options?: IDockerComposeOptions | undefined) => Promise;
- buildAll: (options?: IDockerComposeBuildOptions) => Promise;
- buildMany: (services: string[], options?: IDockerComposeBuildOptions) => Promise;
- buildOne: (service: string, options?: IDockerComposeBuildOptions | undefined) => Promise;
- pullAll: (options?: IDockerComposeOptions) => Promise;
- pullMany: (services: string[], options?: IDockerComposeOptions) => Promise;
- pullOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- config: (options?: IDockerComposeOptions | undefined) => Promise>;
- configServices: (options?: IDockerComposeOptions | undefined) => Promise>;
- configVolumes: (options?: IDockerComposeOptions | undefined) => Promise>;
- ps: (options?: IDockerComposeOptions | undefined) => Promise>;
- push: (options?: IDockerComposePushOptions) => Promise;
- restartAll: (options?: IDockerComposeOptions | undefined) => Promise;
- restartMany: (services: string[], options?: IDockerComposeOptions | undefined) => Promise;
- restartOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- logs: (services: string | string[], options?: IDockerComposeLogOptions) => Promise;
- port: (service: string, containerPort: string | number, options?: IDockerComposeOptions | undefined) => Promise>;
- version: (options?: IDockerComposeOptions | undefined) => Promise>;
-};
-export default _default;
diff --git a/node_modules/docker-compose/dist/src/index.js b/node_modules/docker-compose/dist/src/index.js
deleted file mode 100644
index 98529c8..0000000
--- a/node_modules/docker-compose/dist/src/index.js
+++ /dev/null
@@ -1,488 +0,0 @@
-"use strict";
-var __assign = (this && this.__assign) || function () {
- __assign = Object.assign || function(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
- t[p] = s[p];
- }
- return t;
- };
- return __assign.apply(this, arguments);
-};
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
-};
-var __generator = (this && this.__generator) || function (thisArg, body) {
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
- function verb(n) { return function (v) { return step([n, v]); }; }
- function step(op) {
- if (f) throw new TypeError("Generator is already executing.");
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
- if (y = 0, t) op = [op[0] & 2, t.value];
- switch (op[0]) {
- case 0: case 1: t = op; break;
- case 4: _.label++; return { value: op[1], done: false };
- case 5: _.label++; y = op[1]; op = [0]; continue;
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
- default:
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
- if (t[2]) _.ops.pop();
- _.trys.pop(); continue;
- }
- op = body.call(thisArg, _);
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
- }
-};
-var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
- if (ar || !(i in from)) {
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
- ar[i] = from[i];
- }
- }
- return to.concat(ar || Array.prototype.slice.call(from));
-};
-var __importDefault = (this && this.__importDefault) || function (mod) {
- return (mod && mod.__esModule) ? mod : { "default": mod };
-};
-Object.defineProperty(exports, "__esModule", { value: true });
-exports.version = exports.port = exports.logs = exports.restartOne = exports.restartMany = exports.restartAll = exports.push = exports.ps = exports.configVolumes = exports.configServices = exports.config = exports.pullOne = exports.pullMany = exports.pullAll = exports.buildOne = exports.buildMany = exports.buildAll = exports.run = exports.exec = exports.rm = exports.kill = exports.unpauseOne = exports.pauseOne = exports.stopMany = exports.stopOne = exports.stop = exports.down = exports.upOne = exports.upMany = exports.upAll = exports.execCompose = exports.mapPsOutput = void 0;
-var child_process_1 = __importDefault(require("child_process"));
-var yaml_1 = __importDefault(require("yaml"));
-var map_ports_1 = __importDefault(require("./map-ports"));
-var nonEmptyString = function (v) { return v !== ''; };
-var mapPsOutput = function (output, options) {
- var isQuiet = false;
- if (options === null || options === void 0 ? void 0 : options.commandOptions) {
- isQuiet =
- options.commandOptions.includes('-q') ||
- options.commandOptions.includes('--quiet') ||
- options.commandOptions.includes('--services');
- }
- var services = output
- .split("\n")
- .filter(nonEmptyString)
- .filter(function (_, index) { return isQuiet || index > 1; })
- .map(function (line) {
- var _a;
- var nameFragment = line;
- var commandFragment = '';
- var stateFragment = '';
- var untypedPortsFragment = '';
- if (!isQuiet) {
- ;
- _a = line.split(/\s{3,}/), nameFragment = _a[0], commandFragment = _a[1], stateFragment = _a[2], untypedPortsFragment = _a[3];
- }
- return {
- name: nameFragment.trim(),
- command: commandFragment.trim(),
- state: stateFragment.trim(),
- ports: (0, map_ports_1.default)(untypedPortsFragment.trim())
- };
- });
- return { services: services };
-};
-exports.mapPsOutput = mapPsOutput;
-/**
- * Converts supplied yml files to cli arguments
- * https://docs.docker.com/compose/reference/overview/#use--f-to-specify-name-and-path-of-one-or-more-compose-files
- */
-var configToArgs = function (config) {
- if (typeof config === 'undefined') {
- return [];
- }
- else if (typeof config === 'string') {
- return ['-f', config];
- }
- else if (config instanceof Array) {
- return config.reduce(function (args, item) { return args.concat(['-f', item]); }, []);
- }
- throw new Error("Invalid argument supplied: ".concat(config));
-};
-/**
- * Converts docker-compose commandline options to cli arguments
- */
-var composeOptionsToArgs = function (composeOptions) {
- var composeArgs = [];
- composeOptions.forEach(function (option) {
- if (option instanceof Array) {
- composeArgs = composeArgs.concat(option);
- }
- if (typeof option === 'string') {
- composeArgs = composeArgs.concat([option]);
- }
- });
- return composeArgs;
-};
-/**
- * Executes docker-compose command with common options
- */
-var execCompose = function (command, args, options) {
- if (options === void 0) { options = {}; }
- return new Promise(function (resolve, reject) {
- var composeOptions = options.composeOptions || [];
- var commandOptions = options.commandOptions || [];
- var composeArgs = composeOptionsToArgs(composeOptions);
- var isConfigProvidedAsString = !!options.configAsString;
- var configArgs = isConfigProvidedAsString
- ? ['-f', '-']
- : configToArgs(options.config);
- composeArgs = composeArgs.concat(configArgs.concat([command].concat(composeOptionsToArgs(commandOptions), args)));
- var cwd = options.cwd;
- var env = options.env || undefined;
- var executablePath = options.executablePath || 'docker-compose';
- var childProc = child_process_1.default.spawn(executablePath, composeArgs, {
- cwd: cwd,
- env: env
- });
- childProc.on('error', function (err) {
- reject(err);
- });
- var result = {
- exitCode: null,
- err: '',
- out: ''
- };
- childProc.stdout.on('data', function (chunk) {
- var _a;
- result.out += chunk.toString();
- (_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stdout');
- });
- childProc.stderr.on('data', function (chunk) {
- var _a;
- result.err += chunk.toString();
- (_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stderr');
- });
- childProc.on('exit', function (exitCode) {
- result.exitCode = exitCode;
- if (exitCode === 0) {
- resolve(result);
- }
- else {
- reject(result);
- }
- });
- if (isConfigProvidedAsString) {
- childProc.stdin.write(options.configAsString);
- childProc.stdin.end();
- }
- if (options.log) {
- childProc.stdout.pipe(process.stdout);
- childProc.stderr.pipe(process.stderr);
- }
- });
-};
-exports.execCompose = execCompose;
-/**
- * Determines whether or not to use the default non-interactive flag -d for up commands
- */
-var shouldUseDefaultNonInteractiveFlag = function (options) {
- if (options === void 0) { options = {}; }
- var commandOptions = options.commandOptions || [];
- var containsOtherNonInteractiveFlag = commandOptions.reduce(function (memo, item) {
- return (memo &&
- !item.includes('--abort-on-container-exit') &&
- !item.includes('--no-start'));
- }, true);
- return containsOtherNonInteractiveFlag;
-};
-var upAll = function (options) {
- var args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : [];
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upAll = upAll;
-var upMany = function (services, options) {
- var args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d'].concat(services)
- : services;
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upMany = upMany;
-var upOne = function (service, options) {
- var args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d', service]
- : [service];
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upOne = upOne;
-var down = function (options) {
- return (0, exports.execCompose)('down', [], options);
-};
-exports.down = down;
-var stop = function (options) {
- return (0, exports.execCompose)('stop', [], options);
-};
-exports.stop = stop;
-var stopOne = function (service, options) {
- return (0, exports.execCompose)('stop', [service], options);
-};
-exports.stopOne = stopOne;
-var stopMany = function (options) {
- var services = [];
- for (var _i = 1; _i < arguments.length; _i++) {
- services[_i - 1] = arguments[_i];
- }
- return (0, exports.execCompose)('stop', __spreadArray([], services, true), options);
-};
-exports.stopMany = stopMany;
-var pauseOne = function (service, options) {
- return (0, exports.execCompose)('pause', [service], options);
-};
-exports.pauseOne = pauseOne;
-var unpauseOne = function (service, options) {
- return (0, exports.execCompose)('unpause', [service], options);
-};
-exports.unpauseOne = unpauseOne;
-var kill = function (options) {
- return (0, exports.execCompose)('kill', [], options);
-};
-exports.kill = kill;
-var rm = function (options) {
- var services = [];
- for (var _i = 1; _i < arguments.length; _i++) {
- services[_i - 1] = arguments[_i];
- }
- return (0, exports.execCompose)('rm', __spreadArray(['-f'], services, true), options);
-};
-exports.rm = rm;
-var exec = function (container, command, options) {
- var args = Array.isArray(command) ? command : command.split(/\s+/);
- return (0, exports.execCompose)('exec', ['-T', container].concat(args), options);
-};
-exports.exec = exec;
-var run = function (container, command, options) {
- var args = Array.isArray(command) ? command : command.split(/\s+/);
- return (0, exports.execCompose)('run', ['-T', container].concat(args), options);
-};
-exports.run = run;
-var buildAll = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('build', options.parallel ? ['--parallel'] : [], options);
-};
-exports.buildAll = buildAll;
-var buildMany = function (services, options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('build', options.parallel ? ['--parallel'].concat(services) : services, options);
-};
-exports.buildMany = buildMany;
-var buildOne = function (service, options) {
- return (0, exports.execCompose)('build', [service], options);
-};
-exports.buildOne = buildOne;
-var pullAll = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('pull', [], options);
-};
-exports.pullAll = pullAll;
-var pullMany = function (services, options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('pull', services, options);
-};
-exports.pullMany = pullMany;
-var pullOne = function (service, options) {
- return (0, exports.execCompose)('pull', [service], options);
-};
-exports.pullOne = pullOne;
-var config = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, config_1, error_1;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', [], options)];
- case 1:
- result = _a.sent();
- config_1 = yaml_1.default.parse(result.out);
- return [2 /*return*/, __assign(__assign({}, result), { data: { config: config_1 } })];
- case 2:
- error_1 = _a.sent();
- return [2 /*return*/, Promise.reject(error_1)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.config = config;
-var configServices = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, services, error_2;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', ['--services'], options)];
- case 1:
- result = _a.sent();
- services = result.out.split('\n').filter(nonEmptyString);
- return [2 /*return*/, __assign(__assign({}, result), { data: { services: services } })];
- case 2:
- error_2 = _a.sent();
- return [2 /*return*/, Promise.reject(error_2)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.configServices = configServices;
-var configVolumes = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, volumes, error_3;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', ['--volumes'], options)];
- case 1:
- result = _a.sent();
- volumes = result.out.split('\n').filter(nonEmptyString);
- return [2 /*return*/, __assign(__assign({}, result), { data: { volumes: volumes } })];
- case 2:
- error_3 = _a.sent();
- return [2 /*return*/, Promise.reject(error_3)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.configVolumes = configVolumes;
-var ps = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, data, error_4;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('ps', [], options)];
- case 1:
- result = _a.sent();
- data = (0, exports.mapPsOutput)(result.out, options);
- return [2 /*return*/, __assign(__assign({}, result), { data: data })];
- case 2:
- error_4 = _a.sent();
- return [2 /*return*/, Promise.reject(error_4)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.ps = ps;
-var push = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('push', options.ignorePushFailures ? ['--ignore-push-failures'] : [], options);
-};
-exports.push = push;
-var restartAll = function (options) {
- return (0, exports.execCompose)('restart', [], options);
-};
-exports.restartAll = restartAll;
-var restartMany = function (services, options) {
- return (0, exports.execCompose)('restart', services, options);
-};
-exports.restartMany = restartMany;
-var restartOne = function (service, options) {
- return (0, exports.restartMany)([service], options);
-};
-exports.restartOne = restartOne;
-var logs = function (services, options) {
- if (options === void 0) { options = {}; }
- var args = Array.isArray(services) ? services : [services];
- if (options.follow) {
- args = __spreadArray(['--follow'], args, true);
- }
- return (0, exports.execCompose)('logs', args, options);
-};
-exports.logs = logs;
-var port = function (service, containerPort, options) {
- return __awaiter(this, void 0, void 0, function () {
- var args, result, _a, address, port_1, error_5;
- return __generator(this, function (_b) {
- switch (_b.label) {
- case 0:
- args = [service, containerPort];
- _b.label = 1;
- case 1:
- _b.trys.push([1, 3, , 4]);
- return [4 /*yield*/, (0, exports.execCompose)('port', args, options)];
- case 2:
- result = _b.sent();
- _a = result.out.split(':'), address = _a[0], port_1 = _a[1];
- return [2 /*return*/, __assign(__assign({}, result), { data: {
- address: address,
- port: Number(port_1)
- } })];
- case 3:
- error_5 = _b.sent();
- return [2 /*return*/, Promise.reject(error_5)];
- case 4: return [2 /*return*/];
- }
- });
- });
-};
-exports.port = port;
-var version = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, version_1, error_6;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('version', ['--short'], options)];
- case 1:
- result = _a.sent();
- version_1 = result.out.replace('\n', '').trim();
- return [2 /*return*/, __assign(__assign({}, result), { data: { version: version_1 } })];
- case 2:
- error_6 = _a.sent();
- return [2 /*return*/, Promise.reject(error_6)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.version = version;
-exports.default = {
- upAll: exports.upAll,
- upMany: exports.upMany,
- upOne: exports.upOne,
- down: exports.down,
- stop: exports.stop,
- stopOne: exports.stopOne,
- stopMany: exports.stopMany,
- pauseOne: exports.pauseOne,
- unpauseOne: exports.unpauseOne,
- kill: exports.kill,
- rm: exports.rm,
- exec: exports.exec,
- run: exports.run,
- buildAll: exports.buildAll,
- buildMany: exports.buildMany,
- buildOne: exports.buildOne,
- pullAll: exports.pullAll,
- pullMany: exports.pullMany,
- pullOne: exports.pullOne,
- config: exports.config,
- configServices: exports.configServices,
- configVolumes: exports.configVolumes,
- ps: exports.ps,
- push: exports.push,
- restartAll: exports.restartAll,
- restartMany: exports.restartMany,
- restartOne: exports.restartOne,
- logs: exports.logs,
- port: exports.port,
- version: exports.version
-};
diff --git a/node_modules/docker-compose/dist/src/map-ports.d.ts b/node_modules/docker-compose/dist/src/map-ports.d.ts
deleted file mode 100644
index e21db0f..0000000
--- a/node_modules/docker-compose/dist/src/map-ports.d.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-declare const mapPorts: (ports: string) => Array<{
- mapped?: {
- address: string;
- port: number;
- };
- exposed: {
- port: number;
- protocol: string;
- };
-}>;
-export default mapPorts;
diff --git a/node_modules/docker-compose/dist/src/map-ports.js b/node_modules/docker-compose/dist/src/map-ports.js
deleted file mode 100644
index 252aef7..0000000
--- a/node_modules/docker-compose/dist/src/map-ports.js
+++ /dev/null
@@ -1,27 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-var mapPorts = function (ports) {
- if (!ports) {
- return [];
- }
- return ports.split(',').map(function (untypedPort) {
- var exposedFragments = untypedPort.trim().split('->');
- var _a = exposedFragments.length === 1
- ? exposedFragments[0].split('/')
- : exposedFragments[1].split('/'), port = _a[0], protocol = _a[1];
- var mapped = exposedFragments[0];
- var lastDoubleColon = mapped.lastIndexOf(':');
- if (lastDoubleColon === -1) {
- return {
- exposed: { port: Number(port), protocol: protocol }
- };
- }
- var address = mapped.substr(0, lastDoubleColon);
- var mappedPort = mapped.substr(lastDoubleColon + 1);
- return {
- exposed: { port: Number(port), protocol: protocol },
- mapped: { port: Number(mappedPort), address: address }
- };
- });
-};
-exports.default = mapPorts;
diff --git a/node_modules/docker-compose/dist/src/v2-map-ports.d.ts b/node_modules/docker-compose/dist/src/v2-map-ports.d.ts
deleted file mode 100644
index e21db0f..0000000
--- a/node_modules/docker-compose/dist/src/v2-map-ports.d.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-declare const mapPorts: (ports: string) => Array<{
- mapped?: {
- address: string;
- port: number;
- };
- exposed: {
- port: number;
- protocol: string;
- };
-}>;
-export default mapPorts;
diff --git a/node_modules/docker-compose/dist/src/v2-map-ports.js b/node_modules/docker-compose/dist/src/v2-map-ports.js
deleted file mode 100644
index 252aef7..0000000
--- a/node_modules/docker-compose/dist/src/v2-map-ports.js
+++ /dev/null
@@ -1,27 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-var mapPorts = function (ports) {
- if (!ports) {
- return [];
- }
- return ports.split(',').map(function (untypedPort) {
- var exposedFragments = untypedPort.trim().split('->');
- var _a = exposedFragments.length === 1
- ? exposedFragments[0].split('/')
- : exposedFragments[1].split('/'), port = _a[0], protocol = _a[1];
- var mapped = exposedFragments[0];
- var lastDoubleColon = mapped.lastIndexOf(':');
- if (lastDoubleColon === -1) {
- return {
- exposed: { port: Number(port), protocol: protocol }
- };
- }
- var address = mapped.substr(0, lastDoubleColon);
- var mappedPort = mapped.substr(lastDoubleColon + 1);
- return {
- exposed: { port: Number(port), protocol: protocol },
- mapped: { port: Number(mappedPort), address: address }
- };
- });
-};
-exports.default = mapPorts;
diff --git a/node_modules/docker-compose/dist/src/v2.d.ts b/node_modules/docker-compose/dist/src/v2.d.ts
deleted file mode 100644
index 1d05ac1..0000000
--- a/node_modules/docker-compose/dist/src/v2.d.ts
+++ /dev/null
@@ -1,137 +0,0 @@
-///
-export interface IDockerComposeOptions {
- cwd?: string;
- executablePath?: string;
- config?: string | string[];
- configAsString?: string;
- log?: boolean;
- composeOptions?: string[] | (string | string[])[];
- commandOptions?: string[] | (string | string[])[];
- env?: NodeJS.ProcessEnv;
- callback?: (chunk: Buffer, streamSource?: 'stdout' | 'stderr') => void;
-}
-export type DockerComposePortResult = {
- address: string;
- port: number;
-};
-export type DockerComposeVersionResult = {
- version: string;
-};
-export type DockerComposeConfigResult = {
- config: {
- version: Record;
- services: Record>;
- volumes: Record;
- };
-};
-export type DockerComposeConfigServicesResult = {
- services: string[];
-};
-export type DockerComposeConfigVolumesResult = {
- volumes: string[];
-};
-export interface IDockerComposeLogOptions extends IDockerComposeOptions {
- follow?: boolean;
-}
-export interface IDockerComposeBuildOptions extends IDockerComposeOptions {
- parallel?: boolean;
-}
-export interface IDockerComposePushOptions extends IDockerComposeOptions {
- ignorePushFailures?: boolean;
-}
-export interface IDockerComposeResult {
- exitCode: number | null;
- out: string;
- err: string;
-}
-export type TypedDockerComposeResult = {
- exitCode: number | null;
- out: string;
- err: string;
- data: T;
-};
-export type DockerComposePsResult = {
- services: Array<{
- name: string;
- command: string;
- state: string;
- ports: Array<{
- mapped?: {
- address: string;
- port: number;
- };
- exposed: {
- port: number;
- protocol: string;
- };
- }>;
- }>;
-};
-export declare const mapPsOutput: (output: string, options?: IDockerComposeOptions) => DockerComposePsResult;
-/**
- * Executes docker compose command with common options
- */
-export declare const execCompose: (command: any, args: any, options?: IDockerComposeOptions) => Promise;
-export declare const upAll: (options?: IDockerComposeOptions) => Promise;
-export declare const upMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const upOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const down: (options?: IDockerComposeOptions) => Promise;
-export declare const stop: (options?: IDockerComposeOptions) => Promise;
-export declare const stopOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const stopMany: (options?: IDockerComposeOptions, ...services: string[]) => Promise;
-export declare const pauseOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const unpauseOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const kill: (options?: IDockerComposeOptions) => Promise;
-export declare const rm: (options?: IDockerComposeOptions, ...services: string[]) => Promise;
-export declare const exec: (container: string, command: string | string[], options?: IDockerComposeOptions) => Promise;
-export declare const run: (container: string, command: string | string[], options?: IDockerComposeOptions) => Promise;
-export declare const buildAll: (options?: IDockerComposeBuildOptions) => Promise;
-export declare const buildMany: (services: string[], options?: IDockerComposeBuildOptions) => Promise;
-export declare const buildOne: (service: string, options?: IDockerComposeBuildOptions) => Promise;
-export declare const pullAll: (options?: IDockerComposeOptions) => Promise;
-export declare const pullMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const pullOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const config: (options?: IDockerComposeOptions) => Promise>;
-export declare const configServices: (options?: IDockerComposeOptions) => Promise>;
-export declare const configVolumes: (options?: IDockerComposeOptions) => Promise>;
-export declare const ps: (options?: IDockerComposeOptions) => Promise>;
-export declare const push: (options?: IDockerComposePushOptions) => Promise;
-export declare const restartAll: (options?: IDockerComposeOptions) => Promise;
-export declare const restartMany: (services: string[], options?: IDockerComposeOptions) => Promise;
-export declare const restartOne: (service: string, options?: IDockerComposeOptions) => Promise;
-export declare const logs: (services: string | string[], options?: IDockerComposeLogOptions) => Promise;
-export declare const port: (service: string, containerPort: string | number, options?: IDockerComposeOptions) => Promise>;
-export declare const version: (options?: IDockerComposeOptions) => Promise>;
-declare const _default: {
- upAll: (options?: IDockerComposeOptions | undefined) => Promise;
- upMany: (services: string[], options?: IDockerComposeOptions | undefined) => Promise;
- upOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- down: (options?: IDockerComposeOptions | undefined) => Promise;
- stop: (options?: IDockerComposeOptions | undefined) => Promise;
- stopOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- stopMany: (options?: IDockerComposeOptions | undefined, ...services: string[]) => Promise;
- pauseOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- unpauseOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- kill: (options?: IDockerComposeOptions | undefined) => Promise;
- rm: (options?: IDockerComposeOptions | undefined, ...services: string[]) => Promise;
- exec: (container: string, command: string | string[], options?: IDockerComposeOptions | undefined) => Promise;
- run: (container: string, command: string | string[], options?: IDockerComposeOptions | undefined) => Promise;
- buildAll: (options?: IDockerComposeBuildOptions) => Promise;
- buildMany: (services: string[], options?: IDockerComposeBuildOptions) => Promise;
- buildOne: (service: string, options?: IDockerComposeBuildOptions | undefined) => Promise;
- pullAll: (options?: IDockerComposeOptions) => Promise;
- pullMany: (services: string[], options?: IDockerComposeOptions) => Promise;
- pullOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- config: (options?: IDockerComposeOptions | undefined) => Promise>;
- configServices: (options?: IDockerComposeOptions | undefined) => Promise>;
- configVolumes: (options?: IDockerComposeOptions | undefined) => Promise>;
- ps: (options?: IDockerComposeOptions | undefined) => Promise>;
- push: (options?: IDockerComposePushOptions) => Promise;
- restartAll: (options?: IDockerComposeOptions | undefined) => Promise;
- restartMany: (services: string[], options?: IDockerComposeOptions | undefined) => Promise;
- restartOne: (service: string, options?: IDockerComposeOptions | undefined) => Promise;
- logs: (services: string | string[], options?: IDockerComposeLogOptions) => Promise;
- port: (service: string, containerPort: string | number, options?: IDockerComposeOptions | undefined) => Promise>;
- version: (options?: IDockerComposeOptions | undefined) => Promise>;
-};
-export default _default;
diff --git a/node_modules/docker-compose/dist/src/v2.js b/node_modules/docker-compose/dist/src/v2.js
deleted file mode 100644
index da43cc7..0000000
--- a/node_modules/docker-compose/dist/src/v2.js
+++ /dev/null
@@ -1,494 +0,0 @@
-"use strict";
-var __assign = (this && this.__assign) || function () {
- __assign = Object.assign || function(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
- t[p] = s[p];
- }
- return t;
- };
- return __assign.apply(this, arguments);
-};
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
-};
-var __generator = (this && this.__generator) || function (thisArg, body) {
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
- function verb(n) { return function (v) { return step([n, v]); }; }
- function step(op) {
- if (f) throw new TypeError("Generator is already executing.");
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
- if (y = 0, t) op = [op[0] & 2, t.value];
- switch (op[0]) {
- case 0: case 1: t = op; break;
- case 4: _.label++; return { value: op[1], done: false };
- case 5: _.label++; y = op[1]; op = [0]; continue;
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
- default:
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
- if (t[2]) _.ops.pop();
- _.trys.pop(); continue;
- }
- op = body.call(thisArg, _);
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
- }
-};
-var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
- if (ar || !(i in from)) {
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
- ar[i] = from[i];
- }
- }
- return to.concat(ar || Array.prototype.slice.call(from));
-};
-var __importDefault = (this && this.__importDefault) || function (mod) {
- return (mod && mod.__esModule) ? mod : { "default": mod };
-};
-Object.defineProperty(exports, "__esModule", { value: true });
-exports.version = exports.port = exports.logs = exports.restartOne = exports.restartMany = exports.restartAll = exports.push = exports.ps = exports.configVolumes = exports.configServices = exports.config = exports.pullOne = exports.pullMany = exports.pullAll = exports.buildOne = exports.buildMany = exports.buildAll = exports.run = exports.exec = exports.rm = exports.kill = exports.unpauseOne = exports.pauseOne = exports.stopMany = exports.stopOne = exports.stop = exports.down = exports.upOne = exports.upMany = exports.upAll = exports.execCompose = exports.mapPsOutput = void 0;
-var child_process_1 = __importDefault(require("child_process"));
-var yaml_1 = __importDefault(require("yaml"));
-var v2_map_ports_1 = __importDefault(require("./v2-map-ports"));
-var nonEmptyString = function (v) { return v !== ''; };
-var mapPsOutput = function (output, options) {
- var isQuiet = false;
- if (options === null || options === void 0 ? void 0 : options.commandOptions) {
- isQuiet =
- options.commandOptions.includes('-q') ||
- options.commandOptions.includes('--quiet') ||
- options.commandOptions.includes('--services');
- }
- var services = output
- .split("\n")
- .filter(nonEmptyString)
- .filter(function (_, index) { return isQuiet || index >= 1; })
- .map(function (line) {
- var _a;
- var nameFragment = line;
- var commandFragment = '';
- var imageFragment = '';
- var serviceFragment = '';
- var createdFragment = '';
- var stateFragment = '';
- var untypedPortsFragment = '';
- if (!isQuiet) {
- ;
- _a = line.split(/\s{3,}/), nameFragment = _a[0], imageFragment = _a[1], commandFragment = _a[2], serviceFragment = _a[3], createdFragment = _a[4], stateFragment = _a[5], untypedPortsFragment = _a[6];
- }
- return {
- name: nameFragment.trim(),
- command: commandFragment.trim(),
- state: stateFragment.trim(),
- ports: (0, v2_map_ports_1.default)(untypedPortsFragment.trim())
- };
- });
- return { services: services };
-};
-exports.mapPsOutput = mapPsOutput;
-/**
- * Converts supplied yml files to cli arguments
- * https://docs.docker.com/compose/reference/overview/#use--f-to-specify-name-and-path-of-one-or-more-compose-files
- */
-var configToArgs = function (config) {
- if (typeof config === 'undefined') {
- return [];
- }
- else if (typeof config === 'string') {
- return ['-f', config];
- }
- else if (config instanceof Array) {
- return config.reduce(function (args, item) { return args.concat(['-f', item]); }, []);
- }
- throw new Error("Invalid argument supplied: ".concat(config));
-};
-/**
- * Converts docker compose commandline options to cli arguments
- */
-var composeOptionsToArgs = function (composeOptions) {
- var composeArgs = [];
- composeOptions.forEach(function (option) {
- if (option instanceof Array) {
- composeArgs = composeArgs.concat(option);
- }
- if (typeof option === 'string') {
- composeArgs = composeArgs.concat([option]);
- }
- });
- return composeArgs;
-};
-/**
- * Executes docker compose command with common options
- */
-var execCompose = function (command, args, options) {
- if (options === void 0) { options = {}; }
- return new Promise(function (resolve, reject) {
- var composeOptions = options.composeOptions || [];
- var commandOptions = options.commandOptions || [];
- var composeArgs = composeOptionsToArgs(composeOptions);
- var isConfigProvidedAsString = !!options.configAsString;
- var configArgs = isConfigProvidedAsString
- ? ['-f', '-']
- : configToArgs(options.config);
- composeArgs = composeArgs.concat(configArgs.concat([command].concat(composeOptionsToArgs(commandOptions), args)));
- var cwd = options.cwd;
- var env = options.env || undefined;
- var executablePath = options.executablePath || 'docker';
- var childProc = child_process_1.default.spawn(executablePath, __spreadArray(['compose'], composeArgs, true), {
- cwd: cwd,
- env: env
- });
- childProc.on('error', function (err) {
- reject(err);
- });
- var result = {
- exitCode: null,
- err: '',
- out: ''
- };
- childProc.stdout.on('data', function (chunk) {
- var _a;
- result.out += chunk.toString();
- (_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stdout');
- });
- childProc.stderr.on('data', function (chunk) {
- var _a;
- result.err += chunk.toString();
- (_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stderr');
- });
- childProc.on('exit', function (exitCode) {
- result.exitCode = exitCode;
- console.log("exiting command ".concat(command));
- setTimeout(function () {
- if (exitCode === 0) {
- resolve(result);
- }
- else {
- reject(result);
- }
- }, 500);
- });
- if (isConfigProvidedAsString) {
- childProc.stdin.write(options.configAsString);
- childProc.stdin.end();
- }
- if (options.log) {
- childProc.stdout.pipe(process.stdout);
- childProc.stderr.pipe(process.stderr);
- }
- });
-};
-exports.execCompose = execCompose;
-/**
- * Determines whether or not to use the default non-interactive flag -d for up commands
- */
-var shouldUseDefaultNonInteractiveFlag = function (options) {
- if (options === void 0) { options = {}; }
- var commandOptions = options.commandOptions || [];
- var containsOtherNonInteractiveFlag = commandOptions.reduce(function (memo, item) {
- return (memo &&
- !item.includes('--abort-on-container-exit') &&
- !item.includes('--no-start'));
- }, true);
- return containsOtherNonInteractiveFlag;
-};
-var upAll = function (options) {
- var args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : [];
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upAll = upAll;
-var upMany = function (services, options) {
- var args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d'].concat(services)
- : services;
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upMany = upMany;
-var upOne = function (service, options) {
- var args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d', service]
- : [service];
- return (0, exports.execCompose)('up', args, options);
-};
-exports.upOne = upOne;
-var down = function (options) {
- return (0, exports.execCompose)('down', [], options);
-};
-exports.down = down;
-var stop = function (options) {
- return (0, exports.execCompose)('stop', [], options);
-};
-exports.stop = stop;
-var stopOne = function (service, options) {
- return (0, exports.execCompose)('stop', [service], options);
-};
-exports.stopOne = stopOne;
-var stopMany = function (options) {
- var services = [];
- for (var _i = 1; _i < arguments.length; _i++) {
- services[_i - 1] = arguments[_i];
- }
- return (0, exports.execCompose)('stop', __spreadArray([], services, true), options);
-};
-exports.stopMany = stopMany;
-var pauseOne = function (service, options) {
- return (0, exports.execCompose)('pause', [service], options);
-};
-exports.pauseOne = pauseOne;
-var unpauseOne = function (service, options) {
- return (0, exports.execCompose)('unpause', [service], options);
-};
-exports.unpauseOne = unpauseOne;
-var kill = function (options) {
- return (0, exports.execCompose)('kill', [], options);
-};
-exports.kill = kill;
-var rm = function (options) {
- var services = [];
- for (var _i = 1; _i < arguments.length; _i++) {
- services[_i - 1] = arguments[_i];
- }
- return (0, exports.execCompose)('rm', __spreadArray(['-f'], services, true), options);
-};
-exports.rm = rm;
-var exec = function (container, command, options) {
- var args = Array.isArray(command) ? command : command.split(/\s+/);
- return (0, exports.execCompose)('exec', ['-T', container].concat(args), options);
-};
-exports.exec = exec;
-var run = function (container, command, options) {
- var args = Array.isArray(command) ? command : command.split(/\s+/);
- return (0, exports.execCompose)('run', ['-T', container].concat(args), options);
-};
-exports.run = run;
-var buildAll = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('build', options.parallel ? ['--parallel'] : [], options);
-};
-exports.buildAll = buildAll;
-var buildMany = function (services, options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('build', options.parallel ? ['--parallel'].concat(services) : services, options);
-};
-exports.buildMany = buildMany;
-var buildOne = function (service, options) {
- return (0, exports.execCompose)('build', [service], options);
-};
-exports.buildOne = buildOne;
-var pullAll = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('pull', [], options);
-};
-exports.pullAll = pullAll;
-var pullMany = function (services, options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('pull', services, options);
-};
-exports.pullMany = pullMany;
-var pullOne = function (service, options) {
- return (0, exports.execCompose)('pull', [service], options);
-};
-exports.pullOne = pullOne;
-var config = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, config_1, error_1;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', [], options)];
- case 1:
- result = _a.sent();
- config_1 = yaml_1.default.parse(result.out);
- return [2 /*return*/, __assign(__assign({}, result), { data: { config: config_1 } })];
- case 2:
- error_1 = _a.sent();
- return [2 /*return*/, Promise.reject(error_1)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.config = config;
-var configServices = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, services, error_2;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', ['--services'], options)];
- case 1:
- result = _a.sent();
- services = result.out.split('\n').filter(nonEmptyString);
- return [2 /*return*/, __assign(__assign({}, result), { data: { services: services } })];
- case 2:
- error_2 = _a.sent();
- return [2 /*return*/, Promise.reject(error_2)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.configServices = configServices;
-var configVolumes = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, volumes, error_3;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('config', ['--volumes'], options)];
- case 1:
- result = _a.sent();
- volumes = result.out.split('\n').filter(nonEmptyString);
- return [2 /*return*/, __assign(__assign({}, result), { data: { volumes: volumes } })];
- case 2:
- error_3 = _a.sent();
- return [2 /*return*/, Promise.reject(error_3)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.configVolumes = configVolumes;
-var ps = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, data, error_4;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('ps', [], options)];
- case 1:
- result = _a.sent();
- data = (0, exports.mapPsOutput)(result.out, options);
- return [2 /*return*/, __assign(__assign({}, result), { data: data })];
- case 2:
- error_4 = _a.sent();
- return [2 /*return*/, Promise.reject(error_4)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.ps = ps;
-var push = function (options) {
- if (options === void 0) { options = {}; }
- return (0, exports.execCompose)('push', options.ignorePushFailures ? ['--ignore-push-failures'] : [], options);
-};
-exports.push = push;
-var restartAll = function (options) {
- return (0, exports.execCompose)('restart', [], options);
-};
-exports.restartAll = restartAll;
-var restartMany = function (services, options) {
- return (0, exports.execCompose)('restart', services, options);
-};
-exports.restartMany = restartMany;
-var restartOne = function (service, options) {
- return (0, exports.restartMany)([service], options);
-};
-exports.restartOne = restartOne;
-var logs = function (services, options) {
- if (options === void 0) { options = {}; }
- var args = Array.isArray(services) ? services : [services];
- if (options.follow) {
- args = __spreadArray(['--follow'], args, true);
- }
- return (0, exports.execCompose)('logs', args, options);
-};
-exports.logs = logs;
-var port = function (service, containerPort, options) {
- return __awaiter(this, void 0, void 0, function () {
- var args, result, _a, address, port_1, error_5;
- return __generator(this, function (_b) {
- switch (_b.label) {
- case 0:
- args = [service, containerPort];
- _b.label = 1;
- case 1:
- _b.trys.push([1, 3, , 4]);
- return [4 /*yield*/, (0, exports.execCompose)('port', args, options)];
- case 2:
- result = _b.sent();
- _a = result.out.split(':'), address = _a[0], port_1 = _a[1];
- return [2 /*return*/, __assign(__assign({}, result), { data: {
- address: address,
- port: Number(port_1)
- } })];
- case 3:
- error_5 = _b.sent();
- return [2 /*return*/, Promise.reject(error_5)];
- case 4: return [2 /*return*/];
- }
- });
- });
-};
-exports.port = port;
-var version = function (options) {
- return __awaiter(this, void 0, void 0, function () {
- var result, version_1, error_6;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- _a.trys.push([0, 2, , 3]);
- return [4 /*yield*/, (0, exports.execCompose)('version', ['--short'], options)];
- case 1:
- result = _a.sent();
- version_1 = result.out.replace('\n', '').trim();
- return [2 /*return*/, __assign(__assign({}, result), { data: { version: version_1 } })];
- case 2:
- error_6 = _a.sent();
- return [2 /*return*/, Promise.reject(error_6)];
- case 3: return [2 /*return*/];
- }
- });
- });
-};
-exports.version = version;
-exports.default = {
- upAll: exports.upAll,
- upMany: exports.upMany,
- upOne: exports.upOne,
- down: exports.down,
- stop: exports.stop,
- stopOne: exports.stopOne,
- stopMany: exports.stopMany,
- pauseOne: exports.pauseOne,
- unpauseOne: exports.unpauseOne,
- kill: exports.kill,
- rm: exports.rm,
- exec: exports.exec,
- run: exports.run,
- buildAll: exports.buildAll,
- buildMany: exports.buildMany,
- buildOne: exports.buildOne,
- pullAll: exports.pullAll,
- pullMany: exports.pullMany,
- pullOne: exports.pullOne,
- config: exports.config,
- configServices: exports.configServices,
- configVolumes: exports.configVolumes,
- ps: exports.ps,
- push: exports.push,
- restartAll: exports.restartAll,
- restartMany: exports.restartMany,
- restartOne: exports.restartOne,
- logs: exports.logs,
- port: exports.port,
- version: exports.version
-};
diff --git a/node_modules/docker-compose/dist/v2.d.ts b/node_modules/docker-compose/dist/v2.d.ts
index 1d05ac1..247426c 100644
--- a/node_modules/docker-compose/dist/v2.d.ts
+++ b/node_modules/docker-compose/dist/v2.d.ts
@@ -50,23 +50,24 @@ export type TypedDockerComposeResult = {
err: string;
data: T;
};
-export type DockerComposePsResult = {
- services: Array<{
- name: string;
- command: string;
- state: string;
- ports: Array<{
- mapped?: {
- address: string;
- port: number;
- };
- exposed: {
- port: number;
- protocol: string;
- };
- }>;
+export type DockerComposePsResultService = {
+ name: string;
+ command: string;
+ state: string;
+ ports: Array<{
+ mapped?: {
+ address: string;
+ port: number;
+ };
+ exposed: {
+ port: number;
+ protocol: string;
+ };
}>;
};
+export type DockerComposePsResult = {
+ services: Array;
+};
export declare const mapPsOutput: (output: string, options?: IDockerComposeOptions) => DockerComposePsResult;
/**
* Executes docker compose command with common options
diff --git a/node_modules/docker-compose/dist/v2.js b/node_modules/docker-compose/dist/v2.js
index fe936e1..a6b9c04 100644
--- a/node_modules/docker-compose/dist/v2.js
+++ b/node_modules/docker-compose/dist/v2.js
@@ -64,30 +64,50 @@ var child_process_1 = __importDefault(require("child_process"));
var yaml_1 = __importDefault(require("yaml"));
var v2_map_ports_1 = __importDefault(require("./v2-map-ports"));
var nonEmptyString = function (v) { return v !== ''; };
+var arrayIncludesTuple = function (arr, tuple) {
+ return arr.some(function (subArray) {
+ return Array.isArray(subArray) &&
+ subArray.length === tuple.length &&
+ subArray.every(function (value, index) { return value === tuple[index]; });
+ });
+};
var mapPsOutput = function (output, options) {
var isQuiet = false;
+ var isJson = false;
if (options === null || options === void 0 ? void 0 : options.commandOptions) {
isQuiet =
options.commandOptions.includes('-q') ||
options.commandOptions.includes('--quiet') ||
options.commandOptions.includes('--services');
+ isJson = arrayIncludesTuple(options.commandOptions, ['--format', 'json']);
}
var services = output
.split("\n")
.filter(nonEmptyString)
- .filter(function (_, index) { return isQuiet || index >= 1; })
+ .filter(function (_, index) { return isQuiet || isJson || index >= 1; })
.map(function (line) {
- var _a;
var nameFragment = line;
var commandFragment = '';
- var imageFragment = '';
- var serviceFragment = '';
- var createdFragment = '';
var stateFragment = '';
var untypedPortsFragment = '';
if (!isQuiet) {
- ;
- _a = line.split(/\s{3,}/), nameFragment = _a[0], imageFragment = _a[1], commandFragment = _a[2], serviceFragment = _a[3], createdFragment = _a[4], stateFragment = _a[5], untypedPortsFragment = _a[6];
+ if (isJson) {
+ var serviceLine = JSON.parse(line);
+ nameFragment = serviceLine.Name;
+ commandFragment = serviceLine.Command;
+ stateFragment = serviceLine.State;
+ untypedPortsFragment = serviceLine.Ports;
+ }
+ else {
+ var lineColumns = line.split(/\s{3,}/);
+ // the line has the columns in the following order:
+ // NAME IMAGE COMMAND SERVICE CREATED STATUS PORTS
+ // @see https://docs.docker.com/engine/reference/commandline/compose_ps/#description
+ nameFragment = lineColumns[0];
+ commandFragment = lineColumns[2];
+ stateFragment = lineColumns[5];
+ untypedPortsFragment = lineColumns[6];
+ }
}
return {
name: nameFragment.trim(),
diff --git a/node_modules/docker-compose/package.json b/node_modules/docker-compose/package.json
index 0464ddc..3081aa1 100644
--- a/node_modules/docker-compose/package.json
+++ b/node_modules/docker-compose/package.json
@@ -1,22 +1,25 @@
{
"name": "docker-compose",
- "version": "0.24.1",
+ "version": "0.24.3",
"main": "dist/index.js",
"typings": "dist/index.d.ts",
"types": "dist/index.d.ts",
"scripts": {
+ "ci": "yarn install --frozen-lockfile",
"test-v1": "npx vitest --dir test/v1 --test-timeout=30000",
"test-v2": "npx vitest --dir test/v2 --test-timeout=30000",
"lint": "eslint src/**/*.ts test/**/*.ts",
"build": "tsc",
"prepublishOnly": "tsc",
"release": "yarn build && standard-version",
- "docs:dev": "vuepress dev docs",
- "docs:build": "vuepress build docs"
+ "docs:dev": "vitepress dev docs",
+ "docs:build": "vitepress build docs",
+ "docs:preview": "vitepress preview docs"
},
"repository": {
"url": "git@github.com:PDMLab/docker-compose.git"
},
+ "homepage": "https://pdmlab.github.io/docker-compose/",
"keywords": [
"devops",
"devops-tools",
@@ -98,8 +101,8 @@
"prettier": "^2.2.1",
"standard-version": "9.3.1",
"typescript": "^4.9.5",
- "vitest": "^0.30.1",
- "vuepress": "^2.0.0-beta.7"
+ "vitepress": "^1.0.0-alpha.76",
+ "vitest": "^0.30.1"
},
"engines": {
"node": ">= 6.0.0"
diff --git a/node_modules/docker-compose/readme.md b/node_modules/docker-compose/readme.md
index f78d1de..1f46169 100644
--- a/node_modules/docker-compose/readme.md
+++ b/node_modules/docker-compose/readme.md
@@ -1,5 +1,5 @@
[![Conventional Commits](https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg)](https://conventionalcommits.org)
-[![Discord](https://img.shields.io/discord/1070453198000767076)](https://discord.gg/dKWyyv6M)
+[![Discord](https://img.shields.io/discord/1070453198000767076)](https://discord.gg/pR6duvNHtV)
@@ -84,6 +84,26 @@ To execute command inside a running container
compose.exec('node', 'npm install', { cwd: path.join(__dirname) })
```
+To list the containers for a compose project
+
+```javascript
+const result = await compose.ps({ cwd: path.join(__dirname) })
+result.data.services.forEach((service) => {
+ console.log(service.name, service.command, service.state, service.ports)
+ // state is e.g. 'Up 2 hours'
+})
+```
+
+The docker-compose v2 version also support the `--format json` command option to get a better state support:
+
+```javascript
+const result = await compose.ps({ cwd: path.join(__dirname), commandOptions: [["--format", "json"]] })
+result.data.services.forEach((service) => {
+ console.log(service.name, service.command, service.state, service.ports)
+ // state is one of the defined states: paused | restarting | removing | running | dead | created | exited
+})
+```
+
## Known issues with v2 support
* During testing we noticed that `docker compose` seems to send it's exit code also commands don't seem to have finished. This doesn't occur for all commands, but for example with `stop` or `down`. We had the option to wait for stopped / removed containers using third party libraries but this would make bootstrapping `docker-compose` much more complicated for the users. So we decided to use a `setTimeout(500)` workaround. We're aware this is not perfect but it seems to be the most appropriate solution for now. Details can be found in the [v2 PR discussion](https://github.com/PDMLab/docker-compose/pull/228#issuecomment-1422895821) (we're happy to get help here).
diff --git a/node_modules/docker-compose/src/index.ts b/node_modules/docker-compose/src/index.ts
deleted file mode 100644
index 04ddd69..0000000
--- a/node_modules/docker-compose/src/index.ts
+++ /dev/null
@@ -1,565 +0,0 @@
-import childProcess from 'child_process'
-import yaml from 'yaml'
-import mapPorts from './map-ports'
-
-export interface IDockerComposeOptions {
- cwd?: string
- executablePath?: string
- config?: string | string[]
- configAsString?: string
- log?: boolean
- composeOptions?: string[] | (string | string[])[]
- commandOptions?: string[] | (string | string[])[]
- env?: NodeJS.ProcessEnv
- callback?: (chunk: Buffer, streamSource?: 'stdout' | 'stderr') => void
-}
-
-export type DockerComposePortResult = {
- address: string
- port: number
-}
-
-export type DockerComposeVersionResult = {
- version: string
-}
-
-export type DockerComposeConfigResult = {
- config: {
- version: Record
- services: Record>
- volumes: Record
- }
-}
-
-export type DockerComposeConfigServicesResult = {
- services: string[]
-}
-
-export type DockerComposeConfigVolumesResult = {
- volumes: string[]
-}
-
-export interface IDockerComposeLogOptions extends IDockerComposeOptions {
- follow?: boolean
-}
-
-export interface IDockerComposeBuildOptions extends IDockerComposeOptions {
- parallel?: boolean
-}
-
-export interface IDockerComposePushOptions extends IDockerComposeOptions {
- ignorePushFailures?: boolean
-}
-
-export interface IDockerComposeResult {
- exitCode: number | null
- out: string
- err: string
-}
-
-export type TypedDockerComposeResult = {
- exitCode: number | null
- out: string
- err: string
- data: T
-}
-
-const nonEmptyString = (v: string) => v !== ''
-
-export type DockerComposePsResult = {
- services: Array<{
- name: string
- command: string
- state: string
- ports: Array<{
- mapped?: { address: string; port: number }
- exposed: { port: number; protocol: string }
- }>
- }>
-}
-
-export const mapPsOutput = (
- output: string,
- options?: IDockerComposeOptions
-): DockerComposePsResult => {
- let isQuiet = false
- if (options?.commandOptions) {
- isQuiet =
- options.commandOptions.includes('-q') ||
- options.commandOptions.includes('--quiet') ||
- options.commandOptions.includes('--services')
- }
- const services = output
- .split(`\n`)
- .filter(nonEmptyString)
- .filter((_, index) => isQuiet || index > 1)
- .map((line) => {
- let nameFragment = line
- let commandFragment = ''
- let stateFragment = ''
- let untypedPortsFragment = ''
- if (!isQuiet) {
- ;[
- nameFragment,
- commandFragment,
- stateFragment,
- untypedPortsFragment
- ] = line.split(/\s{3,}/)
- }
- return {
- name: nameFragment.trim(),
- command: commandFragment.trim(),
- state: stateFragment.trim(),
- ports: mapPorts(untypedPortsFragment.trim())
- }
- })
- return { services }
-}
-
-/**
- * Converts supplied yml files to cli arguments
- * https://docs.docker.com/compose/reference/overview/#use--f-to-specify-name-and-path-of-one-or-more-compose-files
- */
-const configToArgs = (config): string[] => {
- if (typeof config === 'undefined') {
- return []
- } else if (typeof config === 'string') {
- return ['-f', config]
- } else if (config instanceof Array) {
- return config.reduce(
- (args, item): string[] => args.concat(['-f', item]),
- []
- )
- }
- throw new Error(`Invalid argument supplied: ${config}`)
-}
-
-/**
- * Converts docker-compose commandline options to cli arguments
- */
-const composeOptionsToArgs = (composeOptions): string[] => {
- let composeArgs: string[] = []
-
- composeOptions.forEach((option: string[] | string): void => {
- if (option instanceof Array) {
- composeArgs = composeArgs.concat(option)
- }
- if (typeof option === 'string') {
- composeArgs = composeArgs.concat([option])
- }
- })
-
- return composeArgs
-}
-
-/**
- * Executes docker-compose command with common options
- */
-export const execCompose = (
- command,
- args,
- options: IDockerComposeOptions = {}
-): Promise =>
- new Promise((resolve, reject): void => {
- const composeOptions = options.composeOptions || []
- const commandOptions = options.commandOptions || []
- let composeArgs = composeOptionsToArgs(composeOptions)
- const isConfigProvidedAsString = !!options.configAsString
-
- const configArgs = isConfigProvidedAsString
- ? ['-f', '-']
- : configToArgs(options.config)
-
- composeArgs = composeArgs.concat(
- configArgs.concat(
- [command].concat(composeOptionsToArgs(commandOptions), args)
- )
- )
-
- const cwd = options.cwd
- const env = options.env || undefined
- const executablePath = options.executablePath || 'docker-compose'
-
- const childProc = childProcess.spawn(executablePath, composeArgs, {
- cwd,
- env
- })
-
- childProc.on('error', (err): void => {
- reject(err)
- })
-
- const result: IDockerComposeResult = {
- exitCode: null,
- err: '',
- out: ''
- }
-
- childProc.stdout.on('data', (chunk): void => {
- result.out += chunk.toString()
- options.callback?.(chunk, 'stdout')
- })
-
- childProc.stderr.on('data', (chunk): void => {
- result.err += chunk.toString()
- options.callback?.(chunk, 'stderr')
- })
-
- childProc.on('exit', (exitCode): void => {
- result.exitCode = exitCode
- if (exitCode === 0) {
- resolve(result)
- } else {
- reject(result)
- }
- })
-
- if (isConfigProvidedAsString) {
- childProc.stdin.write(options.configAsString)
- childProc.stdin.end()
- }
-
- if (options.log) {
- childProc.stdout.pipe(process.stdout)
- childProc.stderr.pipe(process.stderr)
- }
- })
-
-/**
- * Determines whether or not to use the default non-interactive flag -d for up commands
- */
-const shouldUseDefaultNonInteractiveFlag = function (
- options: IDockerComposeOptions = {}
-): boolean {
- const commandOptions = options.commandOptions || []
- const containsOtherNonInteractiveFlag = commandOptions.reduce(
- (memo: boolean, item: string | string[]) => {
- return (
- memo &&
- !item.includes('--abort-on-container-exit') &&
- !item.includes('--no-start')
- )
- },
- true
- )
- return containsOtherNonInteractiveFlag
-}
-
-export const upAll = function (
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : []
- return execCompose('up', args, options)
-}
-
-export const upMany = function (
- services: string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d'].concat(services)
- : services
- return execCompose('up', args, options)
-}
-
-export const upOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d', service]
- : [service]
- return execCompose('up', args, options)
-}
-
-export const down = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('down', [], options)
-}
-
-export const stop = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('stop', [], options)
-}
-
-export const stopOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('stop', [service], options)
-}
-
-export const stopMany = function (
- options?: IDockerComposeOptions,
- ...services: string[]
-): Promise {
- return execCompose('stop', [...services], options)
-}
-
-export const pauseOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('pause', [service], options)
-}
-
-export const unpauseOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('unpause', [service], options)
-}
-
-export const kill = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('kill', [], options)
-}
-
-export const rm = function (
- options?: IDockerComposeOptions,
- ...services: string[]
-): Promise {
- return execCompose('rm', ['-f', ...services], options)
-}
-
-export const exec = function (
- container: string,
- command: string | string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = Array.isArray(command) ? command : command.split(/\s+/)
-
- return execCompose('exec', ['-T', container].concat(args), options)
-}
-
-export const run = function (
- container: string,
- command: string | string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = Array.isArray(command) ? command : command.split(/\s+/)
-
- return execCompose('run', ['-T', container].concat(args), options)
-}
-
-export const buildAll = function (
- options: IDockerComposeBuildOptions = {}
-): Promise {
- return execCompose('build', options.parallel ? ['--parallel'] : [], options)
-}
-
-export const buildMany = function (
- services: string[],
- options: IDockerComposeBuildOptions = {}
-): Promise {
- return execCompose(
- 'build',
- options.parallel ? ['--parallel'].concat(services) : services,
- options
- )
-}
-
-export const buildOne = function (
- service: string,
- options?: IDockerComposeBuildOptions
-): Promise {
- return execCompose('build', [service], options)
-}
-
-export const pullAll = function (
- options: IDockerComposeOptions = {}
-): Promise {
- return execCompose('pull', [], options)
-}
-
-export const pullMany = function (
- services: string[],
- options: IDockerComposeOptions = {}
-): Promise {
- return execCompose('pull', services, options)
-}
-
-export const pullOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('pull', [service], options)
-}
-
-export const config = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', [], options)
- const config = yaml.parse(result.out)
- return {
- ...result,
- data: { config }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const configServices = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', ['--services'], options)
- const services = result.out.split('\n').filter(nonEmptyString)
- return {
- ...result,
- data: { services }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const configVolumes = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', ['--volumes'], options)
- const volumes = result.out.split('\n').filter(nonEmptyString)
- return {
- ...result,
- data: { volumes }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const ps = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('ps', [], options)
- const data = mapPsOutput(result.out, options)
- return {
- ...result,
- data
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const push = function (
- options: IDockerComposePushOptions = {}
-): Promise {
- return execCompose(
- 'push',
- options.ignorePushFailures ? ['--ignore-push-failures'] : [],
- options
- )
-}
-
-export const restartAll = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('restart', [], options)
-}
-
-export const restartMany = function (
- services: string[],
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('restart', services, options)
-}
-
-export const restartOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return restartMany([service], options)
-}
-
-export const logs = function (
- services: string | string[],
- options: IDockerComposeLogOptions = {}
-): Promise {
- let args = Array.isArray(services) ? services : [services]
-
- if (options.follow) {
- args = ['--follow', ...args]
- }
-
- return execCompose('logs', args, options)
-}
-
-export const port = async function (
- service: string,
- containerPort: string | number,
- options?: IDockerComposeOptions
-): Promise> {
- const args = [service, containerPort]
-
- try {
- const result = await execCompose('port', args, options)
- const [address, port] = result.out.split(':')
- return {
- ...result,
- data: {
- address,
- port: Number(port)
- }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const version = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('version', ['--short'], options)
- const version = result.out.replace('\n', '').trim()
- return {
- ...result,
- data: { version }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export default {
- upAll,
- upMany,
- upOne,
- down,
- stop,
- stopOne,
- stopMany,
- pauseOne,
- unpauseOne,
- kill,
- rm,
- exec,
- run,
- buildAll,
- buildMany,
- buildOne,
- pullAll,
- pullMany,
- pullOne,
- config,
- configServices,
- configVolumes,
- ps,
- push,
- restartAll,
- restartMany,
- restartOne,
- logs,
- port,
- version
-}
-
-export * as v2 from './v2'
diff --git a/node_modules/docker-compose/src/map-ports.ts b/node_modules/docker-compose/src/map-ports.ts
deleted file mode 100644
index 417169c..0000000
--- a/node_modules/docker-compose/src/map-ports.ts
+++ /dev/null
@@ -1,38 +0,0 @@
-const mapPorts = (
- ports: string
-): Array<{
- mapped?: { address: string; port: number }
- exposed: { port: number; protocol: string }
-}> => {
- if (!ports) {
- return []
- }
-
- return ports.split(',').map((untypedPort) => {
- const exposedFragments = untypedPort.trim().split('->')
-
- const [port, protocol] =
- exposedFragments.length === 1
- ? exposedFragments[0].split('/')
- : exposedFragments[1].split('/')
-
- const mapped = exposedFragments[0]
- const lastDoubleColon = mapped.lastIndexOf(':')
-
- if (lastDoubleColon === -1) {
- return {
- exposed: { port: Number(port), protocol }
- }
- }
-
- const address = mapped.substr(0, lastDoubleColon)
- const mappedPort = mapped.substr(lastDoubleColon + 1)
-
- return {
- exposed: { port: Number(port), protocol },
- mapped: { port: Number(mappedPort), address }
- }
- })
-}
-
-export default mapPorts
diff --git a/node_modules/docker-compose/src/v2-map-ports.ts b/node_modules/docker-compose/src/v2-map-ports.ts
deleted file mode 100644
index 417169c..0000000
--- a/node_modules/docker-compose/src/v2-map-ports.ts
+++ /dev/null
@@ -1,38 +0,0 @@
-const mapPorts = (
- ports: string
-): Array<{
- mapped?: { address: string; port: number }
- exposed: { port: number; protocol: string }
-}> => {
- if (!ports) {
- return []
- }
-
- return ports.split(',').map((untypedPort) => {
- const exposedFragments = untypedPort.trim().split('->')
-
- const [port, protocol] =
- exposedFragments.length === 1
- ? exposedFragments[0].split('/')
- : exposedFragments[1].split('/')
-
- const mapped = exposedFragments[0]
- const lastDoubleColon = mapped.lastIndexOf(':')
-
- if (lastDoubleColon === -1) {
- return {
- exposed: { port: Number(port), protocol }
- }
- }
-
- const address = mapped.substr(0, lastDoubleColon)
- const mappedPort = mapped.substr(lastDoubleColon + 1)
-
- return {
- exposed: { port: Number(port), protocol },
- mapped: { port: Number(mappedPort), address }
- }
- })
-}
-
-export default mapPorts
diff --git a/node_modules/docker-compose/src/v2.ts b/node_modules/docker-compose/src/v2.ts
deleted file mode 100644
index 48fd670..0000000
--- a/node_modules/docker-compose/src/v2.ts
+++ /dev/null
@@ -1,575 +0,0 @@
-import childProcess from 'child_process'
-import yaml from 'yaml'
-import mapPorts from './v2-map-ports'
-
-export interface IDockerComposeOptions {
- cwd?: string
- executablePath?: string
- config?: string | string[]
- configAsString?: string
- log?: boolean
- composeOptions?: string[] | (string | string[])[]
- commandOptions?: string[] | (string | string[])[]
- env?: NodeJS.ProcessEnv
- callback?: (chunk: Buffer, streamSource?: 'stdout' | 'stderr') => void
-}
-
-export type DockerComposePortResult = {
- address: string
- port: number
-}
-
-export type DockerComposeVersionResult = {
- version: string
-}
-
-export type DockerComposeConfigResult = {
- config: {
- version: Record
- services: Record>
- volumes: Record
- }
-}
-
-export type DockerComposeConfigServicesResult = {
- services: string[]
-}
-
-export type DockerComposeConfigVolumesResult = {
- volumes: string[]
-}
-
-export interface IDockerComposeLogOptions extends IDockerComposeOptions {
- follow?: boolean
-}
-
-export interface IDockerComposeBuildOptions extends IDockerComposeOptions {
- parallel?: boolean
-}
-
-export interface IDockerComposePushOptions extends IDockerComposeOptions {
- ignorePushFailures?: boolean
-}
-
-export interface IDockerComposeResult {
- exitCode: number | null
- out: string
- err: string
-}
-
-export type TypedDockerComposeResult = {
- exitCode: number | null
- out: string
- err: string
- data: T
-}
-
-const nonEmptyString = (v: string) => v !== ''
-
-export type DockerComposePsResult = {
- services: Array<{
- name: string
- command: string
- state: string
- ports: Array<{
- mapped?: { address: string; port: number }
- exposed: { port: number; protocol: string }
- }>
- }>
-}
-
-export const mapPsOutput = (
- output: string,
- options?: IDockerComposeOptions
-): DockerComposePsResult => {
- let isQuiet = false
- if (options?.commandOptions) {
- isQuiet =
- options.commandOptions.includes('-q') ||
- options.commandOptions.includes('--quiet') ||
- options.commandOptions.includes('--services')
- }
- const services = output
- .split(`\n`)
- .filter(nonEmptyString)
- .filter((_, index) => isQuiet || index >= 1)
- .map((line) => {
- let nameFragment = line
- let commandFragment = ''
- let imageFragment = ''
- let serviceFragment = ''
- let createdFragment = ''
- let stateFragment = ''
- let untypedPortsFragment = ''
- if (!isQuiet) {
- ;[
- nameFragment,
- imageFragment,
- commandFragment,
- serviceFragment,
- createdFragment,
- stateFragment,
- untypedPortsFragment
- ] = line.split(/\s{3,}/)
- }
- return {
- name: nameFragment.trim(),
- command: commandFragment.trim(),
- state: stateFragment.trim(),
- ports: mapPorts(untypedPortsFragment.trim())
- }
- })
- return { services }
-}
-
-/**
- * Converts supplied yml files to cli arguments
- * https://docs.docker.com/compose/reference/overview/#use--f-to-specify-name-and-path-of-one-or-more-compose-files
- */
-const configToArgs = (config): string[] => {
- if (typeof config === 'undefined') {
- return []
- } else if (typeof config === 'string') {
- return ['-f', config]
- } else if (config instanceof Array) {
- return config.reduce(
- (args, item): string[] => args.concat(['-f', item]),
- []
- )
- }
- throw new Error(`Invalid argument supplied: ${config}`)
-}
-
-/**
- * Converts docker compose commandline options to cli arguments
- */
-const composeOptionsToArgs = (composeOptions): string[] => {
- let composeArgs: string[] = []
-
- composeOptions.forEach((option: string[] | string): void => {
- if (option instanceof Array) {
- composeArgs = composeArgs.concat(option)
- }
- if (typeof option === 'string') {
- composeArgs = composeArgs.concat([option])
- }
- })
-
- return composeArgs
-}
-
-/**
- * Executes docker compose command with common options
- */
-export const execCompose = (
- command,
- args,
- options: IDockerComposeOptions = {}
-): Promise =>
- new Promise((resolve, reject): void => {
- const composeOptions = options.composeOptions || []
- const commandOptions = options.commandOptions || []
- let composeArgs = composeOptionsToArgs(composeOptions)
- const isConfigProvidedAsString = !!options.configAsString
-
- const configArgs = isConfigProvidedAsString
- ? ['-f', '-']
- : configToArgs(options.config)
-
- composeArgs = composeArgs.concat(
- configArgs.concat(
- [command].concat(composeOptionsToArgs(commandOptions), args)
- )
- )
-
- const cwd = options.cwd
- const env = options.env || undefined
- const executablePath = options.executablePath || 'docker'
-
- const childProc = childProcess.spawn(
- executablePath,
- ['compose', ...composeArgs],
- {
- cwd,
- env
- }
- )
-
- childProc.on('error', (err): void => {
- reject(err)
- })
-
- const result: IDockerComposeResult = {
- exitCode: null,
- err: '',
- out: ''
- }
-
- childProc.stdout.on('data', (chunk): void => {
- result.out += chunk.toString()
- options.callback?.(chunk, 'stdout')
- })
-
- childProc.stderr.on('data', (chunk): void => {
- result.err += chunk.toString()
- options.callback?.(chunk, 'stderr')
- })
-
- childProc.on('exit', (exitCode): void => {
- result.exitCode = exitCode
- setTimeout(() => {
- if (exitCode === 0) {
- resolve(result)
- } else {
- reject(result)
- }
- }, 500)
- })
-
- if (isConfigProvidedAsString) {
- childProc.stdin.write(options.configAsString)
- childProc.stdin.end()
- }
-
- if (options.log) {
- childProc.stdout.pipe(process.stdout)
- childProc.stderr.pipe(process.stderr)
- }
- })
-
-/**
- * Determines whether or not to use the default non-interactive flag -d for up commands
- */
-const shouldUseDefaultNonInteractiveFlag = function (
- options: IDockerComposeOptions = {}
-): boolean {
- const commandOptions = options.commandOptions || []
- const containsOtherNonInteractiveFlag = commandOptions.reduce(
- (memo: boolean, item: string | string[]) => {
- return (
- memo &&
- !item.includes('--abort-on-container-exit') &&
- !item.includes('--no-start')
- )
- },
- true
- )
- return containsOtherNonInteractiveFlag
-}
-
-export const upAll = function (
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : []
- return execCompose('up', args, options)
-}
-
-export const upMany = function (
- services: string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d'].concat(services)
- : services
- return execCompose('up', args, options)
-}
-
-export const upOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- const args = shouldUseDefaultNonInteractiveFlag(options)
- ? ['-d', service]
- : [service]
- return execCompose('up', args, options)
-}
-
-export const down = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('down', [], options)
-}
-
-export const stop = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('stop', [], options)
-}
-
-export const stopOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('stop', [service], options)
-}
-
-export const stopMany = function (
- options?: IDockerComposeOptions,
- ...services: string[]
-): Promise {
- return execCompose('stop', [...services], options)
-}
-
-export const pauseOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('pause', [service], options)
-}
-
-export const unpauseOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('unpause', [service], options)
-}
-
-export const kill = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('kill', [], options)
-}
-
-export const rm = function (
- options?: IDockerComposeOptions,
- ...services: string[]
-): Promise {
- return execCompose('rm', ['-f', ...services], options)
-}
-
-export const exec = function (
- container: string,
- command: string | string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = Array.isArray(command) ? command : command.split(/\s+/)
-
- return execCompose('exec', ['-T', container].concat(args), options)
-}
-
-export const run = function (
- container: string,
- command: string | string[],
- options?: IDockerComposeOptions
-): Promise {
- const args = Array.isArray(command) ? command : command.split(/\s+/)
-
- return execCompose('run', ['-T', container].concat(args), options)
-}
-
-export const buildAll = function (
- options: IDockerComposeBuildOptions = {}
-): Promise {
- return execCompose('build', options.parallel ? ['--parallel'] : [], options)
-}
-
-export const buildMany = function (
- services: string[],
- options: IDockerComposeBuildOptions = {}
-): Promise {
- return execCompose(
- 'build',
- options.parallel ? ['--parallel'].concat(services) : services,
- options
- )
-}
-
-export const buildOne = function (
- service: string,
- options?: IDockerComposeBuildOptions
-): Promise {
- return execCompose('build', [service], options)
-}
-
-export const pullAll = function (
- options: IDockerComposeOptions = {}
-): Promise {
- return execCompose('pull', [], options)
-}
-
-export const pullMany = function (
- services: string[],
- options: IDockerComposeOptions = {}
-): Promise {
- return execCompose('pull', services, options)
-}
-
-export const pullOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('pull', [service], options)
-}
-
-export const config = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', [], options)
- const config = yaml.parse(result.out)
- return {
- ...result,
- data: { config }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const configServices = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', ['--services'], options)
- const services = result.out.split('\n').filter(nonEmptyString)
- return {
- ...result,
- data: { services }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const configVolumes = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('config', ['--volumes'], options)
- const volumes = result.out.split('\n').filter(nonEmptyString)
- return {
- ...result,
- data: { volumes }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const ps = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('ps', [], options)
- const data = mapPsOutput(result.out, options)
- return {
- ...result,
- data
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const push = function (
- options: IDockerComposePushOptions = {}
-): Promise {
- return execCompose(
- 'push',
- options.ignorePushFailures ? ['--ignore-push-failures'] : [],
- options
- )
-}
-
-export const restartAll = function (
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('restart', [], options)
-}
-
-export const restartMany = function (
- services: string[],
- options?: IDockerComposeOptions
-): Promise {
- return execCompose('restart', services, options)
-}
-
-export const restartOne = function (
- service: string,
- options?: IDockerComposeOptions
-): Promise {
- return restartMany([service], options)
-}
-
-export const logs = function (
- services: string | string[],
- options: IDockerComposeLogOptions = {}
-): Promise {
- let args = Array.isArray(services) ? services : [services]
-
- if (options.follow) {
- args = ['--follow', ...args]
- }
-
- return execCompose('logs', args, options)
-}
-
-export const port = async function (
- service: string,
- containerPort: string | number,
- options?: IDockerComposeOptions
-): Promise> {
- const args = [service, containerPort]
-
- try {
- const result = await execCompose('port', args, options)
- const [address, port] = result.out.split(':')
- return {
- ...result,
- data: {
- address,
- port: Number(port)
- }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export const version = async function (
- options?: IDockerComposeOptions
-): Promise> {
- try {
- const result = await execCompose('version', ['--short'], options)
- const version = result.out.replace('\n', '').trim()
- return {
- ...result,
- data: { version }
- }
- } catch (error) {
- return Promise.reject(error)
- }
-}
-
-export default {
- upAll,
- upMany,
- upOne,
- down,
- stop,
- stopOne,
- stopMany,
- pauseOne,
- unpauseOne,
- kill,
- rm,
- exec,
- run,
- buildAll,
- buildMany,
- buildOne,
- pullAll,
- pullMany,
- pullOne,
- config,
- configServices,
- configVolumes,
- ps,
- push,
- restartAll,
- restartMany,
- restartOne,
- logs,
- port,
- version
-}
diff --git a/node_modules/docker-compose/tsconfig.json b/node_modules/docker-compose/tsconfig.json
index 93838df..429cbf3 100644
--- a/node_modules/docker-compose/tsconfig.json
+++ b/node_modules/docker-compose/tsconfig.json
@@ -5,7 +5,8 @@
"target": "es5" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */,
"module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */,
"lib": [
- "es2015"
+ "es2015",
+ "dom"
] /* Specify library files to be included in the compilation. */,
// "allowJs": true, /* Allow javascript files to be compiled. */
// "checkJs": true, /* Report errors in .js files. */
diff --git a/node_modules/eslint-plugin-prettier/node_modules/.bin/eslint b/node_modules/eslint-plugin-prettier/node_modules/.bin/eslint
new file mode 120000
index 0000000..fad93f5
--- /dev/null
+++ b/node_modules/eslint-plugin-prettier/node_modules/.bin/eslint
@@ -0,0 +1 @@
+../../../eslint/bin/eslint.js
\ No newline at end of file
diff --git a/node_modules/eslint-plugin-prettier/node_modules/.bin/prettier b/node_modules/eslint-plugin-prettier/node_modules/.bin/prettier
new file mode 120000
index 0000000..60fde4f
--- /dev/null
+++ b/node_modules/eslint-plugin-prettier/node_modules/.bin/prettier
@@ -0,0 +1 @@
+../../../prettier/bin-prettier.js
\ No newline at end of file
diff --git a/node_modules/espree/node_modules/.bin/acorn b/node_modules/espree/node_modules/.bin/acorn
new file mode 120000
index 0000000..fa65fee
--- /dev/null
+++ b/node_modules/espree/node_modules/.bin/acorn
@@ -0,0 +1 @@
+../../../acorn/bin/acorn
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index 4bdd541..3722f8e 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -11,7 +11,7 @@
"dependencies": {
"@actions/core": "^1.8.2",
"@actions/github": "^4.0.0",
- "docker-compose": "^0.24.0"
+ "docker-compose": "^0.24.3"
},
"devDependencies": {
"eslint": "^8.24.0",
@@ -470,9 +470,9 @@
"integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ=="
},
"node_modules/docker-compose": {
- "version": "0.24.1",
- "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.1.tgz",
- "integrity": "sha512-CVphzCi0Hmw/0CHlAzgiwhLsJjFRqnvpBYMYbf63bz6MON69ElgrfrgQTmgPtEjbifjgaptu3+Gea62vI+9jiA==",
+ "version": "0.24.3",
+ "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.3.tgz",
+ "integrity": "sha512-x3/QN3AIOMe7j2c8f/jcycizMft7dl8MluoB9OGPAYCyKHHiPUFqI9GjCcsU0kYy24vYKMCcfR6+5ZaEyQlrxg==",
"dependencies": {
"yaml": "^2.2.2"
},
@@ -1777,9 +1777,9 @@
"integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ=="
},
"docker-compose": {
- "version": "0.24.1",
- "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.1.tgz",
- "integrity": "sha512-CVphzCi0Hmw/0CHlAzgiwhLsJjFRqnvpBYMYbf63bz6MON69ElgrfrgQTmgPtEjbifjgaptu3+Gea62vI+9jiA==",
+ "version": "0.24.3",
+ "resolved": "https://registry.npmjs.org/docker-compose/-/docker-compose-0.24.3.tgz",
+ "integrity": "sha512-x3/QN3AIOMe7j2c8f/jcycizMft7dl8MluoB9OGPAYCyKHHiPUFqI9GjCcsU0kYy24vYKMCcfR6+5ZaEyQlrxg==",
"requires": {
"yaml": "^2.2.2"
}
diff --git a/package.json b/package.json
index debc4b0..70ecf13 100644
--- a/package.json
+++ b/package.json
@@ -15,7 +15,7 @@
"dependencies": {
"@actions/core": "^1.8.2",
"@actions/github": "^4.0.0",
- "docker-compose": "^0.24.0"
+ "docker-compose": "^0.24.3"
},
"devDependencies": {
"eslint": "^8.24.0",
diff --git a/post.js b/post.js
index 0720c9a..a7e5774 100644
--- a/post.js
+++ b/post.js
@@ -18,6 +18,7 @@ try {
const options = {
config: composeFiles,
+ cwd: core.getInput("cwd"),
log: true,
composeOptions: utils.parseFlags(core.getInput("compose-flags")),
commandOptions: utils.parseFlags(core.getInput("down-flags")),
diff --git a/utils.js b/utils.js
index 83d7afd..4715f5c 100644
--- a/utils.js
+++ b/utils.js
@@ -15,7 +15,7 @@ module.exports.parseComposeFiles = (composeFiles) => {
}
if (!fs.existsSync(composeFile)) {
- console.log(`${composeFile} not exists`);
+ console.log(`${composeFile} does not exist`);
return false;
}