2020-09-02 04:07:11 -04:00
|
|
|
import * as fs from 'fs';
|
2020-08-15 18:36:41 -04:00
|
|
|
import * as buildx from './buildx';
|
2020-09-02 04:07:11 -04:00
|
|
|
import * as context from './context';
|
2022-04-28 03:31:47 -04:00
|
|
|
import * as docker from './docker';
|
2023-01-12 13:44:15 -05:00
|
|
|
import * as github from './github';
|
2020-09-02 04:07:11 -04:00
|
|
|
import * as stateHelper from './state-helper';
|
2020-08-15 18:36:41 -04:00
|
|
|
import * as core from '@actions/core';
|
2021-06-22 13:52:21 -04:00
|
|
|
import * as exec from '@actions/exec';
|
2020-08-15 18:36:41 -04:00
|
|
|
|
|
|
|
async function run(): Promise<void> {
|
|
|
|
try {
|
2022-04-28 03:31:47 -04:00
|
|
|
const defContext = context.defaultContext();
|
|
|
|
const inputs: context.Inputs = await context.getInputs(defContext);
|
|
|
|
|
|
|
|
// standalone if docker cli not available
|
|
|
|
const standalone = !(await docker.isAvailable());
|
|
|
|
|
2023-01-12 13:44:15 -05:00
|
|
|
await core.group(`GitHub Actions runtime token access controls`, async () => {
|
|
|
|
const actionsRuntimeToken = process.env['ACTIONS_RUNTIME_TOKEN'];
|
|
|
|
if (actionsRuntimeToken) {
|
|
|
|
core.info(JSON.stringify(JSON.parse(github.parseRuntimeToken(actionsRuntimeToken).ac as string), undefined, 2));
|
|
|
|
} else {
|
|
|
|
core.info(`ACTIONS_RUNTIME_TOKEN not set`);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-04-27 10:16:22 -04:00
|
|
|
core.startGroup(`Docker info`);
|
2022-04-28 03:31:47 -04:00
|
|
|
if (standalone) {
|
|
|
|
core.info(`Docker info skipped in standalone mode`);
|
|
|
|
} else {
|
|
|
|
await exec.exec('docker', ['version'], {
|
|
|
|
failOnStdErr: false
|
|
|
|
});
|
|
|
|
await exec.exec('docker', ['info'], {
|
|
|
|
failOnStdErr: false
|
|
|
|
});
|
|
|
|
}
|
2021-04-27 10:16:22 -04:00
|
|
|
core.endGroup();
|
2020-08-15 18:36:41 -04:00
|
|
|
|
2022-04-28 03:31:47 -04:00
|
|
|
if (!(await buildx.isAvailable(standalone))) {
|
2021-04-27 10:16:22 -04:00
|
|
|
core.setFailed(`Docker buildx is required. See https://github.com/docker/setup-buildx-action to set up buildx.`);
|
|
|
|
return;
|
2020-08-15 18:36:41 -04:00
|
|
|
}
|
2020-10-19 15:17:06 -04:00
|
|
|
stateHelper.setTmpDir(context.tmpDir());
|
2020-08-15 18:36:41 -04:00
|
|
|
|
2022-04-28 03:31:47 -04:00
|
|
|
const buildxVersion = await buildx.getVersion(standalone);
|
|
|
|
await core.group(`Buildx version`, async () => {
|
|
|
|
const versionCmd = buildx.getCommand(['version'], standalone);
|
|
|
|
await exec.exec(versionCmd.command, versionCmd.args, {
|
|
|
|
failOnStdErr: false
|
|
|
|
});
|
|
|
|
});
|
2020-08-16 16:31:37 -04:00
|
|
|
|
2023-01-11 06:10:34 -05:00
|
|
|
const args: string[] = await context.getArgs(inputs, defContext, buildxVersion, standalone);
|
2022-04-28 03:31:47 -04:00
|
|
|
const buildCmd = buildx.getCommand(args, standalone);
|
2021-06-22 13:52:21 -04:00
|
|
|
await exec
|
2022-04-28 03:31:47 -04:00
|
|
|
.getExecOutput(buildCmd.command, buildCmd.args, {
|
2021-06-22 13:52:21 -04:00
|
|
|
ignoreReturnCode: true
|
|
|
|
})
|
|
|
|
.then(res => {
|
|
|
|
if (res.stderr.length > 0 && res.exitCode != 0) {
|
2022-03-15 16:59:52 -04:00
|
|
|
throw new Error(`buildx failed with: ${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`);
|
2021-06-22 13:52:21 -04:00
|
|
|
}
|
|
|
|
});
|
2020-08-17 16:18:15 -04:00
|
|
|
|
2022-02-09 05:32:35 -05:00
|
|
|
const imageID = await buildx.getImageID();
|
2022-03-14 14:30:50 -04:00
|
|
|
const metadata = await buildx.getMetadata();
|
|
|
|
const digest = await buildx.getDigest(metadata);
|
|
|
|
|
2022-02-09 05:32:35 -05:00
|
|
|
if (imageID) {
|
2022-03-14 14:30:50 -04:00
|
|
|
await core.group(`ImageID`, async () => {
|
2022-02-09 05:32:35 -05:00
|
|
|
core.info(imageID);
|
2022-10-12 00:56:31 -04:00
|
|
|
core.setOutput('imageid', imageID);
|
2022-03-14 14:30:50 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
if (digest) {
|
|
|
|
await core.group(`Digest`, async () => {
|
|
|
|
core.info(digest);
|
2022-10-12 00:56:31 -04:00
|
|
|
core.setOutput('digest', digest);
|
2022-02-09 05:32:35 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
if (metadata) {
|
2022-03-14 14:30:50 -04:00
|
|
|
await core.group(`Metadata`, async () => {
|
2022-02-09 05:32:35 -05:00
|
|
|
core.info(metadata);
|
2022-10-12 00:56:31 -04:00
|
|
|
core.setOutput('metadata', metadata);
|
2022-02-09 05:32:35 -05:00
|
|
|
});
|
|
|
|
}
|
2020-08-15 18:36:41 -04:00
|
|
|
} catch (error) {
|
|
|
|
core.setFailed(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-02 04:07:11 -04:00
|
|
|
async function cleanup(): Promise<void> {
|
|
|
|
if (stateHelper.tmpDir.length > 0) {
|
2021-04-27 10:16:22 -04:00
|
|
|
core.startGroup(`Removing temp folder ${stateHelper.tmpDir}`);
|
2022-07-27 19:36:32 -04:00
|
|
|
fs.rmSync(stateHelper.tmpDir, {recursive: true});
|
2021-04-27 10:16:22 -04:00
|
|
|
core.endGroup();
|
2020-09-02 04:07:11 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!stateHelper.IsPost) {
|
|
|
|
run();
|
|
|
|
} else {
|
|
|
|
cleanup();
|
|
|
|
}
|