2022-11-07 20:41:00 +00:00
|
|
|
import { BuildParameters, Input } from '../..';
|
|
|
|
import YAML from 'yaml';
|
|
|
|
import CloudRunnerSecret from './cloud-runner-secret';
|
|
|
|
import { RemoteClientLogger } from '../remote-client/remote-client-logger';
|
|
|
|
import path from 'path';
|
|
|
|
import CloudRunnerOptions from '../cloud-runner-options';
|
|
|
|
import * as fs from 'fs';
|
Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
2023-01-20 17:40:57 +00:00
|
|
|
|
|
|
|
// import CloudRunnerLogger from './cloud-runner-logger';
|
2022-11-07 20:41:00 +00:00
|
|
|
|
|
|
|
export class CloudRunnerCustomHooks {
|
|
|
|
// TODO also accept hooks as yaml files in the repo
|
|
|
|
public static ApplyHooksToCommands(commands: string, buildParameters: BuildParameters): string {
|
2023-02-12 03:49:33 +00:00
|
|
|
const hooks = CloudRunnerCustomHooks.getHooks(buildParameters.customJobHooks);
|
2022-11-07 20:41:00 +00:00
|
|
|
|
|
|
|
return `echo "---"
|
|
|
|
echo "start cloud runner init"
|
|
|
|
${CloudRunnerOptions.cloudRunnerDebugEnv ? `printenv` : `#`}
|
|
|
|
echo "start of cloud runner job"
|
|
|
|
${hooks.filter((x) => x.hook.includes(`before`)).map((x) => x.commands) || ' '}
|
|
|
|
${commands}
|
|
|
|
${hooks.filter((x) => x.hook.includes(`after`)).map((x) => x.commands) || ' '}
|
|
|
|
echo "end of cloud runner job"
|
|
|
|
echo "---${buildParameters.logId}"`;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static getHooks(customJobHooks): Hook[] {
|
|
|
|
const experimentHooks = customJobHooks;
|
|
|
|
let output = new Array<Hook>();
|
|
|
|
if (experimentHooks && experimentHooks !== '') {
|
|
|
|
try {
|
|
|
|
output = YAML.parse(experimentHooks);
|
|
|
|
} catch (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-02-12 13:00:21 +00:00
|
|
|
return [
|
|
|
|
...output.filter((x) => x.hook !== undefined && x.hook.length > 0),
|
|
|
|
...CloudRunnerCustomHooks.GetCustomHooksFromFiles(`before`),
|
|
|
|
...CloudRunnerCustomHooks.GetCustomHooksFromFiles(`after`),
|
|
|
|
];
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static GetCustomHooksFromFiles(hookLifecycle: string): Hook[] {
|
|
|
|
const results: Hook[] = [];
|
2023-02-12 13:04:59 +00:00
|
|
|
RemoteClientLogger.log(`GetCustomHookFiles: ${hookLifecycle}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
try {
|
|
|
|
const gameCiCustomStepsPath = path.join(process.cwd(), `game-ci`, `hooks`);
|
|
|
|
const files = fs.readdirSync(gameCiCustomStepsPath);
|
|
|
|
for (const file of files) {
|
|
|
|
if (!CloudRunnerOptions.customHookFiles.includes(file.replace(`.yaml`, ``))) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
const fileContents = fs.readFileSync(path.join(gameCiCustomStepsPath, file), `utf8`);
|
|
|
|
const fileContentsObject = CloudRunnerCustomHooks.ParseHooks(fileContents)[0];
|
|
|
|
if (fileContentsObject.hook.includes(hookLifecycle)) {
|
|
|
|
results.push(fileContentsObject);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
RemoteClientLogger.log(`Failed Getting: ${hookLifecycle} \n ${JSON.stringify(error, undefined, 4)}`);
|
|
|
|
}
|
2023-02-12 13:15:25 +00:00
|
|
|
RemoteClientLogger.log(`Active Steps From Hooks: \n ${JSON.stringify(results, undefined, 4)}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
|
|
|
|
return results;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static ConvertYamlSecrets(object) {
|
|
|
|
if (object.secrets === undefined) {
|
|
|
|
object.secrets = [];
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
object.secrets = object.secrets.map((x) => {
|
|
|
|
return {
|
|
|
|
ParameterKey: x.name,
|
|
|
|
EnvironmentVariable: Input.ToEnvVarFormat(x.name),
|
|
|
|
ParameterValue: x.value,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-02-12 05:40:05 +00:00
|
|
|
public static ParseHooks(hooks: string): Hook[] {
|
|
|
|
if (hooks === '') {
|
2022-11-07 20:41:00 +00:00
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
// if (CloudRunner.buildParameters?.cloudRunnerIntegrationTests) {
|
|
|
|
|
Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
2023-01-20 17:40:57 +00:00
|
|
|
// CloudRunnerLogger.log(`Parsing build hooks: ${steps}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
|
|
|
|
// }
|
2023-02-12 05:40:05 +00:00
|
|
|
const isArray = hooks.replace(/\s/g, ``)[0] === `-`;
|
|
|
|
const object: Hook[] = isArray ? YAML.parse(hooks) : [YAML.parse(hooks)];
|
2022-11-07 20:41:00 +00:00
|
|
|
for (const hook of object) {
|
|
|
|
CloudRunnerCustomHooks.ConvertYamlSecrets(hook);
|
|
|
|
if (hook.secrets === undefined) {
|
|
|
|
hook.secrets = [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (object === undefined) {
|
2023-02-12 05:40:05 +00:00
|
|
|
throw new Error(`Failed to parse ${hooks}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return object;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static getSecrets(hooks) {
|
|
|
|
const secrets = hooks.map((x) => x.secrets).filter((x) => x !== undefined && x.length > 0);
|
|
|
|
|
|
|
|
// eslint-disable-next-line unicorn/no-array-reduce
|
|
|
|
return secrets.length > 0 ? secrets.reduce((x, y) => [...x, ...y]) : [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
export class Hook {
|
|
|
|
public commands;
|
|
|
|
public secrets: CloudRunnerSecret[] = new Array<CloudRunnerSecret>();
|
|
|
|
public name;
|
|
|
|
public hook!: string[];
|
|
|
|
public step!: string[];
|
|
|
|
}
|