gitlab-ci-local 4.48.2 → 4.50.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/package.json +7 -4
- package/src/argv.js +21 -15
- package/src/git-data.js +56 -21
- package/src/gitlab-preset.js +27 -0
- package/src/index.js +13 -9
- package/src/job.js +83 -25
- package/src/parallel.js +10 -3
- package/src/parser-includes.js +37 -4
- package/src/parser.js +7 -4
- package/src/schema/schema.json +1 -1
- package/src/utils.js +68 -13
- package/src/validator.js +5 -5
package/src/parallel.js
CHANGED
|
@@ -3,12 +3,19 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.matrixVariablesList = void 0;
|
|
6
|
+
exports.matrixVariablesList = exports.isPlainParallel = void 0;
|
|
7
7
|
const assert_1 = __importDefault(require("assert"));
|
|
8
8
|
const deep_extend_1 = __importDefault(require("deep-extend"));
|
|
9
|
+
function isPlainParallel(jobData) {
|
|
10
|
+
return Number.isInteger(jobData.parallel);
|
|
11
|
+
}
|
|
12
|
+
exports.isPlainParallel = isPlainParallel;
|
|
9
13
|
function matrixVariablesList(jobData, jobName) {
|
|
14
|
+
if (isPlainParallel(jobData)) {
|
|
15
|
+
return Array(jobData.parallel).fill(null);
|
|
16
|
+
}
|
|
10
17
|
if (jobData?.parallel?.matrix == null) {
|
|
11
|
-
return null;
|
|
18
|
+
return [null];
|
|
12
19
|
}
|
|
13
20
|
(0, assert_1.default)(Array.isArray(jobData.parallel.matrix), `${jobName} parallel.matrix is not an array`);
|
|
14
21
|
const matrixVariables = [];
|
|
@@ -44,4 +51,4 @@ function matrixVariablesList(jobData, jobName) {
|
|
|
44
51
|
return matrixVariables;
|
|
45
52
|
}
|
|
46
53
|
exports.matrixVariablesList = matrixVariablesList;
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYWxsZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJwYXJhbGxlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxvREFBNEI7QUFDNUIsOERBQXFDO0FBRXJDLFNBQWdCLGVBQWUsQ0FBRSxPQUFZO0lBQ3pDLE9BQU8sTUFBTSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDOUMsQ0FBQztBQUZELDBDQUVDO0FBRUQsU0FBZ0IsbUJBQW1CLENBQUUsT0FBWSxFQUFFLE9BQWU7SUFDOUQsSUFBSSxlQUFlLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUMzQixPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3BDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBQ0QsSUFBQSxnQkFBTSxFQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxHQUFHLE9BQU8sa0NBQWtDLENBQUMsQ0FBQztJQUU3RixNQUFNLGVBQWUsR0FBOEIsRUFBRSxDQUFDO0lBRXRELHlDQUF5QztJQUN6QyxLQUFLLE1BQU0sQ0FBQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDdEMsS0FBSyxNQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUMzQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BELENBQUM7SUFDTCxDQUFDO0lBRUQsMkRBQTJEO0lBQzNELE1BQU0sSUFBSSxHQUFHLElBQUEscUJBQVUsRUFBQyxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDckMsS0FBSyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ25DLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUVWLElBQUksS0FBSyxHQUFHLEVBQUUsQ0FBQztRQUNmLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQztZQUMxQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzVCLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQixNQUFNLE1BQU0sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDdEIsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7WUFFZCxNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ3hELEtBQUssR0FBRyxFQUFFLENBQUM7WUFFWCxLQUFLLE1BQU0sS0FBSyxJQUFJLFVBQVUsRUFBRSxDQUFDO2dCQUM3QixLQUFLLE1BQU0sQ0FBQyxJQUFJLE1BQU0sRUFBRSxDQUFDO29CQUNyQixNQUFNLGNBQWMsR0FBNEIsRUFBQyxHQUFHLEtBQUssRUFBQyxDQUFDO29CQUMzRCxjQUFjLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO29CQUN4QixLQUFLLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO2dCQUMvQixDQUFDO1lBQ0wsQ0FBQztZQUNELENBQUMsRUFBRSxDQUFDO1FBQ1IsQ0FBQztRQUNELGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsT0FBTyxlQUFlLENBQUM7QUFDM0IsQ0FBQztBQTlDRCxrREE4Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gXCJhc3NlcnRcIjtcbmltcG9ydCBkZWVwRXh0ZW5kIGZyb20gXCJkZWVwLWV4dGVuZFwiO1xuXG5leHBvcnQgZnVuY3Rpb24gaXNQbGFpblBhcmFsbGVsIChqb2JEYXRhOiBhbnkpIHtcbiAgICByZXR1cm4gTnVtYmVyLmlzSW50ZWdlcihqb2JEYXRhLnBhcmFsbGVsKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hdHJpeFZhcmlhYmxlc0xpc3QgKGpvYkRhdGE6IGFueSwgam9iTmFtZTogc3RyaW5nKToge1trZXk6IHN0cmluZ106IHN0cmluZ31bXSB8IG51bGxbXSB7XG4gICAgaWYgKGlzUGxhaW5QYXJhbGxlbChqb2JEYXRhKSkge1xuICAgICAgICByZXR1cm4gQXJyYXkoam9iRGF0YS5wYXJhbGxlbCkuZmlsbChudWxsKTtcbiAgICB9XG4gICAgaWYgKGpvYkRhdGE/LnBhcmFsbGVsPy5tYXRyaXggPT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gW251bGxdO1xuICAgIH1cbiAgICBhc3NlcnQoQXJyYXkuaXNBcnJheShqb2JEYXRhLnBhcmFsbGVsLm1hdHJpeCksIGAke2pvYk5hbWV9IHBhcmFsbGVsLm1hdHJpeCBpcyBub3QgYW4gYXJyYXlgKTtcblxuICAgIGNvbnN0IG1hdHJpeFZhcmlhYmxlczoge1trZXk6IHN0cmluZ106IHN0cmluZ31bXSA9IFtdO1xuXG4gICAgLy8gRXhwYW5kIHN0cmluZyB2YWx1ZSB0byBhcnJheSBvZiB2YWx1ZXNcbiAgICBmb3IgKGNvbnN0IG0gb2Ygam9iRGF0YS5wYXJhbGxlbC5tYXRyaXgpIHtcbiAgICAgICAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMobSkpIHtcbiAgICAgICAgICAgIG1ba2V5XSA9IEFycmF5LmlzQXJyYXkodmFsdWUpID8gdmFsdWUgOiBbdmFsdWVdO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLy8gR2VuZXJhdGUgdmFyaWFibGVzIGluIHdoaWxlIGxvb3AgYnkgZXhwYW5kaW5nIHRoZSBtYXRyaXhcbiAgICBjb25zdCBkZWVwID0gZGVlcEV4dGVuZCh7fSwgam9iRGF0YSk7XG4gICAgZm9yIChjb25zdCBtIG9mIGRlZXAucGFyYWxsZWwubWF0cml4KSB7XG4gICAgICAgIGxldCBpID0gMDtcblxuICAgICAgICBsZXQgaW5uZXIgPSBbXTtcbiAgICAgICAgd2hpbGUgKE9iamVjdC5rZXlzKG0pLmxlbmd0aCA+IDAgJiYgaSA8IDEwMCkge1xuICAgICAgICAgICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKG0pO1xuICAgICAgICAgICAgY29uc3Qga2V5ID0ga2V5c1swXTtcbiAgICAgICAgICAgIGNvbnN0IHZhbHVlcyA9IG1ba2V5XTtcbiAgICAgICAgICAgIGRlbGV0ZSBtW2tleV07XG5cbiAgICAgICAgICAgIGNvbnN0IGlubmVyQ2xvbmUgPSBpbm5lci5sZW5ndGggPiAwID8gWy4uLmlubmVyXSA6IFt7fV07XG4gICAgICAgICAgICBpbm5lciA9IFtdO1xuXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGNsb25lIG9mIGlubmVyQ2xvbmUpIHtcbiAgICAgICAgICAgICAgICBmb3IgKGNvbnN0IHYgb2YgdmFsdWVzKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IG1hdHJpeFZhcmlhYmxlOiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSA9IHsuLi5jbG9uZX07XG4gICAgICAgICAgICAgICAgICAgIG1hdHJpeFZhcmlhYmxlW2tleV0gPSB2O1xuICAgICAgICAgICAgICAgICAgICBpbm5lci5wdXNoKG1hdHJpeFZhcmlhYmxlKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpKys7XG4gICAgICAgIH1cbiAgICAgICAgbWF0cml4VmFyaWFibGVzLnB1c2goLi4uaW5uZXIpO1xuICAgIH1cblxuICAgIHJldHVybiBtYXRyaXhWYXJpYWJsZXM7XG59XG4iXX0=
|
package/src/parser-includes.js
CHANGED
|
@@ -53,7 +53,7 @@ class ParserIncludes {
|
|
|
53
53
|
for (const value of include) {
|
|
54
54
|
if (value["rules"]) {
|
|
55
55
|
const include_rules = value["rules"];
|
|
56
|
-
const rulesResult = utils_1.Utils.getRulesResult({ cwd, rules: include_rules, variables: opts.variables });
|
|
56
|
+
const rulesResult = utils_1.Utils.getRulesResult({ cwd, rules: include_rules, variables: opts.variables }, gitData);
|
|
57
57
|
if (rulesResult.when === "never") {
|
|
58
58
|
continue;
|
|
59
59
|
}
|
|
@@ -83,7 +83,7 @@ class ParserIncludes {
|
|
|
83
83
|
for (const value of include) {
|
|
84
84
|
if (value["rules"]) {
|
|
85
85
|
const include_rules = value["rules"];
|
|
86
|
-
const rulesResult = utils_1.Utils.getRulesResult({ cwd, rules: include_rules, variables: opts.variables });
|
|
86
|
+
const rulesResult = utils_1.Utils.getRulesResult({ cwd, rules: include_rules, variables: opts.variables }, gitData);
|
|
87
87
|
if (rulesResult.when === "never") {
|
|
88
88
|
continue;
|
|
89
89
|
}
|
|
@@ -112,6 +112,25 @@ class ParserIncludes {
|
|
|
112
112
|
includeDatas = includeDatas.concat(await this.init(fileDoc, opts));
|
|
113
113
|
}
|
|
114
114
|
}
|
|
115
|
+
else if (value["component"]) {
|
|
116
|
+
const { domain, projectPath, componentName, ref } = this.parseIncludeComponent(value["component"]);
|
|
117
|
+
// converts component to project
|
|
118
|
+
const files = [`${componentName}.yml`, `${componentName}/template.yml`, null];
|
|
119
|
+
for (const f of files) {
|
|
120
|
+
(0, assert_1.default)(f !== null, `This GitLab CI configuration is invalid: component: \`${value["component"]}\`. One of the file [${files}] must exists in \`${domain}/${projectPath}\``);
|
|
121
|
+
if (!(await utils_1.Utils.remoteFileExist(f, ref, domain, projectPath, gitData.remote.schema)))
|
|
122
|
+
continue;
|
|
123
|
+
const fileDoc = {
|
|
124
|
+
include: {
|
|
125
|
+
project: projectPath,
|
|
126
|
+
file: f,
|
|
127
|
+
ref: ref,
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
includeDatas = includeDatas.concat(await this.init(fileDoc, opts));
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
115
134
|
else if (value["template"]) {
|
|
116
135
|
const { project, ref, file, domain } = this.covertTemplateToProjectFile(value["template"]);
|
|
117
136
|
const fsUrl = utils_1.Utils.fsUrl(`https://${domain}/${project}/-/raw/${ref}/${file}`);
|
|
@@ -164,6 +183,20 @@ class ParserIncludes {
|
|
|
164
183
|
file: `lib/gitlab/ci/templates/${template}`,
|
|
165
184
|
};
|
|
166
185
|
}
|
|
186
|
+
static parseIncludeComponent(component) {
|
|
187
|
+
(0, assert_1.default)(!component.includes("://"), `This GitLab CI configuration is invalid: component: \`${component}\` should not contain protocol`);
|
|
188
|
+
// eslint-disable-next-line no-useless-escape
|
|
189
|
+
const pattern = /(?<domain>[^/\s]+)\/(?<projectPath>.+)\/(?<componentName>[^@]+)@(?<ref>.+)/; // regexr.com/7v7hm
|
|
190
|
+
const gitRemoteMatch = pattern.exec(component);
|
|
191
|
+
if (gitRemoteMatch?.groups == null)
|
|
192
|
+
throw new Error(`This is a bug, please create a github issue if this is something you're expecting to work. input: ${component}`);
|
|
193
|
+
return {
|
|
194
|
+
domain: gitRemoteMatch.groups["domain"],
|
|
195
|
+
projectPath: gitRemoteMatch.groups["projectPath"],
|
|
196
|
+
componentName: `templates/${gitRemoteMatch.groups["componentName"]}`,
|
|
197
|
+
ref: gitRemoteMatch.groups["ref"],
|
|
198
|
+
};
|
|
199
|
+
}
|
|
167
200
|
static async downloadIncludeRemote(cwd, stateDir, url, fetchIncludes) {
|
|
168
201
|
const fsUrl = utils_1.Utils.fsUrl(url);
|
|
169
202
|
try {
|
|
@@ -189,7 +222,7 @@ class ParserIncludes {
|
|
|
189
222
|
await fs_extra_1.default.mkdirp(path_1.default.dirname(`${cwd}/${target}/${normalizedFile}`));
|
|
190
223
|
await utils_1.Utils.bash(`
|
|
191
224
|
cd ${cwd}/${stateDir} \\
|
|
192
|
-
&& git clone -n --depth=1 --filter=tree:0 \\
|
|
225
|
+
&& git clone --branch "${ref}" -n --depth=1 --filter=tree:0 \\
|
|
193
226
|
${remote.schema}://${remote.host}/${project}.git \\
|
|
194
227
|
${cwd}/${target}.${ext} \\
|
|
195
228
|
&& cd ${cwd}/${target}.${ext} \\
|
|
@@ -215,4 +248,4 @@ function validateIncludeLocal(filePath) {
|
|
|
215
248
|
(0, assert_1.default)(!filePath.startsWith("./"), `\`${filePath}\` for include:local is invalid. Gitlab does not support relative path (ie. cannot start with \`./\`).`);
|
|
216
249
|
(0, assert_1.default)(!filePath.includes(".."), `\`${filePath}\` for include:local is invalid. Gitlab does not support directory traversal.`);
|
|
217
250
|
}
|
|
218
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parser-includes.js","sourceRoot":"","sources":["parser-includes.ts"],"names":[],"mappings":"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","sourcesContent":["import {Utils} from \"./utils\";\nimport fs from \"fs-extra\";\nimport {WriteStreams} from \"./write-streams\";\nimport {GitData} from \"./git-data\";\nimport assert, {AssertionError} from \"assert\";\nimport chalk from \"chalk\";\nimport {Parser} from \"./parser\";\nimport axios from \"axios\";\nimport globby from \"globby\";\nimport path from \"path\";\n\ntype ParserIncludesInitOptions = {\n    cwd: string;\n    stateDir: string;\n    writeStreams: WriteStreams;\n    gitData: GitData;\n    fetchIncludes: boolean;\n    variables: {[key: string]: string};\n    expandVariables: boolean;\n};\n\nconst MAXIMUM_INCLUDE = 150; // https://docs.gitlab.com/ee/administration/settings/continuous_integration.html#maximum-includes\n\nexport class ParserIncludes {\n    private static count: number = 0;\n\n    static resetCount (): void {\n        this.count = 0;\n    }\n\n    static async init (gitlabData: any, opts: ParserIncludesInitOptions): Promise<any[]> {\n        this.count++;\n        assert(\n            this.count <= MAXIMUM_INCLUDE + 1, // 1st init call is not counted\n            chalk`This GitLab CI configuration is invalid: Maximum of {blueBright ${MAXIMUM_INCLUDE}} nested includes are allowed!.`\n        );\n        let includeDatas: any[] = [];\n        const promises = [];\n        const {stateDir, cwd, fetchIncludes, gitData, expandVariables} = opts;\n\n        const include = this.expandInclude(gitlabData?.include, opts.variables);\n\n        // Find files to fetch from remote and place in .gitlab-ci-local/includes\n        for (const value of include) {\n            if (value[\"rules\"]) {\n                const include_rules = value[\"rules\"];\n                const rulesResult = Utils.getRulesResult({cwd, rules: include_rules, variables: opts.variables});\n                if (rulesResult.when === \"never\") {\n                    continue;\n                }\n            }\n            if (value[\"local\"]) {\n                validateIncludeLocal(value[\"local\"]);\n                const files = await globby(value[\"local\"].replace(/^\\//, \"\"), {dot: true, cwd});\n                if (files.length == 0) {\n                    throw new AssertionError({message: `Local include file cannot be found ${value[\"local\"]}`});\n                }\n            } else if (value[\"file\"]) {\n                for (const fileValue of Array.isArray(value[\"file\"]) ? value[\"file\"] : [value[\"file\"]]) {\n                    promises.push(this.downloadIncludeProjectFile(cwd, stateDir, value[\"project\"], value[\"ref\"] || \"HEAD\", fileValue, gitData, fetchIncludes));\n                }\n            } else if (value[\"template\"]) {\n                const {project, ref, file, domain} = this.covertTemplateToProjectFile(value[\"template\"]);\n                const url = `https://${domain}/${project}/-/raw/${ref}/${file}`;\n                promises.push(this.downloadIncludeRemote(cwd, stateDir, url, fetchIncludes));\n            } else if (value[\"remote\"]) {\n                promises.push(this.downloadIncludeRemote(cwd, stateDir, value[\"remote\"], fetchIncludes));\n            }\n\n        }\n\n        await Promise.all(promises);\n\n        for (const value of include) {\n            if (value[\"rules\"]) {\n                const include_rules = value[\"rules\"];\n                const rulesResult = Utils.getRulesResult({cwd, rules: include_rules, variables: opts.variables});\n                if (rulesResult.when === \"never\") {\n                    continue;\n                }\n            }\n            if (value[\"local\"]) {\n                const files = await globby([value[\"local\"].replace(/^\\//, \"\")], {dot: true, cwd});\n                for (const localFile of files) {\n                    const content = await Parser.loadYaml(`${cwd}/${localFile}`, {inputs: value.inputs || {}}, expandVariables);\n                    includeDatas = includeDatas.concat(await this.init(content, opts));\n                }\n            } else if (value[\"project\"]) {\n                for (const fileValue of Array.isArray(value[\"file\"]) ? value[\"file\"] : [value[\"file\"]]) {\n                    const fileDoc = await Parser.loadYaml(\n                        `${cwd}/${stateDir}/includes/${gitData.remote.host}/${value[\"project\"]}/${value[\"ref\"] || \"HEAD\"}/${fileValue}`\n                        , {inputs: value.inputs || {}}\n                        , expandVariables);\n                    // Expand local includes inside a \"project\"-like include\n                    fileDoc[\"include\"] = this.expandInclude(fileDoc[\"include\"], opts.variables);\n                    fileDoc[\"include\"].forEach((inner: any, i: number) => {\n                        if (!inner[\"local\"]) return;\n                        fileDoc[\"include\"][i] = {\n                            project: value[\"project\"],\n                            file: inner[\"local\"].replace(/^\\//, \"\"),\n                            ref: value[\"ref\"],\n                        };\n                    });\n\n                    includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n                }\n            } else if (value[\"template\"]) {\n                const {project, ref, file, domain} = this.covertTemplateToProjectFile(value[\"template\"]);\n                const fsUrl = Utils.fsUrl(`https://${domain}/${project}/-/raw/${ref}/${file}`);\n                const fileDoc = await Parser.loadYaml(\n                    `${cwd}/${stateDir}/includes/${fsUrl}`, {inputs: value.inputs || {}}, expandVariables\n                );\n                includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n            } else if (value[\"remote\"]) {\n                const fsUrl = Utils.fsUrl(value[\"remote\"]);\n                const fileDoc = await Parser.loadYaml(\n                    `${cwd}/${stateDir}/includes/${fsUrl}`, {inputs: value.inputs || {}}, expandVariables\n                );\n                includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n            } else {\n                throw new AssertionError({message: `Didn't understand include ${JSON.stringify(value)}`});\n            }\n        }\n\n        includeDatas.push(gitlabData);\n        return includeDatas;\n    }\n\n    static expandInclude (i: any, variables: {[key: string]: string}): any[] {\n        let include = i || [];\n        if (include && include.length == null) {\n            include = [ i ];\n        }\n        if (typeof include === \"string\") {\n            include = [include];\n        }\n\n        for (const [index, entry] of Object.entries(include)) {\n            if (typeof entry === \"string\" && (entry.startsWith(\"https:\") || entry.startsWith(\"http:\"))) {\n                include[index] = {\"remote\": entry};\n            } else if (typeof entry === \"string\") {\n                include[index] = {\"local\": entry};\n            } else {\n                include[index] = entry;\n            }\n\n        }\n\n        for (const entry of include) {\n            for (const [key, value] of Object.entries(entry)) {\n                entry[key] = Utils.expandText(value, variables);\n            }\n        }\n\n        return include;\n    }\n\n    static covertTemplateToProjectFile (template: string): {project: string; ref: string; file: string; domain: string} {\n        return {\n            domain: \"gitlab.com\",\n            project: \"gitlab-org/gitlab\",\n            ref: \"HEAD\",\n            file: `lib/gitlab/ci/templates/${template}`,\n        };\n    }\n\n    static async downloadIncludeRemote (cwd: string, stateDir: string, url: string, fetchIncludes: boolean): Promise<void> {\n        const fsUrl = Utils.fsUrl(url);\n        try {\n            const target = `${cwd}/${stateDir}/includes/${fsUrl}`;\n            if (await fs.pathExists(target) && !fetchIncludes) return;\n            const res = await axios.get(url);\n            await fs.outputFile(target, res.data);\n        } catch (e) {\n            throw new AssertionError({message: `Remote include could not be fetched ${url}\\n${e}`});\n        }\n    }\n\n    static async downloadIncludeProjectFile (cwd: string, stateDir: string, project: string, ref: string, file: string, gitData: GitData, fetchIncludes: boolean): Promise<void> {\n        const remote = gitData.remote;\n        const normalizedFile = file.replace(/^\\/+/, \"\");\n        try {\n            const target = `${stateDir}/includes/${remote.host}/${project}/${ref}`;\n            if (await fs.pathExists(`${cwd}/${target}/${normalizedFile}`) && !fetchIncludes) return;\n\n            if (remote.schema.startsWith(\"http\")) {\n                const ext = \"tmp-\" + Math.random();\n                await fs.mkdirp(path.dirname(`${cwd}/${target}/${normalizedFile}`));\n                await Utils.bash(`\n                    cd ${cwd}/${stateDir} \\\\\n                        && git clone -n --depth=1 --filter=tree:0 \\\\\n                                ${remote.schema}://${remote.host}/${project}.git \\\\\n                                ${cwd}/${target}.${ext} \\\\\n                        && cd ${cwd}/${target}.${ext} \\\\\n                        && git sparse-checkout set --no-cone ${normalizedFile} \\\\\n                        && git checkout \\\\\n                        && cd ${cwd}/${stateDir} \\\\\n                        && cp ${cwd}/${target}.${ext}/${normalizedFile} \\\\\n                              ${cwd}/${target}/${normalizedFile}\n                    `, cwd);\n            } else {\n                await fs.mkdirp(`${cwd}/${target}`);\n                await Utils.bash(`set -eou pipefail; git archive --remote=ssh://git@${remote.host}:${remote.port}/${project}.git ${ref} ${normalizedFile} | tar -f - -xC ${target}/`, cwd);\n            }\n        } catch (e) {\n            throw new AssertionError({message: `Project include could not be fetched { project: ${project}, ref: ${ref}, file: ${normalizedFile} }\\n${e}`});\n        }\n    }\n}\n\nfunction validateIncludeLocal (filePath: string) {\n    assert(!filePath.startsWith(\"./\"), `\\`${filePath}\\` for include:local is invalid. Gitlab does not support relative path (ie. cannot start with \\`./\\`).`);\n    assert(!filePath.includes(\"..\"), `\\`${filePath}\\` for include:local is invalid. Gitlab does not support directory traversal.`);\n}\n"]}
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parser-includes.js","sourceRoot":"","sources":["parser-includes.ts"],"names":[],"mappings":"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","sourcesContent":["import {Utils} from \"./utils\";\nimport fs from \"fs-extra\";\nimport {WriteStreams} from \"./write-streams\";\nimport {GitData} from \"./git-data\";\nimport assert, {AssertionError} from \"assert\";\nimport chalk from \"chalk\";\nimport {Parser} from \"./parser\";\nimport axios from \"axios\";\nimport globby from \"globby\";\nimport path from \"path\";\n\ntype ParserIncludesInitOptions = {\n    cwd: string;\n    stateDir: string;\n    writeStreams: WriteStreams;\n    gitData: GitData;\n    fetchIncludes: boolean;\n    variables: {[key: string]: string};\n    expandVariables: boolean;\n};\n\nconst MAXIMUM_INCLUDE = 150; // https://docs.gitlab.com/ee/administration/settings/continuous_integration.html#maximum-includes\n\nexport class ParserIncludes {\n    private static count: number = 0;\n\n    static resetCount (): void {\n        this.count = 0;\n    }\n\n    static async init (gitlabData: any, opts: ParserIncludesInitOptions): Promise<any[]> {\n        this.count++;\n        assert(\n            this.count <= MAXIMUM_INCLUDE + 1, // 1st init call is not counted\n            chalk`This GitLab CI configuration is invalid: Maximum of {blueBright ${MAXIMUM_INCLUDE}} nested includes are allowed!.`\n        );\n        let includeDatas: any[] = [];\n        const promises = [];\n        const {stateDir, cwd, fetchIncludes, gitData, expandVariables} = opts;\n\n        const include = this.expandInclude(gitlabData?.include, opts.variables);\n\n        // Find files to fetch from remote and place in .gitlab-ci-local/includes\n        for (const value of include) {\n            if (value[\"rules\"]) {\n                const include_rules = value[\"rules\"];\n                const rulesResult = Utils.getRulesResult({cwd, rules: include_rules, variables: opts.variables}, gitData);\n                if (rulesResult.when === \"never\") {\n                    continue;\n                }\n            }\n            if (value[\"local\"]) {\n                validateIncludeLocal(value[\"local\"]);\n                const files = await globby(value[\"local\"].replace(/^\\//, \"\"), {dot: true, cwd});\n                if (files.length == 0) {\n                    throw new AssertionError({message: `Local include file cannot be found ${value[\"local\"]}`});\n                }\n            } else if (value[\"file\"]) {\n                for (const fileValue of Array.isArray(value[\"file\"]) ? value[\"file\"] : [value[\"file\"]]) {\n                    promises.push(this.downloadIncludeProjectFile(cwd, stateDir, value[\"project\"], value[\"ref\"] || \"HEAD\", fileValue, gitData, fetchIncludes));\n                }\n            } else if (value[\"template\"]) {\n                const {project, ref, file, domain} = this.covertTemplateToProjectFile(value[\"template\"]);\n                const url = `https://${domain}/${project}/-/raw/${ref}/${file}`;\n                promises.push(this.downloadIncludeRemote(cwd, stateDir, url, fetchIncludes));\n            } else if (value[\"remote\"]) {\n                promises.push(this.downloadIncludeRemote(cwd, stateDir, value[\"remote\"], fetchIncludes));\n            }\n\n        }\n\n        await Promise.all(promises);\n\n        for (const value of include) {\n            if (value[\"rules\"]) {\n                const include_rules = value[\"rules\"];\n                const rulesResult = Utils.getRulesResult({cwd, rules: include_rules, variables: opts.variables}, gitData);\n                if (rulesResult.when === \"never\") {\n                    continue;\n                }\n            }\n            if (value[\"local\"]) {\n                const files = await globby([value[\"local\"].replace(/^\\//, \"\")], {dot: true, cwd});\n                for (const localFile of files) {\n                    const content = await Parser.loadYaml(`${cwd}/${localFile}`, {inputs: value.inputs || {}}, expandVariables);\n                    includeDatas = includeDatas.concat(await this.init(content, opts));\n                }\n            } else if (value[\"project\"]) {\n                for (const fileValue of Array.isArray(value[\"file\"]) ? value[\"file\"] : [value[\"file\"]]) {\n                    const fileDoc = await Parser.loadYaml(\n                        `${cwd}/${stateDir}/includes/${gitData.remote.host}/${value[\"project\"]}/${value[\"ref\"] || \"HEAD\"}/${fileValue}`\n                        , {inputs: value.inputs || {}}\n                        , expandVariables);\n                    // Expand local includes inside a \"project\"-like include\n                    fileDoc[\"include\"] = this.expandInclude(fileDoc[\"include\"], opts.variables);\n                    fileDoc[\"include\"].forEach((inner: any, i: number) => {\n                        if (!inner[\"local\"]) return;\n                        fileDoc[\"include\"][i] = {\n                            project: value[\"project\"],\n                            file: inner[\"local\"].replace(/^\\//, \"\"),\n                            ref: value[\"ref\"],\n                        };\n                    });\n\n                    includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n                }\n            } else if (value[\"component\"]) {\n                const {domain, projectPath, componentName, ref} = this.parseIncludeComponent(value[\"component\"]);\n                // converts component to project\n                const files = [`${componentName}.yml`, `${componentName}/template.yml`, null];\n                for (const f of files) {\n                    assert(f !== null, `This GitLab CI configuration is invalid: component: \\`${value[\"component\"]}\\`. One of the file [${files}] must exists in \\`${domain}/${projectPath}\\``);\n                    if (!(await Utils.remoteFileExist(f, ref, domain, projectPath, gitData.remote.schema))) continue;\n                    const fileDoc = {\n                        include: {\n                            project: projectPath,\n                            file: f,\n                            ref: ref,\n                        },\n                    };\n                    includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n                    break;\n                }\n            } else if (value[\"template\"]) {\n                const {project, ref, file, domain} = this.covertTemplateToProjectFile(value[\"template\"]);\n                const fsUrl = Utils.fsUrl(`https://${domain}/${project}/-/raw/${ref}/${file}`);\n                const fileDoc = await Parser.loadYaml(\n                    `${cwd}/${stateDir}/includes/${fsUrl}`, {inputs: value.inputs || {}}, expandVariables\n                );\n                includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n            } else if (value[\"remote\"]) {\n                const fsUrl = Utils.fsUrl(value[\"remote\"]);\n                const fileDoc = await Parser.loadYaml(\n                    `${cwd}/${stateDir}/includes/${fsUrl}`, {inputs: value.inputs || {}}, expandVariables\n                );\n                includeDatas = includeDatas.concat(await this.init(fileDoc, opts));\n            } else {\n                throw new AssertionError({message: `Didn't understand include ${JSON.stringify(value)}`});\n            }\n        }\n\n        includeDatas.push(gitlabData);\n        return includeDatas;\n    }\n\n    static expandInclude (i: any, variables: {[key: string]: string}): any[] {\n        let include = i || [];\n        if (include && include.length == null) {\n            include = [ i ];\n        }\n        if (typeof include === \"string\") {\n            include = [include];\n        }\n\n        for (const [index, entry] of Object.entries(include)) {\n            if (typeof entry === \"string\" && (entry.startsWith(\"https:\") || entry.startsWith(\"http:\"))) {\n                include[index] = {\"remote\": entry};\n            } else if (typeof entry === \"string\") {\n                include[index] = {\"local\": entry};\n            } else {\n                include[index] = entry;\n            }\n\n        }\n\n        for (const entry of include) {\n            for (const [key, value] of Object.entries(entry)) {\n                entry[key] = Utils.expandText(value, variables);\n            }\n        }\n\n        return include;\n    }\n\n    static covertTemplateToProjectFile (template: string): {project: string; ref: string; file: string; domain: string} {\n        return {\n            domain: \"gitlab.com\",\n            project: \"gitlab-org/gitlab\",\n            ref: \"HEAD\",\n            file: `lib/gitlab/ci/templates/${template}`,\n        };\n    }\n\n    static parseIncludeComponent (component: string): {domain: string; projectPath: string; componentName: string; ref: string} {\n        assert(!component.includes(\"://\"), `This GitLab CI configuration is invalid: component: \\`${component}\\` should not contain protocol`);\n        // eslint-disable-next-line no-useless-escape\n        const pattern = /(?<domain>[^/\\s]+)\\/(?<projectPath>.+)\\/(?<componentName>[^@]+)@(?<ref>.+)/; // regexr.com/7v7hm\n        const gitRemoteMatch = pattern.exec(component);\n\n        if (gitRemoteMatch?.groups == null) throw new Error(`This is a bug, please create a github issue if this is something you're expecting to work. input: ${component}`);\n        return {\n            domain: gitRemoteMatch.groups[\"domain\"],\n            projectPath: gitRemoteMatch.groups[\"projectPath\"],\n            componentName: `templates/${gitRemoteMatch.groups[\"componentName\"]}`,\n            ref: gitRemoteMatch.groups[\"ref\"],\n        };\n    }\n\n    static async downloadIncludeRemote (cwd: string, stateDir: string, url: string, fetchIncludes: boolean): Promise<void> {\n        const fsUrl = Utils.fsUrl(url);\n        try {\n            const target = `${cwd}/${stateDir}/includes/${fsUrl}`;\n            if (await fs.pathExists(target) && !fetchIncludes) return;\n            const res = await axios.get(url);\n            await fs.outputFile(target, res.data);\n        } catch (e) {\n            throw new AssertionError({message: `Remote include could not be fetched ${url}\\n${e}`});\n        }\n    }\n\n    static async downloadIncludeProjectFile (cwd: string, stateDir: string, project: string, ref: string, file: string, gitData: GitData, fetchIncludes: boolean): Promise<void> {\n        const remote = gitData.remote;\n        const normalizedFile = file.replace(/^\\/+/, \"\");\n        try {\n            const target = `${stateDir}/includes/${remote.host}/${project}/${ref}`;\n            if (await fs.pathExists(`${cwd}/${target}/${normalizedFile}`) && !fetchIncludes) return;\n\n            if (remote.schema.startsWith(\"http\")) {\n                const ext = \"tmp-\" + Math.random();\n                await fs.mkdirp(path.dirname(`${cwd}/${target}/${normalizedFile}`));\n                await Utils.bash(`\n                    cd ${cwd}/${stateDir} \\\\\n                        && git clone --branch \"${ref}\" -n --depth=1 --filter=tree:0 \\\\\n                                ${remote.schema}://${remote.host}/${project}.git \\\\\n                                ${cwd}/${target}.${ext} \\\\\n                        && cd ${cwd}/${target}.${ext} \\\\\n                        && git sparse-checkout set --no-cone ${normalizedFile} \\\\\n                        && git checkout \\\\\n                        && cd ${cwd}/${stateDir} \\\\\n                        && cp ${cwd}/${target}.${ext}/${normalizedFile} \\\\\n                              ${cwd}/${target}/${normalizedFile}\n                    `, cwd);\n            } else {\n                await fs.mkdirp(`${cwd}/${target}`);\n                await Utils.bash(`set -eou pipefail; git archive --remote=ssh://git@${remote.host}:${remote.port}/${project}.git ${ref} ${normalizedFile} | tar -f - -xC ${target}/`, cwd);\n            }\n        } catch (e) {\n            throw new AssertionError({message: `Project include could not be fetched { project: ${project}, ref: ${ref}, file: ${normalizedFile} }\\n${e}`});\n        }\n    }\n}\n\nfunction validateIncludeLocal (filePath: string) {\n    assert(!filePath.startsWith(\"./\"), `\\`${filePath}\\` for include:local is invalid. Gitlab does not support relative path (ie. cannot start with \\`./\\`).`);\n    assert(!filePath.includes(\"..\"), `\\`${filePath}\\` for include:local is invalid. Gitlab does not support directory traversal.`);\n}\n"]}
|
package/src/parser.js
CHANGED
|
@@ -82,7 +82,7 @@ class Parser {
|
|
|
82
82
|
writeStreams.stderr((0, chalk_1.default) `{yellow ${warning}}\n`);
|
|
83
83
|
}
|
|
84
84
|
// # Second layer of check for errors that are not caught in Validator.run
|
|
85
|
-
if (parser.argv.
|
|
85
|
+
if (parser.argv.jsonSchemaValidation) {
|
|
86
86
|
const time = process.hrtime();
|
|
87
87
|
validator_1.Validator.jsonSchemaValidation(parser.gitlabData);
|
|
88
88
|
writeStreams.stderr((0, chalk_1.default) `{grey json schema validated} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
|
|
@@ -149,12 +149,15 @@ class Parser {
|
|
|
149
149
|
(0, assert_1.default)(gitData != null, "gitData must be set");
|
|
150
150
|
(0, assert_1.default)(variablesFromFiles != null, "homeVariables must be set");
|
|
151
151
|
let nodeIndex = 1;
|
|
152
|
-
const parallelMatrixVariablesList = parallel.matrixVariablesList(jobData, jobName)
|
|
152
|
+
const parallelMatrixVariablesList = parallel.matrixVariablesList(jobData, jobName);
|
|
153
153
|
for (const parallelMatrixVariables of parallelMatrixVariablesList) {
|
|
154
154
|
let matrixJobName = jobName;
|
|
155
155
|
if (parallelMatrixVariables) {
|
|
156
156
|
matrixJobName = `${jobName}: [${Object.values(parallelMatrixVariables ?? []).join(",")}]`;
|
|
157
157
|
}
|
|
158
|
+
else if (parallel.isPlainParallel(jobData)) {
|
|
159
|
+
matrixJobName = `${jobName}: [${nodeIndex}/${parallelMatrixVariablesList.length}]`;
|
|
160
|
+
}
|
|
158
161
|
const job = new job_1.Job({
|
|
159
162
|
argv,
|
|
160
163
|
writeStreams,
|
|
@@ -167,7 +170,7 @@ class Parser {
|
|
|
167
170
|
gitData,
|
|
168
171
|
variablesFromFiles,
|
|
169
172
|
matrixVariables: parallelMatrixVariables,
|
|
170
|
-
nodeIndex:
|
|
173
|
+
nodeIndex: (jobData.parallel != null) ? nodeIndex : null,
|
|
171
174
|
nodesTotal: parallelMatrixVariablesList.length,
|
|
172
175
|
expandVariables: this.expandVariables,
|
|
173
176
|
});
|
|
@@ -341,4 +344,4 @@ function validateInput(inputValue, ctx) {
|
|
|
341
344
|
console.log((0, chalk_1.default) `{black.bgYellowBright WARN } spec:inputs:regex is currently not supported via gitlab-ci-local. This will just be a no-op.`);
|
|
342
345
|
}
|
|
343
346
|
}
|
|
344
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parser.js","sourceRoot":"","sources":["parser.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\";\nimport path from \"path\";\nimport deepExtend from \"deep-extend\";\nimport * as fs from \"fs-extra\";\nimport * as yaml from \"js-yaml\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {Job} from \"./job\";\nimport * as DataExpander from \"./data-expander\";\nimport {Utils} from \"./utils\";\nimport assert from \"assert\";\nimport {Validator} from \"./validator\";\nimport * as parallel from \"./parallel\";\nimport {GitData} from \"./git-data\";\nimport {ParserIncludes} from \"./parser-includes\";\nimport {Producers} from \"./producers\";\nimport {VariablesFromFiles} from \"./variables-from-files\";\nimport {Argv} from \"./argv\";\nimport {WriteStreams} from \"./write-streams\";\nimport {init as initPredefinedVariables} from \"./predefined-variables\";\n\nconst MAX_FUNCTIONS = 3;\nconst INCLUDE_INPUTS_SUPPORTED_TYPES = [\"string\", \"boolean\", \"number\"];\n\nexport class Parser {\n\n    private _stages: string[] = [];\n    private _gitlabData: any;\n    private _jobNamePad: number | null = null;\n\n    readonly jobs: Job[];\n    readonly argv: Argv;\n    readonly writeStreams: WriteStreams;\n    readonly pipelineIid: number;\n    readonly expandVariables: boolean;\n\n    private constructor (argv: Argv, writeStreams: WriteStreams, pipelineIid: number, jobs: Job[], expandVariables: boolean) {\n        this.argv = argv;\n        this.writeStreams = writeStreams;\n        this.pipelineIid = pipelineIid;\n        this.jobs = jobs;\n        this.expandVariables = expandVariables;\n    }\n\n    get stages (): readonly string[] {\n        return this._stages;\n    }\n\n    get gitlabData () {\n        return this._gitlabData;\n    }\n\n    get jobNamePad (): number {\n        return this._jobNamePad ?? 0;\n    }\n\n    static async create (argv: Argv, writeStreams: WriteStreams, pipelineIid: number, jobs: Job[], expandVariables: boolean = true) {\n        const parser = new Parser(argv, writeStreams, pipelineIid, jobs, expandVariables);\n        const time = process.hrtime();\n        await parser.init();\n        const warnings = await Validator.run(parser.jobs, parser.stages);\n        const parsingTime = process.hrtime(time);\n        writeStreams.stderr(chalk`{grey parsing and downloads finished} in {grey ${prettyHrtime(parsingTime)}}\\n`);\n\n        for (const warning of warnings) {\n            writeStreams.stderr(chalk`{yellow ${warning}}\\n`);\n        }\n\n        // # Second layer of check for errors that are not caught in Validator.run\n        if (parser.argv.enableJsonSchemaValidation) {\n            const time = process.hrtime();\n            Validator.jsonSchemaValidation(parser.gitlabData);\n            writeStreams.stderr(chalk`{grey json schema validated} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n        return parser;\n    }\n\n    async init () {\n        const argv = this.argv;\n        const cwd = argv.cwd;\n        const stateDir = argv.stateDir;\n        const writeStreams = this.writeStreams;\n        const file = argv.file;\n        const pipelineIid = this.pipelineIid;\n        const fetchIncludes = argv.fetchIncludes;\n        const gitData = await GitData.init(cwd, writeStreams);\n        const variablesFromFiles = await VariablesFromFiles.init(argv, writeStreams, gitData);\n        const predefinedVariables = initPredefinedVariables({gitData, argv});\n        const envMatchedVariables = Utils.findEnvMatchedVariables(variablesFromFiles);\n        const variables = {...predefinedVariables, ...envMatchedVariables, ...argv.variable};\n        const expanded = Utils.expandVariables(variables);\n\n        let yamlDataList: any[] = [{stages: [\".pre\", \"build\", \"test\", \"deploy\", \".post\"]}];\n        const gitlabCiData = await Parser.loadYaml(`${cwd}/${file}`, {}, this.expandVariables);\n\n        yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiData, {cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables}));\n        ParserIncludes.resetCount();\n\n        const gitlabCiLocalData = await Parser.loadYaml(`${cwd}/.gitlab-ci-local.yml`, {}, this.expandVariables);\n        yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiLocalData, {cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables}));\n        ParserIncludes.resetCount();\n\n        const gitlabData: any = deepExtend({}, ...yamlDataList);\n\n        // Expand various fields in gitlabData\n        DataExpander.jobExtends(gitlabData);\n        DataExpander.reference(gitlabData, gitlabData);\n        DataExpander.complexObjects(gitlabData);\n        DataExpander.defaults(gitlabData);\n        DataExpander.globalVariables(gitlabData);\n        DataExpander.flattenLists(gitlabData);\n\n        assert(gitlabData.stages && Array.isArray(gitlabData.stages), chalk`{yellow stages:} must be an array`);\n        if (!gitlabData.stages.includes(\".pre\")) {\n            gitlabData.stages.unshift(\".pre\");\n        }\n        if (!gitlabData.stages.includes(\".post\")) {\n            gitlabData.stages.push(\".post\");\n        }\n        this._stages = gitlabData.stages;\n\n        // Check job variables for invalid hash of key value pairs, and cast numbers to strings\n        Utils.forEachRealJob(gitlabData, (jobName, jobData) => {\n            for (const [key, _value] of Object.entries(jobData.variables || {})) {\n                let value = _value;\n                if (value === null) value = \"\"; // variable's values are nullable\n                assert(\n                    typeof value === \"string\" || typeof value === \"number\",\n                    chalk`{blueBright ${jobName}} has invalid variables hash of key value pairs. ${key}=${value}`\n                );\n                jobData.variables[key] = String(value);\n            }\n\n            for (let i = 0; i < (jobData.services ?? []).length; i++) {\n                const service = jobData.services[i];\n                for (const [key, value] of Object.entries(service.variables || {})) {\n                    assert(\n                        typeof value === \"string\" || typeof value === \"number\",\n                        chalk`{blueBright ${jobName}.services[${i}]} has invalid variables hash of key value pairs. ${key}=${value}`\n                    );\n                    jobData.services[i].variables[key] = String(value);\n                }\n            }\n        });\n\n        this._gitlabData = gitlabData;\n\n        // Generate jobs and put them into stages\n        Utils.forEachRealJob(gitlabData, (jobName, jobData) => {\n            assert(gitData != null, \"gitData must be set\");\n            assert(variablesFromFiles != null, \"homeVariables must be set\");\n\n            let nodeIndex = 1;\n            const parallelMatrixVariablesList = parallel.matrixVariablesList(jobData, jobName) ?? [null];\n            for (const parallelMatrixVariables of parallelMatrixVariablesList) {\n                let matrixJobName = jobName;\n                if (parallelMatrixVariables) {\n                    matrixJobName = `${jobName}: [${Object.values(parallelMatrixVariables ?? []).join(\",\")}]`;\n                }\n\n                const job = new Job({\n                    argv,\n                    writeStreams,\n                    data: jobData,\n                    name: matrixJobName,\n                    baseName: jobName,\n                    globalVariables: gitlabData.variables,\n                    pipelineIid: pipelineIid,\n                    predefinedVariables,\n                    gitData,\n                    variablesFromFiles,\n                    matrixVariables: parallelMatrixVariables,\n                    nodeIndex: parallelMatrixVariables !== null ? nodeIndex : null,\n                    nodesTotal: parallelMatrixVariablesList.length,\n                    expandVariables: this.expandVariables,\n                });\n                const foundStage = this.stages.includes(job.stage);\n                assert(foundStage, chalk`{yellow stage:${job.stage}} not found for {blueBright ${job.name}}`);\n                this.jobs.push(job);\n                nodeIndex++;\n            }\n        });\n\n        // Add some padding so that job logs are nicely aligned\n        // allow users to override this in case they have really long job name (see #840)\n        if (this.argv.maxJobNamePadding !== null && this.argv.maxJobNamePadding <= 0) {\n            this._jobNamePad = 0;\n        } else {\n            const jobs = this.argv.job.length !== 0 ? this.argv.job : this.jobs;\n            jobs.forEach((job) => {\n                let jobNeedsLength: number[] = [];\n\n                if (this.argv.needs && this.argv.job.length > 0) {\n                    const found = this.jobs.find(j => j.baseName === job);\n                    if (found !== undefined && found.needs !== null) {\n                        jobNeedsLength = found.needs.map(f => f.job.length);\n                    }\n                }\n                const jobLength = typeof job == \"string\" ? job.length : job.name.length;\n                this._jobNamePad = Math.max(jobLength, this._jobNamePad ?? 0, ...jobNeedsLength);\n            });\n            if (this.argv.maxJobNamePadding !== null) {\n                this._jobNamePad = Math.min(this.argv.maxJobNamePadding ?? 0, this._jobNamePad ?? 0);\n            }\n        }\n\n        // Set jobNamePad on all jobs\n        this.jobs.forEach((job) => {\n            job.jobNamePad = this.jobNamePad;\n        });\n\n        // Generate producers for each job\n        this.jobs.forEach((job) => {\n            job.producers = Producers.init(this.jobs, this.stages, job);\n        });\n    }\n\n    static async loadYaml (filePath: string, ctx: any = {}, expandVariables: boolean = true): Promise<any> {\n        const ymlPath = `${filePath}`;\n        if (!fs.existsSync(ymlPath)) {\n            return {};\n        }\n\n        const fileContent = await fs.readFile(`${filePath}`, \"utf8\");\n        const fileSplit = fileContent.split(/\\r?\\n/g);\n        const fileSplitClone = fileSplit.slice();\n\n        let interactiveMatch = null;\n        let descriptionMatch = null;\n        let injectSSHAgent = null;\n        let noArtifactsToSourceMatch = null;\n        let index = 0;\n        if (expandVariables) {\n            for (const line of fileSplit) {\n                interactiveMatch = !interactiveMatch ? /#\\s?@\\s?[Ii]nteractive/.exec(line) : interactiveMatch;\n                injectSSHAgent = !injectSSHAgent ? /#\\s?@\\s?[Ii]njectSSHAgent/.exec(line) : injectSSHAgent;\n                noArtifactsToSourceMatch = !noArtifactsToSourceMatch ? /#\\s?@\\s?NoArtifactsToSource/i.exec(line) : noArtifactsToSourceMatch;\n                descriptionMatch = !descriptionMatch ? /#\\s?@\\s?[Dd]escription (?<description>.*)/.exec(line) : descriptionMatch;\n\n                const jobMatch = /\\w:/.exec(line);\n                if (jobMatch && (interactiveMatch || descriptionMatch || injectSSHAgent || noArtifactsToSourceMatch)) {\n                    if (interactiveMatch) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclInteractive: true\");\n                        index++;\n                    }\n                    if (injectSSHAgent) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclInjectSSHAgent: true\");\n                        index++;\n                    }\n                    if (noArtifactsToSourceMatch) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclArtifactsToSource: false\");\n                        index++;\n                    }\n                    if (descriptionMatch) {\n                        fileSplitClone.splice(index + 1, 0, `  gclDescription: ${descriptionMatch?.groups?.description ?? \"\"}`);\n                        index++;\n                    }\n                    interactiveMatch = null;\n                    descriptionMatch = null;\n                    injectSSHAgent = null;\n                    noArtifactsToSourceMatch = null;\n                }\n                index++;\n            }\n        }\n\n        const referenceType = new yaml.Type(\"!reference\", {\n            kind: \"sequence\",\n            construct: function (data) {\n                return {referenceData: data};\n            },\n        });\n        const schema = yaml.DEFAULT_SCHEMA.extend([referenceType]);\n        let fileData;\n\n        try {\n            fileData = yaml.loadAll(fileSplitClone.join(\"\\n\"), null, {schema}) as any[];\n        } catch (e: any) {\n            if (e instanceof yaml.YAMLException && e.reason === \"duplicated mapping key\") {\n                console.log(chalk`{black.bgYellowBright  WARN } duplicated mapping key detected! Values will be overwritten!`);\n                fileData = yaml.loadAll(fileSplitClone.join(\"\\n\"), null, {schema, json: true}) as any[];\n            } else {\n                throw e;\n            }\n        }\n\n        if (fileData.length <= 1) return fileData[0];\n\n        if (isGitlabSpecFile(fileData[0])) {\n            const inputsSpecification: any = fileData[0];\n            const uninterpolatedConfigurations: any = fileData[1];\n\n            const interpolatedConfigurations = JSON.stringify(uninterpolatedConfigurations)\n                .replace(\n                    /\\$\\[\\[\\s*inputs.(?<interpolationKey>[\\w-]+)\\s*\\|?\\s*(?<interpolationFunctions>.*?)\\s*\\]\\]/g // regexr.com/7sh15\n                    , (_: string, interpolationKey: string, interpolationFunctions: string) => {\n                        const configFilePath = path.relative(process.cwd(), filePath);\n                        const context = {\n                            interpolationKey,\n                            interpolationFunctions,\n                            inputsSpecification,\n                            configFilePath,\n                            ...ctx,\n                        };\n\n                        validateInterpolationKey(context);\n                        validateInterpolationFunctions(context);\n                        const inputValue = getInputValue(context);\n                        validateInput(inputValue, context);\n\n                        const jsonValue = JSON.stringify(inputValue);\n                        // Unquote string if necessary\n                        if (typeof(jsonValue) == \"string\" && jsonValue.startsWith(\"\\\"\") && jsonValue.endsWith(\"\\\"\")) {\n                            return jsonValue.slice(1, -1);\n                        }\n                        return jsonValue;\n                    });\n            return JSON.parse(interpolatedConfigurations);\n        }\n        return fileData[0];\n    }\n}\n\nfunction isGitlabSpecFile (fileData: any) {\n    return \"spec\" in fileData;\n}\n\nfunction validateInterpolationFunctions (ctx: any) {\n    const {interpolationFunctions, configFilePath} = ctx;\n    if (interpolationFunctions != \"\") {\n        console.log(chalk`{black.bgYellowBright  WARN } interpolation functions is currently not supported via gitlab-ci-local. Functions will just be a no-op.`);\n    }\n    assert(interpolationFunctions.split(\"|\").length <= MAX_FUNCTIONS, chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: too many functions in interpolation block.`);\n}\n\nfunction getInputValue (ctx: any) {\n    const {inputs, interpolationKey, configFilePath, inputsSpecification} = ctx;\n    const inputValue = inputs[interpolationKey] || inputsSpecification.spec.inputs[interpolationKey]?.default;\n    assert(inputValue !== undefined, chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: required value has not been provided.`);\n    return inputValue;\n}\n\nfunction validateInterpolationKey (ctx: any): any {\n    const {configFilePath, interpolationKey, inputsSpecification} = ctx;\n    const invalidInterpolationKeyErr = chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: unknown interpolation key: \\`${interpolationKey}\\`.`;\n    assert(inputsSpecification.spec.inputs?.[interpolationKey] !== undefined, invalidInterpolationKeyErr);\n}\n\nfunction validateInput (inputValue: any, ctx: any): any {\n    const {configFilePath, interpolationKey, inputsSpecification} = ctx;\n\n    const options = inputsSpecification.spec.inputs[interpolationKey]?.options;\n    if (options) {\n        assert(options.includes(inputValue),\n            chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: \\`{blueBright ${inputValue}}\\` cannot be used because it is not in the list of allowed options.`);\n    }\n\n    const type = inputsSpecification.spec.inputs[interpolationKey]?.type || \"string\";\n    assert(INCLUDE_INPUTS_SUPPORTED_TYPES.includes(type),\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: header:spec:inputs:{blueBright ${interpolationKey}} input type unknown value: {blueBright ${type}}.`);\n    assert(typeof inputValue == type,\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: provided value is not a {blueBright ${type}}.`);\n\n    const regex = inputsSpecification.spec.inputs[interpolationKey]?.regex;\n    if (regex) {\n        console.log(chalk`{black.bgYellowBright  WARN } spec:inputs:regex is currently not supported via gitlab-ci-local. This will just be a no-op.`);\n    }\n}\n"]}
|
|
347
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parser.js","sourceRoot":"","sources":["parser.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\";\nimport path from \"path\";\nimport deepExtend from \"deep-extend\";\nimport * as fs from \"fs-extra\";\nimport * as yaml from \"js-yaml\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {Job} from \"./job\";\nimport * as DataExpander from \"./data-expander\";\nimport {Utils} from \"./utils\";\nimport assert from \"assert\";\nimport {Validator} from \"./validator\";\nimport * as parallel from \"./parallel\";\nimport {GitData} from \"./git-data\";\nimport {ParserIncludes} from \"./parser-includes\";\nimport {Producers} from \"./producers\";\nimport {VariablesFromFiles} from \"./variables-from-files\";\nimport {Argv} from \"./argv\";\nimport {WriteStreams} from \"./write-streams\";\nimport {init as initPredefinedVariables} from \"./predefined-variables\";\n\nconst MAX_FUNCTIONS = 3;\nconst INCLUDE_INPUTS_SUPPORTED_TYPES = [\"string\", \"boolean\", \"number\"];\n\nexport class Parser {\n\n    private _stages: string[] = [];\n    private _gitlabData: any;\n    private _jobNamePad: number | null = null;\n\n    readonly jobs: Job[];\n    readonly argv: Argv;\n    readonly writeStreams: WriteStreams;\n    readonly pipelineIid: number;\n    readonly expandVariables: boolean;\n\n    private constructor (argv: Argv, writeStreams: WriteStreams, pipelineIid: number, jobs: Job[], expandVariables: boolean) {\n        this.argv = argv;\n        this.writeStreams = writeStreams;\n        this.pipelineIid = pipelineIid;\n        this.jobs = jobs;\n        this.expandVariables = expandVariables;\n    }\n\n    get stages (): readonly string[] {\n        return this._stages;\n    }\n\n    get gitlabData () {\n        return this._gitlabData;\n    }\n\n    get jobNamePad (): number {\n        return this._jobNamePad ?? 0;\n    }\n\n    static async create (argv: Argv, writeStreams: WriteStreams, pipelineIid: number, jobs: Job[], expandVariables: boolean = true) {\n        const parser = new Parser(argv, writeStreams, pipelineIid, jobs, expandVariables);\n        const time = process.hrtime();\n        await parser.init();\n        const warnings = await Validator.run(parser.jobs, parser.stages);\n        const parsingTime = process.hrtime(time);\n        writeStreams.stderr(chalk`{grey parsing and downloads finished} in {grey ${prettyHrtime(parsingTime)}}\\n`);\n\n        for (const warning of warnings) {\n            writeStreams.stderr(chalk`{yellow ${warning}}\\n`);\n        }\n\n        // # Second layer of check for errors that are not caught in Validator.run\n        if (parser.argv.jsonSchemaValidation) {\n            const time = process.hrtime();\n            Validator.jsonSchemaValidation(parser.gitlabData);\n            writeStreams.stderr(chalk`{grey json schema validated} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n        return parser;\n    }\n\n    async init () {\n        const argv = this.argv;\n        const cwd = argv.cwd;\n        const stateDir = argv.stateDir;\n        const writeStreams = this.writeStreams;\n        const file = argv.file;\n        const pipelineIid = this.pipelineIid;\n        const fetchIncludes = argv.fetchIncludes;\n        const gitData = await GitData.init(cwd, writeStreams);\n        const variablesFromFiles = await VariablesFromFiles.init(argv, writeStreams, gitData);\n        const predefinedVariables = initPredefinedVariables({gitData, argv});\n        const envMatchedVariables = Utils.findEnvMatchedVariables(variablesFromFiles);\n        const variables = {...predefinedVariables, ...envMatchedVariables, ...argv.variable};\n        const expanded = Utils.expandVariables(variables);\n\n        let yamlDataList: any[] = [{stages: [\".pre\", \"build\", \"test\", \"deploy\", \".post\"]}];\n        const gitlabCiData = await Parser.loadYaml(`${cwd}/${file}`, {}, this.expandVariables);\n\n        yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiData, {cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables}));\n        ParserIncludes.resetCount();\n\n        const gitlabCiLocalData = await Parser.loadYaml(`${cwd}/.gitlab-ci-local.yml`, {}, this.expandVariables);\n        yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiLocalData, {cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables}));\n        ParserIncludes.resetCount();\n\n        const gitlabData: any = deepExtend({}, ...yamlDataList);\n\n        // Expand various fields in gitlabData\n        DataExpander.jobExtends(gitlabData);\n        DataExpander.reference(gitlabData, gitlabData);\n        DataExpander.complexObjects(gitlabData);\n        DataExpander.defaults(gitlabData);\n        DataExpander.globalVariables(gitlabData);\n        DataExpander.flattenLists(gitlabData);\n\n        assert(gitlabData.stages && Array.isArray(gitlabData.stages), chalk`{yellow stages:} must be an array`);\n        if (!gitlabData.stages.includes(\".pre\")) {\n            gitlabData.stages.unshift(\".pre\");\n        }\n        if (!gitlabData.stages.includes(\".post\")) {\n            gitlabData.stages.push(\".post\");\n        }\n        this._stages = gitlabData.stages;\n\n        // Check job variables for invalid hash of key value pairs, and cast numbers to strings\n        Utils.forEachRealJob(gitlabData, (jobName, jobData) => {\n            for (const [key, _value] of Object.entries(jobData.variables || {})) {\n                let value = _value;\n                if (value === null) value = \"\"; // variable's values are nullable\n                assert(\n                    typeof value === \"string\" || typeof value === \"number\",\n                    chalk`{blueBright ${jobName}} has invalid variables hash of key value pairs. ${key}=${value}`\n                );\n                jobData.variables[key] = String(value);\n            }\n\n            for (let i = 0; i < (jobData.services ?? []).length; i++) {\n                const service = jobData.services[i];\n                for (const [key, value] of Object.entries(service.variables || {})) {\n                    assert(\n                        typeof value === \"string\" || typeof value === \"number\",\n                        chalk`{blueBright ${jobName}.services[${i}]} has invalid variables hash of key value pairs. ${key}=${value}`\n                    );\n                    jobData.services[i].variables[key] = String(value);\n                }\n            }\n        });\n\n        this._gitlabData = gitlabData;\n\n        // Generate jobs and put them into stages\n        Utils.forEachRealJob(gitlabData, (jobName, jobData) => {\n            assert(gitData != null, \"gitData must be set\");\n            assert(variablesFromFiles != null, \"homeVariables must be set\");\n\n            let nodeIndex = 1;\n            const parallelMatrixVariablesList = parallel.matrixVariablesList(jobData, jobName);\n            for (const parallelMatrixVariables of parallelMatrixVariablesList) {\n                let matrixJobName = jobName;\n                if (parallelMatrixVariables) {\n                    matrixJobName = `${jobName}: [${Object.values(parallelMatrixVariables ?? []).join(\",\")}]`;\n                } else if (parallel.isPlainParallel(jobData)) {\n                    matrixJobName = `${jobName}: [${nodeIndex}/${parallelMatrixVariablesList.length}]`;\n                }\n\n                const job = new Job({\n                    argv,\n                    writeStreams,\n                    data: jobData,\n                    name: matrixJobName,\n                    baseName: jobName,\n                    globalVariables: gitlabData.variables,\n                    pipelineIid: pipelineIid,\n                    predefinedVariables,\n                    gitData,\n                    variablesFromFiles,\n                    matrixVariables: parallelMatrixVariables,\n                    nodeIndex: (jobData.parallel != null) ? nodeIndex : null,\n                    nodesTotal: parallelMatrixVariablesList.length,\n                    expandVariables: this.expandVariables,\n                });\n                const foundStage = this.stages.includes(job.stage);\n                assert(foundStage, chalk`{yellow stage:${job.stage}} not found for {blueBright ${job.name}}`);\n                this.jobs.push(job);\n                nodeIndex++;\n            }\n        });\n\n        // Add some padding so that job logs are nicely aligned\n        // allow users to override this in case they have really long job name (see #840)\n        if (this.argv.maxJobNamePadding !== null && this.argv.maxJobNamePadding <= 0) {\n            this._jobNamePad = 0;\n        } else {\n            const jobs = this.argv.job.length !== 0 ? this.argv.job : this.jobs;\n            jobs.forEach((job) => {\n                let jobNeedsLength: number[] = [];\n\n                if (this.argv.needs && this.argv.job.length > 0) {\n                    const found = this.jobs.find(j => j.baseName === job);\n                    if (found !== undefined && found.needs !== null) {\n                        jobNeedsLength = found.needs.map(f => f.job.length);\n                    }\n                }\n                const jobLength = typeof job == \"string\" ? job.length : job.name.length;\n                this._jobNamePad = Math.max(jobLength, this._jobNamePad ?? 0, ...jobNeedsLength);\n            });\n            if (this.argv.maxJobNamePadding !== null) {\n                this._jobNamePad = Math.min(this.argv.maxJobNamePadding ?? 0, this._jobNamePad ?? 0);\n            }\n        }\n\n        // Set jobNamePad on all jobs\n        this.jobs.forEach((job) => {\n            job.jobNamePad = this.jobNamePad;\n        });\n\n        // Generate producers for each job\n        this.jobs.forEach((job) => {\n            job.producers = Producers.init(this.jobs, this.stages, job);\n        });\n    }\n\n    static async loadYaml (filePath: string, ctx: any = {}, expandVariables: boolean = true): Promise<any> {\n        const ymlPath = `${filePath}`;\n        if (!fs.existsSync(ymlPath)) {\n            return {};\n        }\n\n        const fileContent = await fs.readFile(`${filePath}`, \"utf8\");\n        const fileSplit = fileContent.split(/\\r?\\n/g);\n        const fileSplitClone = fileSplit.slice();\n\n        let interactiveMatch = null;\n        let descriptionMatch = null;\n        let injectSSHAgent = null;\n        let noArtifactsToSourceMatch = null;\n        let index = 0;\n        if (expandVariables) {\n            for (const line of fileSplit) {\n                interactiveMatch = !interactiveMatch ? /#\\s?@\\s?[Ii]nteractive/.exec(line) : interactiveMatch;\n                injectSSHAgent = !injectSSHAgent ? /#\\s?@\\s?[Ii]njectSSHAgent/.exec(line) : injectSSHAgent;\n                noArtifactsToSourceMatch = !noArtifactsToSourceMatch ? /#\\s?@\\s?NoArtifactsToSource/i.exec(line) : noArtifactsToSourceMatch;\n                descriptionMatch = !descriptionMatch ? /#\\s?@\\s?[Dd]escription (?<description>.*)/.exec(line) : descriptionMatch;\n\n                const jobMatch = /\\w:/.exec(line);\n                if (jobMatch && (interactiveMatch || descriptionMatch || injectSSHAgent || noArtifactsToSourceMatch)) {\n                    if (interactiveMatch) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclInteractive: true\");\n                        index++;\n                    }\n                    if (injectSSHAgent) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclInjectSSHAgent: true\");\n                        index++;\n                    }\n                    if (noArtifactsToSourceMatch) {\n                        fileSplitClone.splice(index + 1, 0, \"  gclArtifactsToSource: false\");\n                        index++;\n                    }\n                    if (descriptionMatch) {\n                        fileSplitClone.splice(index + 1, 0, `  gclDescription: ${descriptionMatch?.groups?.description ?? \"\"}`);\n                        index++;\n                    }\n                    interactiveMatch = null;\n                    descriptionMatch = null;\n                    injectSSHAgent = null;\n                    noArtifactsToSourceMatch = null;\n                }\n                index++;\n            }\n        }\n\n        const referenceType = new yaml.Type(\"!reference\", {\n            kind: \"sequence\",\n            construct: function (data) {\n                return {referenceData: data};\n            },\n        });\n        const schema = yaml.DEFAULT_SCHEMA.extend([referenceType]);\n        let fileData;\n\n        try {\n            fileData = yaml.loadAll(fileSplitClone.join(\"\\n\"), null, {schema}) as any[];\n        } catch (e: any) {\n            if (e instanceof yaml.YAMLException && e.reason === \"duplicated mapping key\") {\n                console.log(chalk`{black.bgYellowBright  WARN } duplicated mapping key detected! Values will be overwritten!`);\n                fileData = yaml.loadAll(fileSplitClone.join(\"\\n\"), null, {schema, json: true}) as any[];\n            } else {\n                throw e;\n            }\n        }\n\n        if (fileData.length <= 1) return fileData[0];\n\n        if (isGitlabSpecFile(fileData[0])) {\n            const inputsSpecification: any = fileData[0];\n            const uninterpolatedConfigurations: any = fileData[1];\n\n            const interpolatedConfigurations = JSON.stringify(uninterpolatedConfigurations)\n                .replace(\n                    /\\$\\[\\[\\s*inputs.(?<interpolationKey>[\\w-]+)\\s*\\|?\\s*(?<interpolationFunctions>.*?)\\s*\\]\\]/g // regexr.com/7sh15\n                    , (_: string, interpolationKey: string, interpolationFunctions: string) => {\n                        const configFilePath = path.relative(process.cwd(), filePath);\n                        const context = {\n                            interpolationKey,\n                            interpolationFunctions,\n                            inputsSpecification,\n                            configFilePath,\n                            ...ctx,\n                        };\n\n                        validateInterpolationKey(context);\n                        validateInterpolationFunctions(context);\n                        const inputValue = getInputValue(context);\n                        validateInput(inputValue, context);\n\n                        const jsonValue = JSON.stringify(inputValue);\n                        // Unquote string if necessary\n                        if (typeof(jsonValue) == \"string\" && jsonValue.startsWith(\"\\\"\") && jsonValue.endsWith(\"\\\"\")) {\n                            return jsonValue.slice(1, -1);\n                        }\n                        return jsonValue;\n                    });\n            return JSON.parse(interpolatedConfigurations);\n        }\n        return fileData[0];\n    }\n}\n\nfunction isGitlabSpecFile (fileData: any) {\n    return \"spec\" in fileData;\n}\n\nfunction validateInterpolationFunctions (ctx: any) {\n    const {interpolationFunctions, configFilePath} = ctx;\n    if (interpolationFunctions != \"\") {\n        console.log(chalk`{black.bgYellowBright  WARN } interpolation functions is currently not supported via gitlab-ci-local. Functions will just be a no-op.`);\n    }\n    assert(interpolationFunctions.split(\"|\").length <= MAX_FUNCTIONS, chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: too many functions in interpolation block.`);\n}\n\nfunction getInputValue (ctx: any) {\n    const {inputs, interpolationKey, configFilePath, inputsSpecification} = ctx;\n    const inputValue = inputs[interpolationKey] || inputsSpecification.spec.inputs[interpolationKey]?.default;\n    assert(inputValue !== undefined, chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: required value has not been provided.`);\n    return inputValue;\n}\n\nfunction validateInterpolationKey (ctx: any): any {\n    const {configFilePath, interpolationKey, inputsSpecification} = ctx;\n    const invalidInterpolationKeyErr = chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: unknown interpolation key: \\`${interpolationKey}\\`.`;\n    assert(inputsSpecification.spec.inputs?.[interpolationKey] !== undefined, invalidInterpolationKeyErr);\n}\n\nfunction validateInput (inputValue: any, ctx: any): any {\n    const {configFilePath, interpolationKey, inputsSpecification} = ctx;\n\n    const options = inputsSpecification.spec.inputs[interpolationKey]?.options;\n    if (options) {\n        assert(options.includes(inputValue),\n            chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: \\`{blueBright ${inputValue}}\\` cannot be used because it is not in the list of allowed options.`);\n    }\n\n    const type = inputsSpecification.spec.inputs[interpolationKey]?.type || \"string\";\n    assert(INCLUDE_INPUTS_SUPPORTED_TYPES.includes(type),\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: header:spec:inputs:{blueBright ${interpolationKey}} input type unknown value: {blueBright ${type}}.`);\n    assert(typeof inputValue == type,\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: provided value is not a {blueBright ${type}}.`);\n\n    const regex = inputsSpecification.spec.inputs[interpolationKey]?.regex;\n    if (regex) {\n        console.log(chalk`{black.bgYellowBright  WARN } spec:inputs:regex is currently not supported via gitlab-ci-local. This will just be a no-op.`);\n    }\n}\n"]}
|