Files
bake-action/src/main.ts

85 lines
2.4 KiB
TypeScript
Raw Normal View History

import * as fs from 'fs';
2020-10-08 00:52:52 +02:00
import * as buildx from './buildx';
import * as context from './context';
import * as docker from './docker';
import * as stateHelper from './state-helper';
2020-10-08 00:52:52 +02:00
import * as core from '@actions/core';
import * as exec from '@actions/exec';
async function run(): Promise<void> {
try {
const inputs: context.Inputs = await context.getInputs();
// standalone if docker cli not available
const standalone = !(await docker.isAvailable());
2021-04-27 15:47:00 +02:00
core.startGroup(`Docker info`);
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 15:47:00 +02:00
core.endGroup();
2020-10-08 00:52:52 +02:00
if (!(await buildx.isAvailable(standalone))) {
2021-04-27 15:47:00 +02:00
core.setFailed(`Docker buildx is required. See https://github.com/docker/setup-buildx-action to set up buildx.`);
2020-10-08 00:52:52 +02:00
return;
}
stateHelper.setTmpDir(context.tmpDir());
2020-10-08 00:52:52 +02: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
});
});
const args: string[] = await context.getArgs(inputs, buildxVersion);
const buildCmd = buildx.getCommand(args, standalone);
2020-12-24 18:03:30 +01:00
2021-04-27 15:47:00 +02:00
core.startGroup(`Bake definition`);
await exec.exec(buildCmd.command, [...buildCmd.args, '--print']);
2020-12-23 20:15:23 +01:00
core.endGroup();
2020-12-24 18:03:30 +01:00
2021-06-08 20:40:23 +02:00
await exec
.getExecOutput(buildCmd.command, buildCmd.args, {
2021-06-08 20:40:23 +02:00
ignoreReturnCode: true
})
.then(res => {
if (res.stderr.length > 0 && res.exitCode != 0) {
throw new Error(`buildx bake failed with: ${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`);
2021-06-08 20:40:23 +02:00
}
});
const metadata = await buildx.getMetadata();
if (metadata) {
await core.group(`Metadata output`, async () => {
core.info(metadata);
context.setOutput('metadata', metadata);
});
}
2020-10-08 00:52:52 +02:00
} catch (error) {
core.setFailed(error.message);
}
}
async function cleanup(): Promise<void> {
if (stateHelper.tmpDir.length > 0) {
core.startGroup(`Removing temp folder ${stateHelper.tmpDir}`);
fs.rmdirSync(stateHelper.tmpDir, {recursive: true});
core.endGroup();
}
}
if (!stateHelper.IsPost) {
run();
} else {
cleanup();
}