2020-08-15 20:45:36 +08:00
|
|
|
import * as os from 'os';
|
|
|
|
import * as core from '@actions/core';
|
2020-08-20 22:14:02 +08:00
|
|
|
import * as exec from '@actions/exec';
|
2020-08-20 21:59:36 +08:00
|
|
|
import * as ecr from './ecr';
|
2020-08-20 22:14:02 +08:00
|
|
|
import * as execm from './exec';
|
|
|
|
|
2020-08-15 20:45:36 +08:00
|
|
|
import * as stateHelper from './state-helper';
|
|
|
|
|
|
|
|
async function run(): Promise<void> {
|
|
|
|
try {
|
|
|
|
if (os.platform() !== 'linux') {
|
|
|
|
core.setFailed('Only supported on linux platform');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const registry: string = core.getInput('registry');
|
|
|
|
stateHelper.setRegistry(registry);
|
|
|
|
stateHelper.setLogout(core.getInput('logout'));
|
|
|
|
|
|
|
|
const username: string = core.getInput('username');
|
|
|
|
const password: string = core.getInput('password', {required: true});
|
|
|
|
|
2020-08-20 21:59:36 +08:00
|
|
|
if (await ecr.isECR(registry)) {
|
2020-08-20 22:14:02 +08:00
|
|
|
await exec.exec('aws', ['--version']);
|
2020-08-20 21:59:36 +08:00
|
|
|
const ecrRegion = await ecr.getRegion(registry);
|
|
|
|
process.env.AWS_ACCESS_KEY_ID = username;
|
|
|
|
process.env.AWS_SECRET_ACCESS_KEY = password;
|
2020-08-20 22:03:38 +08:00
|
|
|
|
2020-08-20 22:24:35 +08:00
|
|
|
core.info(`⬇️ Retrieving docker login command for ECR region ${ecrRegion}...`);
|
2020-08-20 22:14:02 +08:00
|
|
|
await execm.exec('aws', ['ecr', 'get-login', '--region', ecrRegion, '--no-include-email'], true).then(res => {
|
2020-08-20 21:59:36 +08:00
|
|
|
if (res.stderr != '' && !res.success) {
|
|
|
|
throw new Error(res.stderr);
|
|
|
|
}
|
2020-08-20 22:24:35 +08:00
|
|
|
core.info(`🔑 Logging into ${registry}...`);
|
|
|
|
execm.exec(res.stdout, [], true).then(res => {
|
|
|
|
if (res.stderr != '' && !res.success) {
|
|
|
|
throw new Error(res.stderr);
|
|
|
|
}
|
|
|
|
core.info('🎉 Login Succeeded!');
|
|
|
|
});
|
2020-08-20 21:59:36 +08:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
let loginArgs: Array<string> = ['login', '--password', password];
|
|
|
|
if (username) {
|
|
|
|
loginArgs.push('--username', username);
|
2020-08-15 20:45:36 +08:00
|
|
|
}
|
2020-08-20 21:59:36 +08:00
|
|
|
loginArgs.push(registry);
|
|
|
|
|
2020-08-20 22:10:17 +08:00
|
|
|
if (registry) {
|
|
|
|
core.info(`🔑 Logging into ${registry}...`);
|
|
|
|
} else {
|
|
|
|
core.info(`🔑 Logging into DockerHub...`);
|
|
|
|
}
|
2020-08-20 22:14:02 +08:00
|
|
|
await execm.exec('docker', loginArgs, true).then(res => {
|
2020-08-20 21:59:36 +08:00
|
|
|
if (res.stderr != '' && !res.success) {
|
|
|
|
throw new Error(res.stderr);
|
|
|
|
}
|
|
|
|
core.info('🎉 Login Succeeded!');
|
|
|
|
});
|
|
|
|
}
|
2020-08-15 20:45:36 +08:00
|
|
|
} catch (error) {
|
|
|
|
core.setFailed(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function logout(): Promise<void> {
|
|
|
|
if (!stateHelper.logout) {
|
|
|
|
return;
|
|
|
|
}
|
2020-08-20 22:14:02 +08:00
|
|
|
await execm.exec('docker', ['logout', stateHelper.registry], false).then(res => {
|
2020-08-15 20:45:36 +08:00
|
|
|
if (res.stderr != '' && !res.success) {
|
|
|
|
core.warning(res.stderr);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!stateHelper.IsPost) {
|
|
|
|
run();
|
|
|
|
} else {
|
|
|
|
logout();
|
|
|
|
}
|