mirror of
https://github.com/hoverkraft-tech/compose-action.git
synced 2026-01-14 00:23:08 +08:00
Compare commits
3 Commits
1d127c94a3
...
14ab51d9bf
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
14ab51d9bf | ||
|
|
714591cd55 | ||
|
|
86e13c8bea |
@ -4,7 +4,7 @@
|
||||
|
||||
```yaml
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@v4.2.2
|
||||
- uses: hoverkraft-tech/compose-action@v1.5.1
|
||||
with:
|
||||
compose-file: "./docker/docker-compose.yml"
|
||||
|
||||
28
.github/workflows/__check-action.yml
vendored
28
.github/workflows/__check-action.yml
vendored
@ -11,7 +11,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with services
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -33,7 +33,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test compose action
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -45,7 +45,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with compose flags
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -62,7 +62,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with env
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -83,7 +83,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with multiple compose files
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -108,7 +108,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with cwd
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -131,7 +131,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with absolute path
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -153,7 +153,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with --abort-on-container-exit
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -165,7 +165,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with --attach-dependencies and service failure
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Act
|
||||
uses: ./
|
||||
@ -184,7 +184,7 @@ jobs:
|
||||
env:
|
||||
DOCKER_COMPOSE_VERSION: "2.29.0"
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: "Arrange: ensure original docker compose version is not the expected one"
|
||||
run: |
|
||||
@ -216,10 +216,10 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with compose version latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: "Arrange: retrieve latest version of docker compose"
|
||||
uses: actions/github-script@v7
|
||||
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
|
||||
with:
|
||||
script: |
|
||||
const dockerComposeVersion = (await github.rest.repos.getLatestRelease({
|
||||
@ -259,10 +259,10 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
name: Test with docker context
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Set up Docker
|
||||
uses: docker/setup-docker-action@v4
|
||||
uses: docker/setup-docker-action@b60f85385d03ac8acfca6d9996982511d8620a19 # v4.3.0
|
||||
with:
|
||||
context: test-context
|
||||
|
||||
|
||||
6
.github/workflows/__check-dist.yml
vendored
6
.github/workflows/__check-dist.yml
vendored
@ -11,8 +11,8 @@ jobs:
|
||||
name: Check dist
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: hoverkraft-tech/ci-github-nodejs/actions/setup-node@0.9.0
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
- uses: hoverkraft-tech/ci-github-nodejs/actions/setup-node@0c281f43dd49fcdec089c67ee99819620d634046 # 0.10.0
|
||||
|
||||
- name: Build dist/ Directory
|
||||
id: package
|
||||
@ -33,7 +33,7 @@ jobs:
|
||||
- if: ${{ failure() && steps.diff.outcome == 'failure' }}
|
||||
name: Upload Artifact
|
||||
id: upload
|
||||
uses: actions/upload-artifact@v4
|
||||
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
|
||||
with:
|
||||
name: dist
|
||||
path: dist/
|
||||
|
||||
2
.github/workflows/__check-nodejs.yml
vendored
2
.github/workflows/__check-nodejs.yml
vendored
@ -10,7 +10,7 @@ permissions:
|
||||
|
||||
jobs:
|
||||
test-nodejs:
|
||||
uses: hoverkraft-tech/ci-github-nodejs/.github/workflows/continuous-integration.yml@0.9.0
|
||||
uses: hoverkraft-tech/ci-github-nodejs/.github/workflows/continuous-integration.yml@0c281f43dd49fcdec089c67ee99819620d634046 # 0.10.0
|
||||
permissions:
|
||||
id-token: write
|
||||
security-events: write
|
||||
|
||||
4
.github/workflows/__shared-ci.yml
vendored
4
.github/workflows/__shared-ci.yml
vendored
@ -6,13 +6,13 @@ on:
|
||||
permissions:
|
||||
contents: read
|
||||
packages: read
|
||||
statuses: write
|
||||
security-events: write
|
||||
statuses: write
|
||||
id-token: write
|
||||
|
||||
jobs:
|
||||
linter:
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/linter.yml@0.18.0
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/linter.yml@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
with:
|
||||
linter-env: |
|
||||
FILTER_REGEX_EXCLUDE=dist/**/*
|
||||
|
||||
2
.github/workflows/greetings.yml
vendored
2
.github/workflows/greetings.yml
vendored
@ -13,4 +13,4 @@ permissions:
|
||||
|
||||
jobs:
|
||||
greetings:
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/greetings.yml@0.18.0
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/greetings.yml@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
|
||||
23
.github/workflows/main-ci.yml
vendored
23
.github/workflows/main-ci.yml
vendored
@ -5,11 +5,17 @@ on:
|
||||
branches: [main]
|
||||
tags: ["*"]
|
||||
|
||||
workflow_dispatch:
|
||||
|
||||
schedule:
|
||||
- cron: "25 8 * * 1"
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
packages: read
|
||||
statuses: write
|
||||
security-events: write
|
||||
statuses: write
|
||||
# FIXME: This is a workaround for having workflow ref. See https://github.com/orgs/community/discussions/38659
|
||||
id-token: write
|
||||
|
||||
concurrency:
|
||||
@ -21,23 +27,24 @@ jobs:
|
||||
uses: ./.github/workflows/__shared-ci.yml
|
||||
secrets: inherit
|
||||
|
||||
generate-readme:
|
||||
release:
|
||||
needs: ci
|
||||
if: github.event_name != 'schedule'
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: bitflight-devops/github-action-readme-generator@v1.8.0
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
- uses: bitflight-devops/github-action-readme-generator@f750ff0ac8a4b68a3c2d622cc50a5ad20bcebaa1 # v1.8.0
|
||||
with:
|
||||
owner: hoverkraft-tech
|
||||
repo: compose-action
|
||||
owner: ${{ github.repository_owner }}
|
||||
repo: ${{ github.event.repository.name }}
|
||||
|
||||
- uses: actions/create-github-app-token@v1
|
||||
- uses: actions/create-github-app-token@af35edadc00be37caa72ed9f3e6d5f7801bfdf09 # v1.11.7
|
||||
id: generate-token
|
||||
with:
|
||||
app-id: ${{ vars.CI_BOT_APP_ID }}
|
||||
private-key: ${{ secrets.CI_BOT_APP_PRIVATE_KEY }}
|
||||
|
||||
- uses: hoverkraft-tech/ci-github-common/actions/create-and-merge-pull-request@0.18.0
|
||||
- uses: hoverkraft-tech/ci-github-common/actions/create-and-merge-pull-request@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
with:
|
||||
github-token: ${{ steps.generate-token.outputs.token }}
|
||||
branch: docs/actions-workflows-documentation-update
|
||||
|
||||
2
.github/workflows/need-fix-to-issue.yml
vendored
2
.github/workflows/need-fix-to-issue.yml
vendored
@ -21,7 +21,7 @@ permissions:
|
||||
|
||||
jobs:
|
||||
main:
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/need-fix-to-issue.yml@0.18.0
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/need-fix-to-issue.yml@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
with:
|
||||
manual-commit-ref: ${{ inputs.manual-commit-ref }}
|
||||
manual-base-ref: ${{ inputs.manual-base-ref }}
|
||||
|
||||
@ -24,6 +24,6 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Update the ${{ env.TAG_NAME }} tag
|
||||
uses: actions/publish-action@v0.3.0
|
||||
uses: actions/publish-action@f784495ce78a41bac4ed7e34a73f0034015764bb # v0.3.0
|
||||
with:
|
||||
source-tag: ${{ env.TAG_NAME }}
|
||||
|
||||
2
.github/workflows/semantic-pull-request.yml
vendored
2
.github/workflows/semantic-pull-request.yml
vendored
@ -13,4 +13,4 @@ permissions:
|
||||
|
||||
jobs:
|
||||
main:
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/semantic-pull-request.yml@0.18.0
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/semantic-pull-request.yml@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
|
||||
2
.github/workflows/stale.yml
vendored
2
.github/workflows/stale.yml
vendored
@ -10,4 +10,4 @@ permissions:
|
||||
|
||||
jobs:
|
||||
main:
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/stale.yml@0.18.0
|
||||
uses: hoverkraft-tech/ci-github-common/.github/workflows/stale.yml@edc1e53751a82ce335e7c3208a32b6ee03856a9f # 0.20.0
|
||||
|
||||
@ -10,11 +10,13 @@
|
||||
# <img src=".github/ghadocs/branding.svg" width="60px" align="center" alt="branding<icon:anchor color:gray-dark>" /> GitHub Action: Docker Compose Action
|
||||
|
||||
<!-- end title -->
|
||||
<!-- markdownlint-disable MD013 -->
|
||||
<!-- start badges -->
|
||||
|
||||
<a href="https%3A%2F%2Fgithub.com%2Fhoverkraft-tech%2Fcompose-action%2Freleases%2Flatest"><img src="https://img.shields.io/github/v/release/hoverkraft-tech/compose-action?display_name=tag&sort=semver&logo=github&style=flat-square" alt="Release%20by%20tag" /></a><a href="https%3A%2F%2Fgithub.com%2Fhoverkraft-tech%2Fcompose-action%2Freleases%2Flatest"><img src="https://img.shields.io/github/release-date/hoverkraft-tech/compose-action?display_name=tag&sort=semver&logo=github&style=flat-square" alt="Release%20by%20date" /></a><img src="https://img.shields.io/github/last-commit/hoverkraft-tech/compose-action?logo=github&style=flat-square" alt="Commit" /><a href="https%3A%2F%2Fgithub.com%2Fhoverkraft-tech%2Fcompose-action%2Fissues"><img src="https://img.shields.io/github/issues/hoverkraft-tech/compose-action?logo=github&style=flat-square" alt="Open%20Issues" /></a><img src="https://img.shields.io/github/downloads/hoverkraft-tech/compose-action/total?logo=github&style=flat-square" alt="Downloads" />
|
||||
|
||||
<!-- end badges -->
|
||||
<!-- markdownlint-enable MD013 -->
|
||||
|
||||
</div>
|
||||
<!-- start description -->
|
||||
@ -128,7 +130,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@v4.2.2
|
||||
|
||||
- name: Run docker compose
|
||||
uses: hoverkraft-tech/compose-action@v2.0.1
|
||||
@ -147,7 +149,7 @@ jobs:
|
||||
|
||||
```yaml
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@v4.2.2
|
||||
- uses: hoverkraft-tech/compose-action@v2.0.1
|
||||
with:
|
||||
compose-file: "./docker/docker-compose.yml"
|
||||
|
||||
704
dist/index.js
generated
vendored
704
dist/index.js
generated
vendored
File diff suppressed because it is too large
Load Diff
667
dist/post.js
generated
vendored
667
dist/post.js
generated
vendored
@ -3191,107 +3191,49 @@ function copyFile(srcFile, destFile, force) {
|
||||
|
||||
"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.stats = exports.version = exports.port = exports.logs = exports.restartOne = exports.restartMany = exports.restartAll = exports.push = exports.images = exports.ps = exports.configVolumes = exports.configServices = exports.config = exports.pullOne = exports.pullMany = exports.pullAll = exports.createOne = exports.createMany = exports.createAll = 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.downOne = exports.downMany = exports.down = exports.downAll = exports.upOne = exports.upMany = exports.upAll = exports.execCompose = exports.mapImListOutput = exports.mapPsOutput = void 0;
|
||||
var child_process_1 = __importDefault(__nccwpck_require__(5317));
|
||||
var yaml_1 = __importDefault(__nccwpck_require__(8815));
|
||||
var map_ports_1 = __importDefault(__nccwpck_require__(9653));
|
||||
var nonEmptyString = function (v) { return v !== ''; };
|
||||
var arrayIncludesTuple = function (arr, tuple) {
|
||||
return arr.some(function (subArray) {
|
||||
return Array.isArray(subArray) &&
|
||||
const child_process_1 = __importDefault(__nccwpck_require__(5317));
|
||||
const yaml_1 = __importDefault(__nccwpck_require__(8815));
|
||||
const map_ports_1 = __importDefault(__nccwpck_require__(9653));
|
||||
const nonEmptyString = (v) => v !== '';
|
||||
const arrayIncludesTuple = (arr, tuple) => {
|
||||
return arr.some((subArray) => Array.isArray(subArray) &&
|
||||
subArray.length === tuple.length &&
|
||||
subArray.every(function (value, index) { return value === tuple[index]; });
|
||||
});
|
||||
subArray.every((value, index) => value === tuple[index]));
|
||||
};
|
||||
var mapPsOutput = function (output, options) {
|
||||
var isQuiet = false;
|
||||
var isJson = false;
|
||||
if (options === null || options === void 0 ? void 0 : options.commandOptions) {
|
||||
const mapPsOutput = (output, options) => {
|
||||
let isQuiet = false;
|
||||
let isJson = false;
|
||||
if (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")
|
||||
const services = output
|
||||
.split(`\n`)
|
||||
.filter(nonEmptyString)
|
||||
.filter(function (_, index) { return isQuiet || isJson || index >= 1; })
|
||||
.map(function (line) {
|
||||
var nameFragment = line;
|
||||
var commandFragment = '';
|
||||
var stateFragment = '';
|
||||
var untypedPortsFragment = '';
|
||||
.filter((_, index) => isQuiet || isJson || index >= 1)
|
||||
.map((line) => {
|
||||
let nameFragment = line;
|
||||
let commandFragment = '';
|
||||
let stateFragment = '';
|
||||
let untypedPortsFragment = '';
|
||||
if (!isQuiet) {
|
||||
if (isJson) {
|
||||
var serviceLine = JSON.parse(line);
|
||||
const serviceLine = JSON.parse(line);
|
||||
nameFragment = serviceLine.Name;
|
||||
commandFragment = serviceLine.Command;
|
||||
stateFragment = serviceLine.State;
|
||||
untypedPortsFragment = serviceLine.Ports;
|
||||
}
|
||||
else {
|
||||
var lineColumns = line.split(/\s{3,}/);
|
||||
const 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
|
||||
@ -3308,24 +3250,24 @@ var mapPsOutput = function (output, options) {
|
||||
ports: (0, map_ports_1.default)(untypedPortsFragment.trim())
|
||||
};
|
||||
});
|
||||
return { services: services };
|
||||
return { services };
|
||||
};
|
||||
exports.mapPsOutput = mapPsOutput;
|
||||
var mapImListOutput = function (output, options) {
|
||||
var isQuiet = false;
|
||||
var isJson = false;
|
||||
if (options === null || options === void 0 ? void 0 : options.commandOptions) {
|
||||
const mapImListOutput = (output, options) => {
|
||||
let isQuiet = false;
|
||||
let isJson = false;
|
||||
if (options?.commandOptions) {
|
||||
isQuiet =
|
||||
options.commandOptions.includes('-q') ||
|
||||
options.commandOptions.includes('--quiet');
|
||||
isJson = arrayIncludesTuple(options.commandOptions, ['--format', 'json']);
|
||||
}
|
||||
if (isJson) {
|
||||
var data = JSON.parse(output);
|
||||
var services_1 = data.map(function (serviceLine) {
|
||||
var idFragment = serviceLine.ID;
|
||||
const data = JSON.parse(output);
|
||||
const services = data.map((serviceLine) => {
|
||||
let idFragment = serviceLine.ID;
|
||||
// trim json 64B id format "type:id" to 12B id
|
||||
var idTypeIndex = idFragment.indexOf(':');
|
||||
const idTypeIndex = idFragment.indexOf(':');
|
||||
if (idTypeIndex > 0)
|
||||
idFragment = idFragment.slice(idTypeIndex + 1, idTypeIndex + 13);
|
||||
return {
|
||||
@ -3335,20 +3277,20 @@ var mapImListOutput = function (output, options) {
|
||||
id: idFragment
|
||||
};
|
||||
});
|
||||
return { services: services_1 };
|
||||
return { services };
|
||||
}
|
||||
var services = output
|
||||
.split("\n")
|
||||
const services = output
|
||||
.split(`\n`)
|
||||
.filter(nonEmptyString)
|
||||
.filter(function (_, index) { return isQuiet || isJson || index >= 1; })
|
||||
.map(function (line) {
|
||||
.filter((_, index) => isQuiet || isJson || index >= 1)
|
||||
.map((line) => {
|
||||
// the line has the columns in the following order:
|
||||
// CONTAINER REPOSITORY TAG IMAGE ID SIZE
|
||||
var lineColumns = line.split(/\s{3,}/);
|
||||
var containerFragment = lineColumns[0] || line;
|
||||
var repositoryFragment = lineColumns[1] || '';
|
||||
var tagFragment = lineColumns[2] || '';
|
||||
var idFragment = lineColumns[3] || '';
|
||||
const lineColumns = line.split(/\s{3,}/);
|
||||
const containerFragment = lineColumns[0] || line;
|
||||
const repositoryFragment = lineColumns[1] || '';
|
||||
const tagFragment = lineColumns[2] || '';
|
||||
const idFragment = lineColumns[3] || '';
|
||||
return {
|
||||
container: containerFragment.trim(),
|
||||
repository: repositoryFragment.trim(),
|
||||
@ -3356,14 +3298,14 @@ var mapImListOutput = function (output, options) {
|
||||
id: idFragment.trim()
|
||||
};
|
||||
});
|
||||
return { services: services };
|
||||
return { services };
|
||||
};
|
||||
exports.mapImListOutput = mapImListOutput;
|
||||
/**
|
||||
* 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) {
|
||||
const configToArgs = (config) => {
|
||||
if (typeof config === 'undefined') {
|
||||
return [];
|
||||
}
|
||||
@ -3371,16 +3313,16 @@ var configToArgs = function (config) {
|
||||
return ['-f', config];
|
||||
}
|
||||
else if (config instanceof Array) {
|
||||
return config.reduce(function (args, item) { return args.concat(['-f', item]); }, []);
|
||||
return config.reduce((args, item) => args.concat(['-f', item]), []);
|
||||
}
|
||||
throw new Error("Invalid argument supplied: ".concat(config));
|
||||
throw new Error(`Invalid argument supplied: ${config}`);
|
||||
};
|
||||
/**
|
||||
* Converts docker compose commandline options to cli arguments
|
||||
*/
|
||||
var composeOptionsToArgs = function (composeOptions) {
|
||||
var composeArgs = [];
|
||||
composeOptions.forEach(function (option) {
|
||||
const composeOptionsToArgs = (composeOptions) => {
|
||||
let composeArgs = [];
|
||||
composeOptions.forEach((option) => {
|
||||
if (option instanceof Array) {
|
||||
composeArgs = composeArgs.concat(option);
|
||||
}
|
||||
@ -3393,47 +3335,51 @@ var composeOptionsToArgs = function (composeOptions) {
|
||||
/**
|
||||
* 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
|
||||
const execCompose = (command, args, options = {}) => new Promise((resolve, reject) => {
|
||||
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)));
|
||||
var cwd = options.cwd;
|
||||
var env = options.env || undefined;
|
||||
var executable = options.executable || { executablePath: 'docker' };
|
||||
var executableOptions = executable.options || [];
|
||||
var executableArgs = composeOptionsToArgs(executableOptions);
|
||||
var childProc = child_process_1.default.spawn(executable.executablePath, __spreadArray(__spreadArray(__spreadArray([], executableArgs, true), ['compose'], false), composeArgs, true), {
|
||||
cwd: cwd,
|
||||
env: env
|
||||
const cwd = options.cwd;
|
||||
const env = options.env || undefined;
|
||||
const executable = options.executable;
|
||||
let executablePath;
|
||||
let executableArgs = [];
|
||||
if (executable?.standalone && !executable.executablePath) {
|
||||
executablePath = 'docker-compose';
|
||||
}
|
||||
else {
|
||||
executablePath = executable?.executablePath || 'docker';
|
||||
const executableOptions = executable?.options || [];
|
||||
executableArgs = [...composeOptionsToArgs(executableOptions), 'compose'];
|
||||
}
|
||||
const childProc = child_process_1.default.spawn(executablePath, [...executableArgs, ...composeArgs], {
|
||||
cwd,
|
||||
env
|
||||
});
|
||||
childProc.on('error', function (err) {
|
||||
childProc.on('error', (err) => {
|
||||
reject(err);
|
||||
});
|
||||
var result = {
|
||||
const result = {
|
||||
exitCode: null,
|
||||
err: '',
|
||||
out: ''
|
||||
};
|
||||
childProc.stdout.on('data', function (chunk) {
|
||||
var _a;
|
||||
childProc.stdout.on('data', (chunk) => {
|
||||
result.out += chunk.toString();
|
||||
(_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stdout');
|
||||
options.callback?.(chunk, 'stdout');
|
||||
});
|
||||
childProc.stderr.on('data', function (chunk) {
|
||||
var _a;
|
||||
childProc.stderr.on('data', (chunk) => {
|
||||
result.err += chunk.toString();
|
||||
(_a = options.callback) === null || _a === void 0 ? void 0 : _a.call(options, chunk, 'stderr');
|
||||
options.callback?.(chunk, 'stderr');
|
||||
});
|
||||
childProc.on('exit', function (exitCode) {
|
||||
childProc.on('exit', (exitCode) => {
|
||||
result.exitCode = exitCode;
|
||||
setTimeout(function () {
|
||||
setTimeout(() => {
|
||||
if (exitCode === 0) {
|
||||
resolve(result);
|
||||
}
|
||||
@ -3451,351 +3397,269 @@ var execCompose = function (command, args, options) {
|
||||
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 noDetachModeFlags = [
|
||||
const shouldUseDefaultNonInteractiveFlag = function (options = {}) {
|
||||
const commandOptions = options.commandOptions || [];
|
||||
const noDetachModeFlags = [
|
||||
'--abort-on-container-exit',
|
||||
'--no-start',
|
||||
'--attach',
|
||||
'--attach-dependencies',
|
||||
'--exit-code-from'
|
||||
];
|
||||
var containsOtherNonInteractiveFlag = commandOptions.reduce(function (memo, item) {
|
||||
return memo && noDetachModeFlags.every(function (flag) { return !item.includes(flag); });
|
||||
const containsOtherNonInteractiveFlag = commandOptions.reduce((memo, item) => {
|
||||
return memo && noDetachModeFlags.every((flag) => !item.includes(flag));
|
||||
}, true);
|
||||
return containsOtherNonInteractiveFlag;
|
||||
};
|
||||
var upAll = function (options) {
|
||||
var args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : [];
|
||||
const upAll = function (options) {
|
||||
const args = shouldUseDefaultNonInteractiveFlag(options) ? ['-d'] : [];
|
||||
return (0, exports.execCompose)('up', args, options);
|
||||
};
|
||||
exports.upAll = upAll;
|
||||
var upMany = function (services, options) {
|
||||
var args = shouldUseDefaultNonInteractiveFlag(options)
|
||||
const upMany = function (services, options) {
|
||||
const 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)
|
||||
const upOne = function (service, options) {
|
||||
const args = shouldUseDefaultNonInteractiveFlag(options)
|
||||
? ['-d', service]
|
||||
: [service];
|
||||
return (0, exports.execCompose)('up', args, options);
|
||||
};
|
||||
exports.upOne = upOne;
|
||||
var downAll = function (options) {
|
||||
const downAll = function (options) {
|
||||
return (0, exports.execCompose)('down', [], options);
|
||||
};
|
||||
exports.downAll = downAll;
|
||||
exports.down = exports.downAll;
|
||||
var downMany = function (services, options) {
|
||||
var args = services;
|
||||
const downMany = function (services, options) {
|
||||
const args = services;
|
||||
return (0, exports.execCompose)('down', args, options);
|
||||
};
|
||||
exports.downMany = downMany;
|
||||
var downOne = function (service, options) {
|
||||
var args = [service];
|
||||
const downOne = function (service, options) {
|
||||
const args = [service];
|
||||
return (0, exports.execCompose)('down', args, options);
|
||||
};
|
||||
exports.downOne = downOne;
|
||||
var stop = function (options) {
|
||||
const stop = function (options) {
|
||||
return (0, exports.execCompose)('stop', [], options);
|
||||
};
|
||||
exports.stop = stop;
|
||||
var stopOne = function (service, options) {
|
||||
const 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);
|
||||
const stopMany = function (options, ...services) {
|
||||
return (0, exports.execCompose)('stop', [...services], options);
|
||||
};
|
||||
exports.stopMany = stopMany;
|
||||
var pauseOne = function (service, options) {
|
||||
const pauseOne = function (service, options) {
|
||||
return (0, exports.execCompose)('pause', [service], options);
|
||||
};
|
||||
exports.pauseOne = pauseOne;
|
||||
var unpauseOne = function (service, options) {
|
||||
const unpauseOne = function (service, options) {
|
||||
return (0, exports.execCompose)('unpause', [service], options);
|
||||
};
|
||||
exports.unpauseOne = unpauseOne;
|
||||
var kill = function (options) {
|
||||
const 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);
|
||||
const rm = function (options, ...services) {
|
||||
return (0, exports.execCompose)('rm', ['-f', ...services], options);
|
||||
};
|
||||
exports.rm = rm;
|
||||
var exec = function (container, command, options) {
|
||||
var args = Array.isArray(command) ? command : command.split(/\s+/);
|
||||
const exec = function (container, command, options) {
|
||||
const 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+/);
|
||||
const run = function (container, command, options) {
|
||||
const 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 = {}; }
|
||||
const buildAll = function (options = {}) {
|
||||
return (0, exports.execCompose)('build', options.parallel ? ['--parallel'] : [], options);
|
||||
};
|
||||
exports.buildAll = buildAll;
|
||||
var buildMany = function (services, options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const buildMany = function (services, options = {}) {
|
||||
return (0, exports.execCompose)('build', options.parallel ? ['--parallel'].concat(services) : services, options);
|
||||
};
|
||||
exports.buildMany = buildMany;
|
||||
var buildOne = function (service, options) {
|
||||
const buildOne = function (service, options) {
|
||||
return (0, exports.execCompose)('build', [service], options);
|
||||
};
|
||||
exports.buildOne = buildOne;
|
||||
var createAll = function (options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const createAll = function (options = {}) {
|
||||
return (0, exports.execCompose)('create', [], options);
|
||||
};
|
||||
exports.createAll = createAll;
|
||||
var createMany = function (services, options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const createMany = function (services, options = {}) {
|
||||
return (0, exports.execCompose)('create', services, options);
|
||||
};
|
||||
exports.createMany = createMany;
|
||||
var createOne = function (service, options) {
|
||||
const createOne = function (service, options) {
|
||||
return (0, exports.execCompose)('create', [service], options);
|
||||
};
|
||||
exports.createOne = createOne;
|
||||
var pullAll = function (options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const pullAll = function (options = {}) {
|
||||
return (0, exports.execCompose)('pull', [], options);
|
||||
};
|
||||
exports.pullAll = pullAll;
|
||||
var pullMany = function (services, options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const pullMany = function (services, options = {}) {
|
||||
return (0, exports.execCompose)('pull', services, options);
|
||||
};
|
||||
exports.pullMany = pullMany;
|
||||
var pullOne = function (service, options) {
|
||||
const 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*/];
|
||||
const config = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('config', [], options);
|
||||
const config = yaml_1.default.parse(result.out);
|
||||
return {
|
||||
...result,
|
||||
data: { config }
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
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*/];
|
||||
const configServices = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('config', ['--services'], options);
|
||||
const services = result.out.split('\n').filter(nonEmptyString);
|
||||
return {
|
||||
...result,
|
||||
data: { services }
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
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*/];
|
||||
const configVolumes = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('config', ['--volumes'], options);
|
||||
const volumes = result.out.split('\n').filter(nonEmptyString);
|
||||
return {
|
||||
...result,
|
||||
data: { volumes }
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
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*/];
|
||||
const ps = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('ps', [], options);
|
||||
const data = (0, exports.mapPsOutput)(result.out, options);
|
||||
return {
|
||||
...result,
|
||||
data
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
exports.ps = ps;
|
||||
var images = function (options) {
|
||||
return __awaiter(this, void 0, void 0, function () {
|
||||
var result, data, error_5;
|
||||
return __generator(this, function (_a) {
|
||||
switch (_a.label) {
|
||||
case 0:
|
||||
_a.trys.push([0, 2, , 3]);
|
||||
return [4 /*yield*/, (0, exports.execCompose)('images', [], options)];
|
||||
case 1:
|
||||
result = _a.sent();
|
||||
data = (0, exports.mapImListOutput)(result.out, options);
|
||||
return [2 /*return*/, __assign(__assign({}, result), { data: data })];
|
||||
case 2:
|
||||
error_5 = _a.sent();
|
||||
return [2 /*return*/, Promise.reject(error_5)];
|
||||
case 3: return [2 /*return*/];
|
||||
const images = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('images', [], options);
|
||||
const data = (0, exports.mapImListOutput)(result.out, options);
|
||||
return {
|
||||
...result,
|
||||
data
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
exports.images = images;
|
||||
var push = function (options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
const push = function (options = {}) {
|
||||
return (0, exports.execCompose)('push', options.ignorePushFailures ? ['--ignore-push-failures'] : [], options);
|
||||
};
|
||||
exports.push = push;
|
||||
var restartAll = function (options) {
|
||||
const restartAll = function (options) {
|
||||
return (0, exports.execCompose)('restart', [], options);
|
||||
};
|
||||
exports.restartAll = restartAll;
|
||||
var restartMany = function (services, options) {
|
||||
const restartMany = function (services, options) {
|
||||
return (0, exports.execCompose)('restart', services, options);
|
||||
};
|
||||
exports.restartMany = restartMany;
|
||||
var restartOne = function (service, options) {
|
||||
const 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];
|
||||
const logs = function (services, options = {}) {
|
||||
let args = Array.isArray(services) ? services : [services];
|
||||
if (options.follow) {
|
||||
args = __spreadArray(['--follow'], args, true);
|
||||
args = ['--follow', ...args];
|
||||
}
|
||||
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_6;
|
||||
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_6 = _b.sent();
|
||||
return [2 /*return*/, Promise.reject(error_6)];
|
||||
case 4: return [2 /*return*/];
|
||||
const port = async function (service, containerPort, options) {
|
||||
const args = [service, containerPort];
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('port', args, options);
|
||||
const [address, port] = result.out.split(':');
|
||||
return {
|
||||
...result,
|
||||
data: {
|
||||
address,
|
||||
port: Number(port)
|
||||
}
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
exports.port = port;
|
||||
var version = function (options) {
|
||||
return __awaiter(this, void 0, void 0, function () {
|
||||
var result, version_1, error_7;
|
||||
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_7 = _a.sent();
|
||||
return [2 /*return*/, Promise.reject(error_7)];
|
||||
case 3: return [2 /*return*/];
|
||||
const version = async function (options) {
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('version', ['--short'], options);
|
||||
const version = result.out.replace('\n', '').trim();
|
||||
return {
|
||||
...result,
|
||||
data: { version }
|
||||
};
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
exports.version = version;
|
||||
var stats = function (service, options) {
|
||||
return __awaiter(this, void 0, void 0, function () {
|
||||
var args, result, output, error_8;
|
||||
return __generator(this, function (_a) {
|
||||
switch (_a.label) {
|
||||
case 0:
|
||||
args = ['--no-stream', '--format', '"{{ json . }}"', service];
|
||||
_a.label = 1;
|
||||
case 1:
|
||||
_a.trys.push([1, 3, , 4]);
|
||||
return [4 /*yield*/, (0, exports.execCompose)('stats', args, options)
|
||||
const stats = async function (service, options) {
|
||||
const args = ['--no-stream', '--format', '"{{ json . }}"', service];
|
||||
try {
|
||||
const result = await (0, exports.execCompose)('stats', args, options);
|
||||
// Remove first and last quote from output, as well as newline.
|
||||
];
|
||||
case 2:
|
||||
result = _a.sent();
|
||||
output = result.out.replace('\n', '').trim().slice(1, -1);
|
||||
return [2 /*return*/, JSON.parse(output)];
|
||||
case 3:
|
||||
error_8 = _a.sent();
|
||||
return [2 /*return*/, Promise.reject(error_8)];
|
||||
case 4: return [2 /*return*/];
|
||||
const output = result.out.replace('\n', '').trim().slice(1, -1);
|
||||
return JSON.parse(output);
|
||||
}
|
||||
catch (error) {
|
||||
return Promise.reject(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
exports.stats = stats;
|
||||
exports["default"] = {
|
||||
@ -3844,27 +3708,27 @@ exports["default"] = {
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||
var mapPorts = function (ports) {
|
||||
const mapPorts = (ports) => {
|
||||
if (!ports) {
|
||||
return [];
|
||||
}
|
||||
return ports.split(',').map(function (untypedPort) {
|
||||
var exposedFragments = untypedPort.trim().split('->');
|
||||
var _a = exposedFragments.length === 1
|
||||
return ports.split(',').map((untypedPort) => {
|
||||
const exposedFragments = untypedPort.trim().split('->');
|
||||
const [port, protocol] = exposedFragments.length === 1
|
||||
? exposedFragments[0].split('/')
|
||||
: exposedFragments[1].split('/'), port = _a[0], protocol = _a[1];
|
||||
var mapped = exposedFragments[0];
|
||||
var lastDoubleColon = mapped.lastIndexOf(':');
|
||||
: exposedFragments[1].split('/');
|
||||
const mapped = exposedFragments[0];
|
||||
const lastDoubleColon = mapped.lastIndexOf(':');
|
||||
if (lastDoubleColon === -1) {
|
||||
return {
|
||||
exposed: { port: Number(port), protocol: protocol }
|
||||
exposed: { port: Number(port), protocol }
|
||||
};
|
||||
}
|
||||
var address = mapped.substr(0, lastDoubleColon);
|
||||
var mappedPort = mapped.substr(lastDoubleColon + 1);
|
||||
const address = mapped.substr(0, lastDoubleColon);
|
||||
const mappedPort = mapped.substr(lastDoubleColon + 1);
|
||||
return {
|
||||
exposed: { port: Number(port), protocol: protocol },
|
||||
mapped: { port: Number(mappedPort), address: address }
|
||||
exposed: { port: Number(port), protocol },
|
||||
mapped: { port: Number(mappedPort), address }
|
||||
};
|
||||
});
|
||||
};
|
||||
@ -9481,7 +9345,7 @@ module.exports = {
|
||||
|
||||
|
||||
const { parseSetCookie } = __nccwpck_require__(8915)
|
||||
const { stringify, getHeadersList } = __nccwpck_require__(3834)
|
||||
const { stringify } = __nccwpck_require__(3834)
|
||||
const { webidl } = __nccwpck_require__(4222)
|
||||
const { Headers } = __nccwpck_require__(6349)
|
||||
|
||||
@ -9557,14 +9421,13 @@ function getSetCookies (headers) {
|
||||
|
||||
webidl.brandCheck(headers, Headers, { strict: false })
|
||||
|
||||
const cookies = getHeadersList(headers).cookies
|
||||
const cookies = headers.getSetCookie()
|
||||
|
||||
if (!cookies) {
|
||||
return []
|
||||
}
|
||||
|
||||
// In older versions of undici, cookies is a list of name:value.
|
||||
return cookies.map((pair) => parseSetCookie(Array.isArray(pair) ? pair[1] : pair))
|
||||
return cookies.map((pair) => parseSetCookie(pair))
|
||||
}
|
||||
|
||||
/**
|
||||
@ -9992,14 +9855,15 @@ module.exports = {
|
||||
/***/ }),
|
||||
|
||||
/***/ 3834:
|
||||
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
|
||||
/***/ ((module) => {
|
||||
|
||||
"use strict";
|
||||
|
||||
|
||||
const assert = __nccwpck_require__(2613)
|
||||
const { kHeadersList } = __nccwpck_require__(6443)
|
||||
|
||||
/**
|
||||
* @param {string} value
|
||||
* @returns {boolean}
|
||||
*/
|
||||
function isCTLExcludingHtab (value) {
|
||||
if (value.length === 0) {
|
||||
return false
|
||||
@ -10260,31 +10124,13 @@ function stringify (cookie) {
|
||||
return out.join('; ')
|
||||
}
|
||||
|
||||
let kHeadersListNode
|
||||
|
||||
function getHeadersList (headers) {
|
||||
if (headers[kHeadersList]) {
|
||||
return headers[kHeadersList]
|
||||
}
|
||||
|
||||
if (!kHeadersListNode) {
|
||||
kHeadersListNode = Object.getOwnPropertySymbols(headers).find(
|
||||
(symbol) => symbol.description === 'headers list'
|
||||
)
|
||||
|
||||
assert(kHeadersListNode, 'Headers cannot be parsed')
|
||||
}
|
||||
|
||||
const headersList = headers[kHeadersListNode]
|
||||
assert(headersList)
|
||||
|
||||
return headersList
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
isCTLExcludingHtab,
|
||||
stringify,
|
||||
getHeadersList
|
||||
validateCookieName,
|
||||
validateCookiePath,
|
||||
validateCookieValue,
|
||||
toIMFDate,
|
||||
stringify
|
||||
}
|
||||
|
||||
|
||||
@ -12213,6 +12059,14 @@ const { isUint8Array, isArrayBuffer } = __nccwpck_require__(8253)
|
||||
const { File: UndiciFile } = __nccwpck_require__(3041)
|
||||
const { parseMIMEType, serializeAMimeType } = __nccwpck_require__(4322)
|
||||
|
||||
let random
|
||||
try {
|
||||
const crypto = __nccwpck_require__(7598)
|
||||
random = (max) => crypto.randomInt(0, max)
|
||||
} catch {
|
||||
random = (max) => Math.floor(Math.random(max))
|
||||
}
|
||||
|
||||
let ReadableStream = globalThis.ReadableStream
|
||||
|
||||
/** @type {globalThis['File']} */
|
||||
@ -12298,7 +12152,7 @@ function extractBody (object, keepalive = false) {
|
||||
// Set source to a copy of the bytes held by object.
|
||||
source = new Uint8Array(object.buffer.slice(object.byteOffset, object.byteOffset + object.byteLength))
|
||||
} else if (util.isFormDataLike(object)) {
|
||||
const boundary = `----formdata-undici-0${`${Math.floor(Math.random() * 1e11)}`.padStart(11, '0')}`
|
||||
const boundary = `----formdata-undici-0${`${random(1e11)}`.padStart(11, '0')}`
|
||||
const prefix = `--${boundary}\r\nContent-Disposition: form-data`
|
||||
|
||||
/*! formdata-polyfill. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource> */
|
||||
@ -14280,6 +14134,7 @@ const {
|
||||
isValidHeaderName,
|
||||
isValidHeaderValue
|
||||
} = __nccwpck_require__(5523)
|
||||
const util = __nccwpck_require__(9023)
|
||||
const { webidl } = __nccwpck_require__(4222)
|
||||
const assert = __nccwpck_require__(2613)
|
||||
|
||||
@ -14833,6 +14688,9 @@ Object.defineProperties(Headers.prototype, {
|
||||
[Symbol.toStringTag]: {
|
||||
value: 'Headers',
|
||||
configurable: true
|
||||
},
|
||||
[util.inspect.custom]: {
|
||||
enumerable: false
|
||||
}
|
||||
})
|
||||
|
||||
@ -24009,6 +23867,20 @@ class Pool extends PoolBase {
|
||||
? { ...options.interceptors }
|
||||
: undefined
|
||||
this[kFactory] = factory
|
||||
|
||||
this.on('connectionError', (origin, targets, error) => {
|
||||
// If a connection error occurs, we remove the client from the pool,
|
||||
// and emit a connectionError event. They will not be re-used.
|
||||
// Fixes https://github.com/nodejs/undici/issues/3895
|
||||
for (const target of targets) {
|
||||
// Do not use kRemoveClient here, as it will close the client,
|
||||
// but the client cannot be closed in this state.
|
||||
const idx = this[kClients].indexOf(target)
|
||||
if (idx !== -1) {
|
||||
this[kClients].splice(idx, 1)
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
[kGetDispatcher] () {
|
||||
@ -26319,7 +26191,7 @@ module.exports = {
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||
exports.run = void 0;
|
||||
exports.run = run;
|
||||
const core_1 = __nccwpck_require__(7484);
|
||||
const input_service_1 = __nccwpck_require__(2301);
|
||||
const logger_service_1 = __nccwpck_require__(8187);
|
||||
@ -26360,7 +26232,6 @@ async function run() {
|
||||
(0, core_1.setFailed)(`${error instanceof Error ? error : JSON.stringify(error)}`);
|
||||
}
|
||||
}
|
||||
exports.run = run;
|
||||
|
||||
|
||||
/***/ }),
|
||||
@ -26645,6 +26516,14 @@ module.exports = require("net");
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ 7598:
|
||||
/***/ ((module) => {
|
||||
|
||||
"use strict";
|
||||
module.exports = require("node:crypto");
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ 8474:
|
||||
/***/ ((module) => {
|
||||
|
||||
|
||||
1638
package-lock.json
generated
1638
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
14
package.json
14
package.json
@ -72,17 +72,17 @@
|
||||
]
|
||||
},
|
||||
"dependencies": {
|
||||
"@actions/core": "^1.10.1",
|
||||
"@actions/core": "^1.11.1",
|
||||
"@actions/github": "^6.0.0",
|
||||
"@actions/tool-cache": "^2.0.1",
|
||||
"@octokit/action": "^7.0.0",
|
||||
"docker-compose": "^1.1.0"
|
||||
"@actions/tool-cache": "^2.0.2",
|
||||
"@octokit/action": "^7.0.1",
|
||||
"docker-compose": "^1.2.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@ts-dev-tools/core": "^1.6.2",
|
||||
"@vercel/ncc": "^0.38.1",
|
||||
"eslint-plugin-github": "^5.0.1",
|
||||
"eslint-plugin-jsonc": "^2.14.1"
|
||||
"@vercel/ncc": "^0.38.3",
|
||||
"eslint-plugin-github": "^6.0.0",
|
||||
"eslint-plugin-jsonc": "^2.20.0"
|
||||
},
|
||||
"eslintConfig": {
|
||||
"root": true,
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user