gitlab-ci-local 4.65.1 → 4.66.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 +20 -19
- package/dist/index.js +340 -0
- package/dist/index.js.map +480 -0
- package/package.json +26 -80
- package/src/argv.js +0 -307
- package/src/commander.js +0 -247
- package/src/data-expander.js +0 -220
- package/src/executor.js +0 -104
- package/src/git-data.js +0 -168
- package/src/gitlab-preset.js +0 -24
- package/src/global.js +0 -40
- package/src/handler.js +0 -119
- package/src/index.js +0 -364
- package/src/job.js +0 -1463
- package/src/mutex.js +0 -20
- package/src/parallel.js +0 -46
- package/src/parser-includes.js +0 -387
- package/src/parser.js +0 -357
- package/src/predefined-variables.js +0 -67
- package/src/producers.js +0 -42
- package/src/schema/index.js +0 -19
- package/src/schema/schema.js +0 -3190
- package/src/schema-error.js +0 -114
- package/src/state.js +0 -22
- package/src/utils.js +0 -485
- package/src/validator.js +0 -151
- package/src/variables-from-files.js +0 -143
- package/src/write-streams.js +0 -51
package/src/parser.js
DELETED
|
@@ -1,357 +0,0 @@
|
|
|
1
|
-
import chalk from "chalk-template";
|
|
2
|
-
import path from "path";
|
|
3
|
-
import deepExtend from "deep-extend";
|
|
4
|
-
import fs from "fs-extra";
|
|
5
|
-
import * as yaml from "js-yaml";
|
|
6
|
-
import prettyHrtime from "pretty-hrtime";
|
|
7
|
-
import { Job } from "./job.js";
|
|
8
|
-
import * as DataExpander from "./data-expander.js";
|
|
9
|
-
import { Utils } from "./utils.js";
|
|
10
|
-
import assert from "assert";
|
|
11
|
-
import { Validator } from "./validator.js";
|
|
12
|
-
import * as parallel from "./parallel.js";
|
|
13
|
-
import { GitData } from "./git-data.js";
|
|
14
|
-
import { ParserIncludes } from "./parser-includes.js";
|
|
15
|
-
import { Producers } from "./producers.js";
|
|
16
|
-
import { VariablesFromFiles } from "./variables-from-files.js";
|
|
17
|
-
import { init as initPredefinedVariables } from "./predefined-variables.js";
|
|
18
|
-
const MAX_FUNCTIONS = 3;
|
|
19
|
-
const INCLUDE_INPUTS_SUPPORTED_TYPES = ["string", "boolean", "number", "array"];
|
|
20
|
-
export class Parser {
|
|
21
|
-
_stages = [];
|
|
22
|
-
_gitlabData;
|
|
23
|
-
_jobNamePad = null;
|
|
24
|
-
jobs;
|
|
25
|
-
argv;
|
|
26
|
-
writeStreams;
|
|
27
|
-
pipelineIid;
|
|
28
|
-
expandVariables;
|
|
29
|
-
constructor(argv, writeStreams, pipelineIid, jobs, expandVariables) {
|
|
30
|
-
this.argv = argv;
|
|
31
|
-
this.writeStreams = writeStreams;
|
|
32
|
-
this.pipelineIid = pipelineIid;
|
|
33
|
-
this.jobs = jobs;
|
|
34
|
-
this.expandVariables = expandVariables;
|
|
35
|
-
}
|
|
36
|
-
get stages() {
|
|
37
|
-
return this._stages;
|
|
38
|
-
}
|
|
39
|
-
get gitlabData() {
|
|
40
|
-
return this._gitlabData;
|
|
41
|
-
}
|
|
42
|
-
get jobNamePad() {
|
|
43
|
-
return this._jobNamePad ?? 0;
|
|
44
|
-
}
|
|
45
|
-
static async create(argv, writeStreams, pipelineIid, jobs, expandVariables = true) {
|
|
46
|
-
const parser = new Parser(argv, writeStreams, pipelineIid, jobs, expandVariables);
|
|
47
|
-
const time = process.hrtime();
|
|
48
|
-
await parser.init();
|
|
49
|
-
const warnings = await Validator.run(parser.jobs, parser.stages);
|
|
50
|
-
for (const job of parser.jobs) {
|
|
51
|
-
if (job.artifacts === null) {
|
|
52
|
-
job.deleteArtifacts();
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
const parsingTime = process.hrtime(time);
|
|
56
|
-
const pathToExpandedGitLabCi = path.join(argv.cwd, argv.stateDir, "expanded-gitlab-ci.yml");
|
|
57
|
-
fs.mkdirpSync(path.join(argv.cwd, argv.stateDir));
|
|
58
|
-
fs.writeFileSync(pathToExpandedGitLabCi, yaml.dump(parser.gitlabData));
|
|
59
|
-
if (argv.childPipelineDepth == 0)
|
|
60
|
-
writeStreams.stderr(chalk `{grey parsing and downloads finished in ${prettyHrtime(parsingTime)}.}\n`);
|
|
61
|
-
for (const warning of warnings) {
|
|
62
|
-
writeStreams.stderr(chalk `{yellow ${warning}}\n`);
|
|
63
|
-
}
|
|
64
|
-
// # Second layer of check for errors that are not caught in Validator.run
|
|
65
|
-
if (parser.argv.jsonSchemaValidation) {
|
|
66
|
-
const time = process.hrtime();
|
|
67
|
-
Validator.jsonSchemaValidation({
|
|
68
|
-
pathToExpandedGitLabCi,
|
|
69
|
-
gitLabCiConfig: parser.gitlabData,
|
|
70
|
-
argv,
|
|
71
|
-
});
|
|
72
|
-
if (argv.childPipelineDepth == 0)
|
|
73
|
-
writeStreams.stderr(chalk `{grey json schema validated in ${prettyHrtime(process.hrtime(time))}}\n`);
|
|
74
|
-
}
|
|
75
|
-
return parser;
|
|
76
|
-
}
|
|
77
|
-
async init() {
|
|
78
|
-
const argv = this.argv;
|
|
79
|
-
const cwd = argv.cwd;
|
|
80
|
-
const stateDir = argv.stateDir;
|
|
81
|
-
const writeStreams = this.writeStreams;
|
|
82
|
-
const file = argv.file;
|
|
83
|
-
const pipelineIid = this.pipelineIid;
|
|
84
|
-
const fetchIncludes = argv.fetchIncludes;
|
|
85
|
-
const gitData = await GitData.init(cwd, writeStreams);
|
|
86
|
-
const variablesFromFiles = await VariablesFromFiles.init(argv, writeStreams, gitData);
|
|
87
|
-
const envMatchedVariables = Utils.findEnvMatchedVariables(variablesFromFiles);
|
|
88
|
-
const predefinedVariables = initPredefinedVariables({ gitData, argv, envMatchedVariables });
|
|
89
|
-
const variables = { ...predefinedVariables, ...envMatchedVariables, ...argv.variable };
|
|
90
|
-
const expanded = Utils.expandVariables(variables);
|
|
91
|
-
let yamlDataList = [{ stages: [".pre", "build", "test", "deploy", ".post"] }];
|
|
92
|
-
const gitlabCiData = await Parser.loadYaml(`${cwd}/${file}`, {}, this.expandVariables);
|
|
93
|
-
yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiData, { argv, cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables, maximumIncludes: argv.maximumIncludes }));
|
|
94
|
-
ParserIncludes.resetCount();
|
|
95
|
-
const gitlabCiLocalData = await Parser.loadYaml(`${cwd}/.gitlab-ci-local.yml`, {}, this.expandVariables);
|
|
96
|
-
yamlDataList = yamlDataList.concat(await ParserIncludes.init(gitlabCiLocalData, { argv, cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables, maximumIncludes: argv.maximumIncludes }));
|
|
97
|
-
ParserIncludes.resetCount();
|
|
98
|
-
const gitlabData = deepExtend({}, ...yamlDataList);
|
|
99
|
-
// Expand various fields in gitlabData
|
|
100
|
-
DataExpander.jobExtends(gitlabData);
|
|
101
|
-
DataExpander.reference(gitlabData, gitlabData);
|
|
102
|
-
DataExpander.flattenLists(gitlabData);
|
|
103
|
-
DataExpander.transformDeprecatedGlobalDefaultSyntax(gitlabData);
|
|
104
|
-
DataExpander.inheritDefault(gitlabData);
|
|
105
|
-
DataExpander.normalize(gitlabData);
|
|
106
|
-
assert(gitlabData.stages && Array.isArray(gitlabData.stages), chalk `{yellow stages:} must be an array`);
|
|
107
|
-
if (!gitlabData.stages.includes(".pre")) {
|
|
108
|
-
gitlabData.stages.unshift(".pre");
|
|
109
|
-
}
|
|
110
|
-
if (!gitlabData.stages.includes(".post")) {
|
|
111
|
-
gitlabData.stages.push(".post");
|
|
112
|
-
}
|
|
113
|
-
this._stages = gitlabData.stages;
|
|
114
|
-
// Check job variables for invalid hash of key value pairs, and cast numbers to strings
|
|
115
|
-
Utils.forEachRealJob(gitlabData, (jobName, jobData) => {
|
|
116
|
-
assert(jobData.when !== "never", chalk `This GitLab CI configuration is invalid: jobs:${jobName} when:never can only be used in a rules section or workflow:rules`);
|
|
117
|
-
for (const [key, value] of Object.entries(jobData.variables ?? {})) {
|
|
118
|
-
jobData.variables[key] = Utils.normalizeVariables(value);
|
|
119
|
-
}
|
|
120
|
-
for (let i = 0; i < (jobData.services ?? []).length; i++) {
|
|
121
|
-
const service = jobData.services[i];
|
|
122
|
-
for (const [key, value] of Object.entries(service.variables || {})) {
|
|
123
|
-
assert(typeof value === "string" || typeof value === "number" || typeof value === "boolean", chalk `{blueBright ${jobName}.services[${i}]} has invalid variables hash of key value pairs. ${key}=${value}`);
|
|
124
|
-
jobData.services[i].variables[key] = String(value);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
this._gitlabData = gitlabData;
|
|
129
|
-
// Generate jobs and put them into stages
|
|
130
|
-
Utils.forEachRealJob(gitlabData, (jobName, jobData) => {
|
|
131
|
-
assert(gitData != null, "gitData must be set");
|
|
132
|
-
assert(variablesFromFiles != null, "homeVariables must be set");
|
|
133
|
-
let nodeIndex = 1;
|
|
134
|
-
const parallelMatrixVariablesList = parallel.matrixVariablesList(jobData, jobName);
|
|
135
|
-
for (const parallelMatrixVariables of parallelMatrixVariablesList) {
|
|
136
|
-
let matrixJobName = jobName;
|
|
137
|
-
if (parallelMatrixVariables) {
|
|
138
|
-
matrixJobName = `${jobName}: [${Object.values(parallelMatrixVariables ?? []).join(",")}]`;
|
|
139
|
-
}
|
|
140
|
-
else if (parallel.isPlainParallel(jobData)) {
|
|
141
|
-
matrixJobName = `${jobName}: [${nodeIndex}/${parallelMatrixVariablesList.length}]`;
|
|
142
|
-
}
|
|
143
|
-
const job = new Job({
|
|
144
|
-
argv,
|
|
145
|
-
writeStreams,
|
|
146
|
-
data: jobData,
|
|
147
|
-
name: matrixJobName,
|
|
148
|
-
baseName: jobName,
|
|
149
|
-
globalVariables: gitlabData.variables,
|
|
150
|
-
pipelineIid: pipelineIid,
|
|
151
|
-
predefinedVariables: { ...predefinedVariables }, // NOTE: pass by value because predefinedVariables is mutated in the constructor
|
|
152
|
-
gitData,
|
|
153
|
-
variablesFromFiles,
|
|
154
|
-
matrixVariables: parallelMatrixVariables,
|
|
155
|
-
nodeIndex: (jobData.parallel != null) ? nodeIndex : null,
|
|
156
|
-
nodesTotal: parallelMatrixVariablesList.length,
|
|
157
|
-
expandVariables: this.expandVariables,
|
|
158
|
-
});
|
|
159
|
-
const foundStage = this.stages.includes(job.stage);
|
|
160
|
-
assert(foundStage, chalk `{yellow stage:${job.stage}} not found for {blueBright ${job.name}}`);
|
|
161
|
-
this.jobs.push(job);
|
|
162
|
-
nodeIndex++;
|
|
163
|
-
}
|
|
164
|
-
});
|
|
165
|
-
// Add some padding so that job logs are nicely aligned
|
|
166
|
-
// allow users to override this in case they have really long job name (see #840)
|
|
167
|
-
if (this.argv.maxJobNamePadding !== null && this.argv.maxJobNamePadding <= 0) {
|
|
168
|
-
this._jobNamePad = 0;
|
|
169
|
-
}
|
|
170
|
-
else {
|
|
171
|
-
const jobs = this.argv.job.length !== 0 ? this.argv.job : this.jobs;
|
|
172
|
-
jobs.forEach((job) => {
|
|
173
|
-
let jobNeedsLength = [];
|
|
174
|
-
if (this.argv.needs && this.argv.job.length > 0) {
|
|
175
|
-
const found = this.jobs.find(j => j.baseName === job);
|
|
176
|
-
if (found?.needs) {
|
|
177
|
-
jobNeedsLength = found.needs.map(f => f.job.length);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
const jobLength = typeof job == "string" ? job.length : job.name.length;
|
|
181
|
-
this._jobNamePad = Math.max(jobLength, this._jobNamePad ?? 0, ...jobNeedsLength);
|
|
182
|
-
});
|
|
183
|
-
if (this.argv.maxJobNamePadding !== null) {
|
|
184
|
-
this._jobNamePad = Math.min(this.argv.maxJobNamePadding ?? 0, this._jobNamePad ?? 0);
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
// Set jobNamePad on all jobs
|
|
188
|
-
this.jobs.forEach((job) => {
|
|
189
|
-
job.jobNamePad = this.jobNamePad;
|
|
190
|
-
});
|
|
191
|
-
// Generate producers for each job
|
|
192
|
-
this.jobs.forEach((job) => {
|
|
193
|
-
job.producers = Producers.init(this.jobs, this.stages, job);
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
static async loadYaml(filePath, ctx = {}, expandVariables = true) {
|
|
197
|
-
const ymlPath = `${filePath}`;
|
|
198
|
-
if (!fs.existsSync(ymlPath)) {
|
|
199
|
-
return {};
|
|
200
|
-
}
|
|
201
|
-
const fileContent = await fs.readFile(`${filePath}`, "utf8");
|
|
202
|
-
const fileSplit = fileContent.split(/\r?\n/g);
|
|
203
|
-
const fileSplitClone = fileSplit.slice();
|
|
204
|
-
let interactiveMatch = null;
|
|
205
|
-
let descriptionMatch = null;
|
|
206
|
-
let injectSSHAgent = null;
|
|
207
|
-
let noArtifactsToSourceMatch = null;
|
|
208
|
-
let index = 0;
|
|
209
|
-
if (expandVariables) {
|
|
210
|
-
for (const line of fileSplit) {
|
|
211
|
-
interactiveMatch = interactiveMatch ?? /#\s?@\s?[Ii]nteractive/.exec(line);
|
|
212
|
-
injectSSHAgent = injectSSHAgent ?? /#\s?@\s?[Ii]njectSSHAgent/.exec(line);
|
|
213
|
-
noArtifactsToSourceMatch = noArtifactsToSourceMatch ?? /#\s?@\s?NoArtifactsToSource/i.exec(line);
|
|
214
|
-
descriptionMatch = descriptionMatch ?? /#\s?@\s?[Dd]escription (?<description>.*)/.exec(line);
|
|
215
|
-
const jobMatch = /\w:/.exec(line);
|
|
216
|
-
if (jobMatch && (interactiveMatch || descriptionMatch || injectSSHAgent || noArtifactsToSourceMatch)) {
|
|
217
|
-
if (interactiveMatch) {
|
|
218
|
-
fileSplitClone.splice(index + 1, 0, " gclInteractive: true");
|
|
219
|
-
index++;
|
|
220
|
-
}
|
|
221
|
-
if (injectSSHAgent) {
|
|
222
|
-
fileSplitClone.splice(index + 1, 0, " gclInjectSSHAgent: true");
|
|
223
|
-
index++;
|
|
224
|
-
}
|
|
225
|
-
if (noArtifactsToSourceMatch) {
|
|
226
|
-
fileSplitClone.splice(index + 1, 0, " gclArtifactsToSource: false");
|
|
227
|
-
index++;
|
|
228
|
-
}
|
|
229
|
-
if (descriptionMatch) {
|
|
230
|
-
fileSplitClone.splice(index + 1, 0, ` gclDescription: ${descriptionMatch?.groups?.description ?? ""}`);
|
|
231
|
-
index++;
|
|
232
|
-
}
|
|
233
|
-
interactiveMatch = null;
|
|
234
|
-
descriptionMatch = null;
|
|
235
|
-
injectSSHAgent = null;
|
|
236
|
-
noArtifactsToSourceMatch = null;
|
|
237
|
-
}
|
|
238
|
-
index++;
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
const referenceType = new yaml.Type("!reference", {
|
|
242
|
-
kind: "sequence",
|
|
243
|
-
construct: function (data) {
|
|
244
|
-
return { referenceData: data };
|
|
245
|
-
},
|
|
246
|
-
});
|
|
247
|
-
const schema = yaml.DEFAULT_SCHEMA.extend([referenceType]);
|
|
248
|
-
let fileData;
|
|
249
|
-
try {
|
|
250
|
-
fileData = yaml.loadAll(fileSplitClone.join("\n"), null, { schema });
|
|
251
|
-
}
|
|
252
|
-
catch (e) {
|
|
253
|
-
if (e instanceof yaml.YAMLException && e.reason === "duplicated mapping key") {
|
|
254
|
-
console.log(chalk `{black.bgYellowBright WARN } duplicated mapping key detected! Values will be overwritten!`);
|
|
255
|
-
fileData = yaml.loadAll(fileSplitClone.join("\n"), null, { schema, json: true });
|
|
256
|
-
}
|
|
257
|
-
else {
|
|
258
|
-
throw e;
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
if (fileData.length <= 1)
|
|
262
|
-
return fileData[0];
|
|
263
|
-
if (isGitlabSpecFile(fileData[0])) {
|
|
264
|
-
const inputsSpecification = fileData[0];
|
|
265
|
-
const uninterpolatedConfigurations = fileData[1];
|
|
266
|
-
const interpolatedConfigurations = JSON.stringify(uninterpolatedConfigurations)
|
|
267
|
-
.replace(/(?<firstChar>.)?(?<secondChar>.)?\$\[\[\s*inputs.(?<interpolationKey>[\w-]+)\s*\|?\s*(?<interpolationFunctions>.*?)\s*\]\](?<lastChar>[^$])?/g // https://regexr.com/81c16
|
|
268
|
-
, (_, firstChar, secondChar, interpolationKey, interpolationFunctions, lastChar) => {
|
|
269
|
-
const configFilePath = path.relative(process.cwd(), filePath);
|
|
270
|
-
const context = {
|
|
271
|
-
interpolationKey,
|
|
272
|
-
interpolationFunctions,
|
|
273
|
-
inputsSpecification,
|
|
274
|
-
configFilePath,
|
|
275
|
-
...ctx,
|
|
276
|
-
};
|
|
277
|
-
firstChar ??= "";
|
|
278
|
-
secondChar ??= "";
|
|
279
|
-
lastChar ??= "";
|
|
280
|
-
const { inputValue, inputType } = parseIncludeInputs(context);
|
|
281
|
-
const firstTwoChar = firstChar + secondChar;
|
|
282
|
-
switch (inputType) {
|
|
283
|
-
case "array":
|
|
284
|
-
if ((secondChar == "\"" && lastChar == "\"") && firstChar != "\\") {
|
|
285
|
-
return firstChar + JSON.stringify(inputValue);
|
|
286
|
-
}
|
|
287
|
-
// NOTE: This behaves slightly differently from gitlab.com. I can't come up with practical use case so i don't think it's worth the effort to mimic this
|
|
288
|
-
return firstTwoChar + JSON.stringify(JSON.stringify(inputValue)).slice(1, -1) + lastChar;
|
|
289
|
-
case "string":
|
|
290
|
-
return firstTwoChar +
|
|
291
|
-
JSON.stringify(inputValue) // ensure a valid json string
|
|
292
|
-
.slice(1, -1) + // remove the surrounding "
|
|
293
|
-
lastChar;
|
|
294
|
-
case "number":
|
|
295
|
-
case "boolean":
|
|
296
|
-
if ((secondChar == "\"" && lastChar == "\"") && firstChar != "\\") {
|
|
297
|
-
return firstChar + inputValue;
|
|
298
|
-
}
|
|
299
|
-
return firstTwoChar + inputValue + lastChar;
|
|
300
|
-
default:
|
|
301
|
-
Utils.switchStatementExhaustiveCheck(inputType);
|
|
302
|
-
}
|
|
303
|
-
});
|
|
304
|
-
return JSON.parse(interpolatedConfigurations);
|
|
305
|
-
}
|
|
306
|
-
return fileData[0];
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
function isGitlabSpecFile(fileData) {
|
|
310
|
-
return "spec" in fileData;
|
|
311
|
-
}
|
|
312
|
-
function validateInterpolationKey(ctx) {
|
|
313
|
-
const { configFilePath, interpolationKey, inputsSpecification } = ctx;
|
|
314
|
-
const invalidInterpolationKeyErr = chalk `This GitLab CI configuration is invalid: \`{blueBright ${configFilePath}}\`: unknown interpolation key: \`${interpolationKey}\`.`;
|
|
315
|
-
assert(inputsSpecification.spec.inputs?.[interpolationKey] !== undefined, invalidInterpolationKeyErr);
|
|
316
|
-
}
|
|
317
|
-
function validateInterpolationFunctions(ctx) {
|
|
318
|
-
const { interpolationFunctions, configFilePath } = ctx;
|
|
319
|
-
if (interpolationFunctions != "") {
|
|
320
|
-
console.log(chalk `{black.bgYellowBright WARN } interpolation functions is currently not supported via gitlab-ci-local. Functions will just be a no-op.`);
|
|
321
|
-
}
|
|
322
|
-
assert(interpolationFunctions.split("|").length <= MAX_FUNCTIONS, chalk `This GitLab CI configuration is invalid: \`{blueBright ${configFilePath}}\`: too many functions in interpolation block.`);
|
|
323
|
-
}
|
|
324
|
-
function validateInput(ctx) {
|
|
325
|
-
const { configFilePath, interpolationKey, inputsSpecification } = ctx;
|
|
326
|
-
const inputValue = getInputValue(ctx);
|
|
327
|
-
const options = inputsSpecification.spec.inputs[interpolationKey]?.options;
|
|
328
|
-
if (options) {
|
|
329
|
-
assert(options.includes(inputValue), 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.`);
|
|
330
|
-
}
|
|
331
|
-
const expectedInputType = getExpectedInputType(ctx);
|
|
332
|
-
assert(INCLUDE_INPUTS_SUPPORTED_TYPES.includes(expectedInputType), chalk `This GitLab CI configuration is invalid: \`{blueBright ${configFilePath}}\`: header:spec:inputs:{blueBright ${interpolationKey}} input type unknown value: {blueBright ${expectedInputType}}.`);
|
|
333
|
-
const inputType = Array.isArray(inputValue) ? "array" : typeof inputValue;
|
|
334
|
-
assert(inputType === expectedInputType, chalk `This GitLab CI configuration is invalid: \`{blueBright ${configFilePath}}\`: \`{blueBright ${interpolationKey}}\` input: provided value is not a {blueBright ${expectedInputType}}.`);
|
|
335
|
-
const regex = inputsSpecification.spec.inputs[interpolationKey]?.regex;
|
|
336
|
-
if (regex) {
|
|
337
|
-
console.log(chalk `{black.bgYellowBright WARN } spec:inputs:regex is currently not supported via gitlab-ci-local. This will just be a no-op.`);
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
function parseIncludeInputs(ctx) {
|
|
341
|
-
validateInterpolationKey(ctx);
|
|
342
|
-
validateInterpolationFunctions(ctx);
|
|
343
|
-
validateInput(ctx);
|
|
344
|
-
return { inputValue: getInputValue(ctx), inputType: getExpectedInputType(ctx) };
|
|
345
|
-
}
|
|
346
|
-
function getInputValue(ctx) {
|
|
347
|
-
const { inputs, interpolationKey, configFilePath, inputsSpecification } = ctx;
|
|
348
|
-
const inputValue = inputs?.[interpolationKey] ??
|
|
349
|
-
inputsSpecification.spec.inputs[interpolationKey]?.default;
|
|
350
|
-
assert(inputValue !== undefined, chalk `This GitLab CI configuration is invalid: \`{blueBright ${configFilePath}}\`: \`{blueBright ${interpolationKey}}\` input: required value has not been provided.`);
|
|
351
|
-
return inputValue;
|
|
352
|
-
}
|
|
353
|
-
function getExpectedInputType(ctx) {
|
|
354
|
-
const { interpolationKey, inputsSpecification } = ctx;
|
|
355
|
-
return inputsSpecification.spec.inputs[interpolationKey]?.type || "string";
|
|
356
|
-
}
|
|
357
|
-
//# 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-template\";\nimport path from \"path\";\nimport deepExtend from \"deep-extend\";\nimport fs from \"fs-extra\";\nimport * as yaml from \"js-yaml\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {Job} from \"./job.js\";\nimport * as DataExpander from \"./data-expander.js\";\nimport {Utils} from \"./utils.js\";\nimport assert from \"assert\";\nimport {Validator} from \"./validator.js\";\nimport * as parallel from \"./parallel.js\";\nimport {GitData} from \"./git-data.js\";\nimport {ParserIncludes} from \"./parser-includes.js\";\nimport {Producers} from \"./producers.js\";\nimport {VariablesFromFiles} from \"./variables-from-files.js\";\nimport {Argv} from \"./argv.js\";\nimport {WriteStreams} from \"./write-streams.js\";\nimport {init as initPredefinedVariables} from \"./predefined-variables.js\";\n\nconst MAX_FUNCTIONS = 3;\nconst INCLUDE_INPUTS_SUPPORTED_TYPES = [\"string\", \"boolean\", \"number\", \"array\"] as const;\nexport type InputType = typeof INCLUDE_INPUTS_SUPPORTED_TYPES[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\n        for (const job of parser.jobs) {\n            if (job.artifacts === null) {\n                job.deleteArtifacts();\n            }\n        }\n\n        const parsingTime = process.hrtime(time);\n        const pathToExpandedGitLabCi = path.join(argv.cwd, argv.stateDir, \"expanded-gitlab-ci.yml\");\n        fs.mkdirpSync(path.join(argv.cwd, argv.stateDir));\n        fs.writeFileSync(pathToExpandedGitLabCi, yaml.dump(parser.gitlabData));\n        if (argv.childPipelineDepth == 0) writeStreams.stderr(chalk`{grey parsing and downloads finished in ${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({\n                pathToExpandedGitLabCi,\n                gitLabCiConfig: parser.gitlabData,\n                argv,\n            });\n            if (argv.childPipelineDepth == 0) writeStreams.stderr(chalk`{grey json schema validated in ${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 envMatchedVariables = Utils.findEnvMatchedVariables(variablesFromFiles);\n        const predefinedVariables = initPredefinedVariables({gitData, argv, envMatchedVariables});\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, {argv, cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables, maximumIncludes: argv.maximumIncludes}));\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, {argv, cwd, stateDir, writeStreams, gitData, fetchIncludes, variables: expanded, expandVariables: this.expandVariables, maximumIncludes: argv.maximumIncludes}));\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.flattenLists(gitlabData);\n        DataExpander.transformDeprecatedGlobalDefaultSyntax(gitlabData);\n        DataExpander.inheritDefault(gitlabData);\n        DataExpander.normalize(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            assert(jobData.when !== \"never\",\n                chalk`This GitLab CI configuration is invalid: jobs:${jobName} when:never can only be used in a rules section or workflow:rules`,\n            );\n            for (const [key, value] of Object.entries(jobData.variables ?? {})) {\n                jobData.variables[key] = Utils.normalizeVariables(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\" || typeof value === \"boolean\",\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: {...predefinedVariables}, // NOTE: pass by value because predefinedVariables is mutated in the constructor\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?.needs) {\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);\n                injectSSHAgent = injectSSHAgent ?? /#\\s?@\\s?[Ii]njectSSHAgent/.exec(line);\n                noArtifactsToSourceMatch = noArtifactsToSourceMatch ?? /#\\s?@\\s?NoArtifactsToSource/i.exec(line);\n                descriptionMatch = descriptionMatch ?? /#\\s?@\\s?[Dd]escription (?<description>.*)/.exec(line);\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                    /(?<firstChar>.)?(?<secondChar>.)?\\$\\[\\[\\s*inputs.(?<interpolationKey>[\\w-]+)\\s*\\|?\\s*(?<interpolationFunctions>.*?)\\s*\\]\\](?<lastChar>[^$])?/g // https://regexr.com/81c16\n                    , (_: string, firstChar: string, secondChar: string, interpolationKey: string, interpolationFunctions: string, lastChar: string) => {\n                        const configFilePath = path.relative(process.cwd(), filePath);\n                        const context = {\n                            interpolationKey,\n                            interpolationFunctions,\n                            inputsSpecification,\n                            configFilePath,\n                            ...ctx,\n                        };\n                        firstChar ??= \"\";\n                        secondChar ??= \"\";\n                        lastChar ??= \"\";\n\n                        const {inputValue, inputType} = parseIncludeInputs(context);\n                        const firstTwoChar = firstChar + secondChar;\n                        switch (inputType) {\n                            case \"array\":\n                                if ((secondChar == \"\\\"\" && lastChar == \"\\\"\") && firstChar != \"\\\\\") {\n                                    return firstChar + JSON.stringify(inputValue);\n                                }\n\n                                // NOTE: This behaves slightly differently from gitlab.com. I can't come up with practical use case so i don't think it's worth the effort to mimic this\n                                return firstTwoChar + JSON.stringify(JSON.stringify(inputValue)).slice(1, -1) + lastChar;\n                            case \"string\":\n                                return firstTwoChar +\n                                    JSON.stringify(inputValue) // ensure a valid json string\n                                        .slice(1, -1) + // remove the surrounding \"\n                                    lastChar;\n\n                            case \"number\":\n                            case \"boolean\":\n                                if ((secondChar == \"\\\"\" && lastChar == \"\\\"\") && firstChar != \"\\\\\") {\n                                    return firstChar + inputValue;\n                                }\n                                return firstTwoChar + inputValue + lastChar;\n\n                            default:\n                                Utils.switchStatementExhaustiveCheck(inputType);\n                        }\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 validateInterpolationKey (ctx: 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 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 validateInput (ctx: any) {\n    const {configFilePath, interpolationKey, inputsSpecification} = ctx;\n    const inputValue = getInputValue(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 expectedInputType = getExpectedInputType(ctx);\n    assert(INCLUDE_INPUTS_SUPPORTED_TYPES.includes(expectedInputType),\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: header:spec:inputs:{blueBright ${interpolationKey}} input type unknown value: {blueBright ${expectedInputType}}.`);\n\n    const inputType = Array.isArray(inputValue) ? \"array\" : typeof inputValue;\n    assert(inputType === expectedInputType,\n        chalk`This GitLab CI configuration is invalid: \\`{blueBright ${configFilePath}}\\`: \\`{blueBright ${interpolationKey}}\\` input: provided value is not a {blueBright ${expectedInputType}}.`);\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\nfunction parseIncludeInputs (ctx: any): {inputValue: any; inputType: InputType} {\n    validateInterpolationKey(ctx);\n    validateInterpolationFunctions(ctx);\n    validateInput(ctx);\n    return {inputValue: getInputValue(ctx), inputType: getExpectedInputType(ctx)};\n}\n\nfunction getInputValue (ctx: any) {\n    const {inputs, interpolationKey, configFilePath, inputsSpecification} = ctx;\n    const inputValue = inputs?.[interpolationKey] ??\n        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 getExpectedInputType (ctx: any): InputType {\n    const {interpolationKey, inputsSpecification} = ctx;\n    return inputsSpecification.spec.inputs[interpolationKey]?.type || \"string\";\n}\n"]}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
import camelCase from "camelcase";
|
|
2
|
-
export function init({ gitData, argv, envMatchedVariables }) {
|
|
3
|
-
const _variables = { ...envMatchedVariables, ...argv.variable };
|
|
4
|
-
// precedence:
|
|
5
|
-
// 1. cli option
|
|
6
|
-
// 2. gitlab variables files
|
|
7
|
-
// 3. values derieved implicitly from `git remote -v`
|
|
8
|
-
// 4. default value
|
|
9
|
-
const CI_SERVER_PROTOCOL = _variables["CI_SERVER_PROTOCOL"] ?? ((gitData.remote.schema === "http" || gitData.remote.schema === "https") ? gitData.remote.schema : "https");
|
|
10
|
-
const CI_SERVER_PORT = _variables["CI_SERVER_PORT"] ?? ((gitData.remote.schema === "http" || gitData.remote.schema === "https") ? gitData.remote.port : "443");
|
|
11
|
-
const CI_SERVER_SHELL_SSH_PORT = _variables["CI_SERVER_SHELL_SSH_PORT"] ?? ((gitData.remote.schema === "ssh") ? gitData.remote.port : "22");
|
|
12
|
-
const CI_SERVER_HOST = _variables["CI_SERVER_HOST"] ?? `${gitData.remote.host}`;
|
|
13
|
-
const CI_SERVER_FQDN = _variables["CI_SERVER_FQDN"] ?? (CI_SERVER_PORT == "443" ? gitData.remote.host : `${gitData.remote.host}:${CI_SERVER_PORT}`);
|
|
14
|
-
const CI_SERVER_URL = _variables["CI_SERVER_URL"] ?? `${CI_SERVER_PROTOCOL}://${CI_SERVER_FQDN}`;
|
|
15
|
-
const CI_PROJECT_ROOT_NAMESPACE = gitData.remote.group.split("/")[0];
|
|
16
|
-
const CI_PROJECT_NAMESPACE = gitData.remote.group;
|
|
17
|
-
const CI_DEPENDENCY_PROXY_SERVER = CI_SERVER_FQDN.includes(":") ? CI_SERVER_FQDN : `${CI_SERVER_HOST}:${CI_SERVER_PORT}`;
|
|
18
|
-
const predefinedVariables = {
|
|
19
|
-
CI: "true",
|
|
20
|
-
GITLAB_USER_LOGIN: gitData.user["GITLAB_USER_LOGIN"],
|
|
21
|
-
GITLAB_USER_EMAIL: gitData.user["GITLAB_USER_EMAIL"],
|
|
22
|
-
GITLAB_USER_NAME: gitData.user["GITLAB_USER_NAME"],
|
|
23
|
-
GITLAB_USER_ID: gitData.user["GITLAB_USER_ID"],
|
|
24
|
-
CI_COMMIT_SHORT_SHA: gitData.commit.SHA.slice(0, 8), // Changes
|
|
25
|
-
CI_COMMIT_SHA: gitData.commit.SHA,
|
|
26
|
-
CI_PROJECT_NAME: gitData.remote.project,
|
|
27
|
-
CI_PROJECT_TITLE: `${camelCase(gitData.remote.project)}`,
|
|
28
|
-
CI_PROJECT_PATH: `${gitData.remote.group}/${gitData.remote.project}`,
|
|
29
|
-
CI_PROJECT_PATH_SLUG: `${gitData.remote.group.replace(/\//g, "-")}-${gitData.remote.project}`.toLowerCase(),
|
|
30
|
-
CI_PROJECT_ROOT_NAMESPACE: CI_PROJECT_ROOT_NAMESPACE,
|
|
31
|
-
CI_PROJECT_NAMESPACE: CI_PROJECT_NAMESPACE,
|
|
32
|
-
CI_PROJECT_VISIBILITY: "internal",
|
|
33
|
-
CI_PROJECT_ID: "1217",
|
|
34
|
-
CI_COMMIT_REF_PROTECTED: "false",
|
|
35
|
-
CI_COMMIT_BRANCH: gitData.commit.REF_NAME, // Not available in merge request or tag pipelines
|
|
36
|
-
CI_COMMIT_REF_NAME: gitData.commit.REF_NAME, // Tag or branch name
|
|
37
|
-
CI_COMMIT_REF_SLUG: gitData.commit.REF_NAME.replace(/[^a-z\d]+/ig, "-").replace(/^-/, "").slice(0, 63).replace(/-$/, "").toLowerCase(),
|
|
38
|
-
CI_COMMIT_TIMESTAMP: gitData.commit.TIMESTAMP,
|
|
39
|
-
CI_PIPELINE_CREATED_AT: new Date().toISOString().split(".")[0] + "Z",
|
|
40
|
-
CI_COMMIT_TITLE: "Commit Title", // First line of commit message.
|
|
41
|
-
CI_COMMIT_MESSAGE: "Commit Title\nMore commit text", // Full commit message
|
|
42
|
-
CI_COMMIT_DESCRIPTION: "More commit text",
|
|
43
|
-
CI_DEFAULT_BRANCH: gitData.branches.default,
|
|
44
|
-
CI_PIPELINE_SOURCE: "push",
|
|
45
|
-
CI_SERVER_FQDN: CI_SERVER_FQDN,
|
|
46
|
-
CI_SERVER_HOST: CI_SERVER_HOST,
|
|
47
|
-
CI_SERVER_PORT: CI_SERVER_PORT,
|
|
48
|
-
CI_SERVER_SHELL_SSH_PORT: CI_SERVER_SHELL_SSH_PORT,
|
|
49
|
-
CI_SERVER_URL: CI_SERVER_URL,
|
|
50
|
-
CI_SERVER_PROTOCOL: CI_SERVER_PROTOCOL,
|
|
51
|
-
CI_API_V4_URL: `${CI_SERVER_URL}/api/v4`,
|
|
52
|
-
CI_PROJECT_URL: `${CI_SERVER_URL}/${gitData.remote.group}/${gitData.remote.project}`,
|
|
53
|
-
CI_TEMPLATE_REGISTRY_HOST: "registry.gitlab.com",
|
|
54
|
-
GITLAB_CI: "false",
|
|
55
|
-
FF_DISABLE_UMASK_FOR_DOCKER_EXECUTOR: argv.umask ? "false" : "true",
|
|
56
|
-
CI_DEPENDENCY_PROXY_DIRECT_GROUP_IMAGE_PREFIX: `${CI_DEPENDENCY_PROXY_SERVER}/${CI_PROJECT_NAMESPACE}/dependency_proxy/containers`,
|
|
57
|
-
CI_DEPENDENCY_PROXY_GROUP_IMAGE_PREFIX: `${CI_DEPENDENCY_PROXY_SERVER}/${CI_PROJECT_ROOT_NAMESPACE}/dependency_proxy/containers`,
|
|
58
|
-
CI_DEPENDENCY_PROXY_SERVER: CI_DEPENDENCY_PROXY_SERVER,
|
|
59
|
-
CI_DEPENDENCY_PROXY_USER: "gitlab-ci-token",
|
|
60
|
-
};
|
|
61
|
-
// Delete variables the user intentionally wants unset
|
|
62
|
-
for (const unsetVariable of argv.unsetVariables) {
|
|
63
|
-
delete predefinedVariables[unsetVariable];
|
|
64
|
-
}
|
|
65
|
-
return predefinedVariables;
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"predefined-variables.js","sourceRoot":"","sources":["predefined-variables.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,WAAW,CAAC;AAUlC,MAAM,UAAU,IAAI,CAAE,EAAC,OAAO,EAAE,IAAI,EAAE,mBAAmB,EAA0B;IAE/E,MAAM,UAAU,GAAG,EAAC,GAAG,mBAAmB,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAC,CAAC;IAE9D,cAAc;IACd,gBAAgB;IAChB,4BAA4B;IAC5B,qDAAqD;IACrD,mBAAmB;IACnB,MAAM,kBAAkB,GAAG,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC3K,MAAM,cAAc,GAAG,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/J,MAAM,wBAAwB,GAAG,UAAU,CAAC,0BAA0B,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAC5I,MAAM,cAAc,GAAG,UAAU,CAAC,gBAAgB,CAAC,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAChF,MAAM,cAAc,GAAG,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,cAAc,EAAE,CAAC,CAAC;IACpJ,MAAM,aAAa,GAAG,UAAU,CAAC,eAAe,CAAC,IAAI,GAAG,kBAAkB,MAAM,cAAc,EAAE,CAAC;IACjG,MAAM,yBAAyB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACrE,MAAM,oBAAoB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAClD,MAAM,0BAA0B,GAAG,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,cAAc,IAAI,cAAc,EAAE,CAAC;IAEzH,MAAM,mBAAmB,GAA4B;QACjD,EAAE,EAAE,MAAM;QACV,iBAAiB,EAAE,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACpD,iBAAiB,EAAE,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACpD,gBAAgB,EAAE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC;QAClD,cAAc,EAAE,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC;QAC9C,mBAAmB,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,UAAU;QAC/D,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG;QACjC,eAAe,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO;QACvC,gBAAgB,EAAE,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;QACxD,eAAe,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE;QACpE,oBAAoB,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,WAAW,EAAE;QAC3G,yBAAyB,EAAE,yBAAyB;QACpD,oBAAoB,EAAE,oBAAoB;QAC1C,qBAAqB,EAAE,UAAU;QACjC,aAAa,EAAE,MAAM;QACrB,uBAAuB,EAAE,OAAO;QAChC,gBAAgB,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,kDAAkD;QAC7F,kBAAkB,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,qBAAqB;QAClE,kBAAkB,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE;QACtI,mBAAmB,EAAE,OAAO,CAAC,MAAM,CAAC,SAAS;QAC7C,sBAAsB,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG;QACpE,eAAe,EAAE,cAAc,EAAE,gCAAgC;QACjE,iBAAiB,EAAE,gCAAgC,EAAE,sBAAsB;QAC3E,qBAAqB,EAAE,kBAAkB;QACzC,iBAAiB,EAAE,OAAO,CAAC,QAAQ,CAAC,OAAO;QAC3C,kBAAkB,EAAE,MAAM;QAC1B,cAAc,EAAE,cAAc;QAC9B,cAAc,EAAE,cAAc;QAC9B,cAAc,EAAE,cAAc;QAC9B,wBAAwB,EAAE,wBAAwB;QAClD,aAAa,EAAE,aAAa;QAC5B,kBAAkB,EAAE,kBAAkB;QACtC,aAAa,EAAE,GAAG,aAAa,SAAS;QACxC,cAAc,EAAE,GAAG,aAAa,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE;QACpF,yBAAyB,EAAE,qBAAqB;QAChD,SAAS,EAAE,OAAO;QAClB,oCAAoC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QAEnE,6CAA6C,EAAE,GAAG,0BAA0B,IAAI,oBAAoB,8BAA8B;QAClI,sCAAsC,EAAE,GAAG,0BAA0B,IAAI,yBAAyB,8BAA8B;QAChI,0BAA0B,EAAE,0BAA0B;QACtD,wBAAwB,EAAE,iBAAiB;KAC9C,CAAC;IAEF,sDAAsD;IACtD,KAAK,MAAM,aAAa,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;QAC9C,OAAO,mBAAmB,CAAC,aAAa,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,mBAAmB,CAAC;AAC/B,CAAC","sourcesContent":["import camelCase from \"camelcase\";\nimport {GitData} from \"./git-data.js\";\nimport {Argv} from \"./argv.js\";\n\ntype PredefinedVariablesOpts = {\n    gitData: GitData;\n    argv: Argv;\n    envMatchedVariables: {[key: string]: string};\n};\n\nexport function init ({gitData, argv, envMatchedVariables}: PredefinedVariablesOpts): {[name: string]: string} {\n\n    const _variables = {...envMatchedVariables, ...argv.variable};\n\n    // precedence:\n    // 1. cli option\n    // 2. gitlab variables files\n    // 3. values derieved implicitly from `git remote -v`\n    // 4. default value\n    const CI_SERVER_PROTOCOL = _variables[\"CI_SERVER_PROTOCOL\"] ?? ((gitData.remote.schema === \"http\" || gitData.remote.schema === \"https\") ? gitData.remote.schema : \"https\");\n    const CI_SERVER_PORT = _variables[\"CI_SERVER_PORT\"] ?? ((gitData.remote.schema === \"http\" || gitData.remote.schema === \"https\") ? gitData.remote.port : \"443\");\n    const CI_SERVER_SHELL_SSH_PORT = _variables[\"CI_SERVER_SHELL_SSH_PORT\"] ?? ((gitData.remote.schema === \"ssh\") ? gitData.remote.port : \"22\");\n    const CI_SERVER_HOST = _variables[\"CI_SERVER_HOST\"] ?? `${gitData.remote.host}`;\n    const CI_SERVER_FQDN = _variables[\"CI_SERVER_FQDN\"] ?? (CI_SERVER_PORT == \"443\" ? gitData.remote.host : `${gitData.remote.host}:${CI_SERVER_PORT}`);\n    const CI_SERVER_URL = _variables[\"CI_SERVER_URL\"] ?? `${CI_SERVER_PROTOCOL}://${CI_SERVER_FQDN}`;\n    const CI_PROJECT_ROOT_NAMESPACE = gitData.remote.group.split(\"/\")[0];\n    const CI_PROJECT_NAMESPACE = gitData.remote.group;\n    const CI_DEPENDENCY_PROXY_SERVER = CI_SERVER_FQDN.includes(\":\") ? CI_SERVER_FQDN : `${CI_SERVER_HOST}:${CI_SERVER_PORT}`;\n\n    const predefinedVariables: {[key: string]: string} = {\n        CI: \"true\",\n        GITLAB_USER_LOGIN: gitData.user[\"GITLAB_USER_LOGIN\"],\n        GITLAB_USER_EMAIL: gitData.user[\"GITLAB_USER_EMAIL\"],\n        GITLAB_USER_NAME: gitData.user[\"GITLAB_USER_NAME\"],\n        GITLAB_USER_ID: gitData.user[\"GITLAB_USER_ID\"],\n        CI_COMMIT_SHORT_SHA: gitData.commit.SHA.slice(0, 8), // Changes\n        CI_COMMIT_SHA: gitData.commit.SHA,\n        CI_PROJECT_NAME: gitData.remote.project,\n        CI_PROJECT_TITLE: `${camelCase(gitData.remote.project)}`,\n        CI_PROJECT_PATH: `${gitData.remote.group}/${gitData.remote.project}`,\n        CI_PROJECT_PATH_SLUG: `${gitData.remote.group.replace(/\\//g, \"-\")}-${gitData.remote.project}`.toLowerCase(),\n        CI_PROJECT_ROOT_NAMESPACE: CI_PROJECT_ROOT_NAMESPACE,\n        CI_PROJECT_NAMESPACE: CI_PROJECT_NAMESPACE,\n        CI_PROJECT_VISIBILITY: \"internal\",\n        CI_PROJECT_ID: \"1217\",\n        CI_COMMIT_REF_PROTECTED: \"false\",\n        CI_COMMIT_BRANCH: gitData.commit.REF_NAME, // Not available in merge request or tag pipelines\n        CI_COMMIT_REF_NAME: gitData.commit.REF_NAME, // Tag or branch name\n        CI_COMMIT_REF_SLUG: gitData.commit.REF_NAME.replace(/[^a-z\\d]+/ig, \"-\").replace(/^-/, \"\").slice(0, 63).replace(/-$/, \"\").toLowerCase(),\n        CI_COMMIT_TIMESTAMP: gitData.commit.TIMESTAMP,\n        CI_PIPELINE_CREATED_AT: new Date().toISOString().split(\".\")[0] + \"Z\",\n        CI_COMMIT_TITLE: \"Commit Title\", // First line of commit message.\n        CI_COMMIT_MESSAGE: \"Commit Title\\nMore commit text\", // Full commit message\n        CI_COMMIT_DESCRIPTION: \"More commit text\",\n        CI_DEFAULT_BRANCH: gitData.branches.default,\n        CI_PIPELINE_SOURCE: \"push\",\n        CI_SERVER_FQDN: CI_SERVER_FQDN,\n        CI_SERVER_HOST: CI_SERVER_HOST,\n        CI_SERVER_PORT: CI_SERVER_PORT,\n        CI_SERVER_SHELL_SSH_PORT: CI_SERVER_SHELL_SSH_PORT,\n        CI_SERVER_URL: CI_SERVER_URL,\n        CI_SERVER_PROTOCOL: CI_SERVER_PROTOCOL,\n        CI_API_V4_URL: `${CI_SERVER_URL}/api/v4`,\n        CI_PROJECT_URL: `${CI_SERVER_URL}/${gitData.remote.group}/${gitData.remote.project}`,\n        CI_TEMPLATE_REGISTRY_HOST: \"registry.gitlab.com\",\n        GITLAB_CI: \"false\",\n        FF_DISABLE_UMASK_FOR_DOCKER_EXECUTOR: argv.umask ? \"false\" : \"true\",\n\n        CI_DEPENDENCY_PROXY_DIRECT_GROUP_IMAGE_PREFIX: `${CI_DEPENDENCY_PROXY_SERVER}/${CI_PROJECT_NAMESPACE}/dependency_proxy/containers`,\n        CI_DEPENDENCY_PROXY_GROUP_IMAGE_PREFIX: `${CI_DEPENDENCY_PROXY_SERVER}/${CI_PROJECT_ROOT_NAMESPACE}/dependency_proxy/containers`,\n        CI_DEPENDENCY_PROXY_SERVER: CI_DEPENDENCY_PROXY_SERVER,\n        CI_DEPENDENCY_PROXY_USER: \"gitlab-ci-token\",\n    };\n\n    // Delete variables the user intentionally wants unset\n    for (const unsetVariable of argv.unsetVariables) {\n        delete predefinedVariables[unsetVariable];\n    }\n\n    return predefinedVariables;\n}\n"]}
|
package/src/producers.js
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { Utils } from "./utils.js";
|
|
2
|
-
export class Producers {
|
|
3
|
-
static init(jobs, stages, job) {
|
|
4
|
-
const producerSet = new Set();
|
|
5
|
-
if (job.needs && job.needs.length === 0)
|
|
6
|
-
return [];
|
|
7
|
-
if (!job.needs && !job.dependencies) {
|
|
8
|
-
for (const jobName of Utils.getJobNamesFromPreviousStages(jobs, stages, job)) {
|
|
9
|
-
producerSet.add(jobName);
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
(job.dependencies ?? []).forEach(dependency => {
|
|
13
|
-
const foundInNeeds = (job.needs ?? []).find(n => n.job === dependency);
|
|
14
|
-
if (foundInNeeds)
|
|
15
|
-
return;
|
|
16
|
-
producerSet.add(dependency);
|
|
17
|
-
});
|
|
18
|
-
(job.needs ?? []).forEach(need => {
|
|
19
|
-
if (!need.artifacts)
|
|
20
|
-
return;
|
|
21
|
-
if (need.pipeline)
|
|
22
|
-
return;
|
|
23
|
-
if (need.project)
|
|
24
|
-
return;
|
|
25
|
-
producerSet.add(need.job);
|
|
26
|
-
});
|
|
27
|
-
const producers = [];
|
|
28
|
-
for (const potential of jobs) {
|
|
29
|
-
if (potential.artifacts == null)
|
|
30
|
-
continue;
|
|
31
|
-
if (potential.when == "never")
|
|
32
|
-
continue;
|
|
33
|
-
if (!producerSet.has(potential.name) && !producerSet.has(potential.baseName))
|
|
34
|
-
continue;
|
|
35
|
-
producers.push(potential);
|
|
36
|
-
}
|
|
37
|
-
return producers.map(producer => {
|
|
38
|
-
return { name: producer.name, dotenv: producer?.artifacts?.reports?.dotenv ?? null };
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicHJvZHVjZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxLQUFLLEVBQUMsTUFBTSxZQUFZLENBQUM7QUFHakMsTUFBTSxPQUFPLFNBQVM7SUFFbEIsTUFBTSxDQUFDLElBQUksQ0FBRSxJQUF3QixFQUFFLE1BQXlCLEVBQUUsR0FBUTtRQUN0RSxNQUFNLFdBQVcsR0FBZ0IsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUUzQyxJQUFJLEdBQUcsQ0FBQyxLQUFLLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQztZQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ25ELElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ2xDLEtBQUssTUFBTSxPQUFPLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDM0UsV0FBVyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM3QixDQUFDO1FBQ0wsQ0FBQztRQUNELENBQUMsR0FBRyxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDMUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssVUFBVSxDQUFDLENBQUM7WUFDdkUsSUFBSSxZQUFZO2dCQUFFLE9BQU87WUFDekIsV0FBVyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNoQyxDQUFDLENBQUMsQ0FBQztRQUNILENBQUMsR0FBRyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDN0IsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTO2dCQUFFLE9BQU87WUFDNUIsSUFBSSxJQUFJLENBQUMsUUFBUTtnQkFBRSxPQUFPO1lBQzFCLElBQUksSUFBSSxDQUFDLE9BQU87Z0JBQUUsT0FBTztZQUN6QixXQUFXLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM5QixDQUFDLENBQUMsQ0FBQztRQUVILE1BQU0sU0FBUyxHQUFVLEVBQUUsQ0FBQztRQUU1QixLQUFLLE1BQU0sU0FBUyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQzNCLElBQUksU0FBUyxDQUFDLFNBQVMsSUFBSSxJQUFJO2dCQUFFLFNBQVM7WUFDMUMsSUFBSSxTQUFTLENBQUMsSUFBSSxJQUFJLE9BQU87Z0JBQUUsU0FBUztZQUN4QyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7Z0JBQUUsU0FBUztZQUN2RixTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzlCLENBQUM7UUFDRCxPQUFPLFNBQVMsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDNUIsT0FBTyxFQUFDLElBQUksRUFBRSxRQUFRLENBQUMsSUFBSSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLElBQUksSUFBSSxFQUFDLENBQUM7UUFDdkYsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0NBRUoiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1V0aWxzfSBmcm9tIFwiLi91dGlscy5qc1wiO1xuaW1wb3J0IHtKb2J9IGZyb20gXCIuL2pvYi5qc1wiO1xuXG5leHBvcnQgY2xhc3MgUHJvZHVjZXJzIHtcblxuICAgIHN0YXRpYyBpbml0IChqb2JzOiBSZWFkb25seUFycmF5PEpvYj4sIHN0YWdlczogcmVhZG9ubHkgc3RyaW5nW10sIGpvYjogSm9iKSB7XG4gICAgICAgIGNvbnN0IHByb2R1Y2VyU2V0OiBTZXQ8c3RyaW5nPiA9IG5ldyBTZXQoKTtcblxuICAgICAgICBpZiAoam9iLm5lZWRzICYmIGpvYi5uZWVkcy5sZW5ndGggPT09IDApIHJldHVybiBbXTtcbiAgICAgICAgaWYgKCFqb2IubmVlZHMgJiYgIWpvYi5kZXBlbmRlbmNpZXMpIHtcbiAgICAgICAgICAgIGZvciAoY29uc3Qgam9iTmFtZSBvZiBVdGlscy5nZXRKb2JOYW1lc0Zyb21QcmV2aW91c1N0YWdlcyhqb2JzLCBzdGFnZXMsIGpvYikpIHtcbiAgICAgICAgICAgICAgICBwcm9kdWNlclNldC5hZGQoam9iTmFtZSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgKGpvYi5kZXBlbmRlbmNpZXMgPz8gW10pLmZvckVhY2goZGVwZW5kZW5jeSA9PiB7XG4gICAgICAgICAgICBjb25zdCBmb3VuZEluTmVlZHMgPSAoam9iLm5lZWRzID8/IFtdKS5maW5kKG4gPT4gbi5qb2IgPT09IGRlcGVuZGVuY3kpO1xuICAgICAgICAgICAgaWYgKGZvdW5kSW5OZWVkcykgcmV0dXJuO1xuICAgICAgICAgICAgcHJvZHVjZXJTZXQuYWRkKGRlcGVuZGVuY3kpO1xuICAgICAgICB9KTtcbiAgICAgICAgKGpvYi5uZWVkcyA/PyBbXSkuZm9yRWFjaChuZWVkID0+IHtcbiAgICAgICAgICAgIGlmICghbmVlZC5hcnRpZmFjdHMpIHJldHVybjtcbiAgICAgICAgICAgIGlmIChuZWVkLnBpcGVsaW5lKSByZXR1cm47XG4gICAgICAgICAgICBpZiAobmVlZC5wcm9qZWN0KSByZXR1cm47XG4gICAgICAgICAgICBwcm9kdWNlclNldC5hZGQobmVlZC5qb2IpO1xuICAgICAgICB9KTtcblxuICAgICAgICBjb25zdCBwcm9kdWNlcnM6IEpvYltdID0gW107XG5cbiAgICAgICAgZm9yIChjb25zdCBwb3RlbnRpYWwgb2Ygam9icykge1xuICAgICAgICAgICAgaWYgKHBvdGVudGlhbC5hcnRpZmFjdHMgPT0gbnVsbCkgY29udGludWU7XG4gICAgICAgICAgICBpZiAocG90ZW50aWFsLndoZW4gPT0gXCJuZXZlclwiKSBjb250aW51ZTtcbiAgICAgICAgICAgIGlmICghcHJvZHVjZXJTZXQuaGFzKHBvdGVudGlhbC5uYW1lKSAmJiAhcHJvZHVjZXJTZXQuaGFzKHBvdGVudGlhbC5iYXNlTmFtZSkpIGNvbnRpbnVlO1xuICAgICAgICAgICAgcHJvZHVjZXJzLnB1c2gocG90ZW50aWFsKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcHJvZHVjZXJzLm1hcChwcm9kdWNlciA9PiB7XG4gICAgICAgICAgICByZXR1cm4ge25hbWU6IHByb2R1Y2VyLm5hbWUsIGRvdGVudjogcHJvZHVjZXI/LmFydGlmYWN0cz8ucmVwb3J0cz8uZG90ZW52ID8/IG51bGx9O1xuICAgICAgICB9KTtcbiAgICB9XG5cbn1cbiJdfQ==
|
package/src/schema/index.js
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { schema } from "./schema.js";
|
|
2
|
-
// @ts-expect-error ts-expect-error
|
|
3
|
-
schema.definitions.job_template.properties.gclInjectSSHAgent = {
|
|
4
|
-
"type": "boolean",
|
|
5
|
-
};
|
|
6
|
-
// @ts-expect-error ts-expect-error
|
|
7
|
-
schema.definitions.job_template.properties.gclInteractive = {
|
|
8
|
-
"type": "boolean",
|
|
9
|
-
};
|
|
10
|
-
// @ts-expect-error ts-expect-error
|
|
11
|
-
schema.definitions.job_template.properties.gclArtifactsToSource = {
|
|
12
|
-
"type": "boolean",
|
|
13
|
-
};
|
|
14
|
-
// @ts-expect-error ts-expect-error
|
|
15
|
-
schema.definitions.job_template.properties.gclDescription = {
|
|
16
|
-
"type": "string",
|
|
17
|
-
};
|
|
18
|
-
export default schema;
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sYUFBYSxDQUFDO0FBRW5DLG1DQUFtQztBQUNuQyxNQUFNLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLEdBQUc7SUFDM0QsTUFBTSxFQUFFLFNBQVM7Q0FDcEIsQ0FBQztBQUNGLG1DQUFtQztBQUNuQyxNQUFNLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsY0FBYyxHQUFHO0lBQ3hELE1BQU0sRUFBRSxTQUFTO0NBQ3BCLENBQUM7QUFDRixtQ0FBbUM7QUFDbkMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLG9CQUFvQixHQUFHO0lBQzlELE1BQU0sRUFBRSxTQUFTO0NBQ3BCLENBQUM7QUFDRixtQ0FBbUM7QUFDbkMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLGNBQWMsR0FBRztJQUN4RCxNQUFNLEVBQUUsUUFBUTtDQUNuQixDQUFDO0FBRUYsZUFBZSxNQUFNLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge3NjaGVtYX0gZnJvbSBcIi4vc2NoZW1hLmpzXCI7XG5cbi8vIEB0cy1leHBlY3QtZXJyb3IgdHMtZXhwZWN0LWVycm9yXG5zY2hlbWEuZGVmaW5pdGlvbnMuam9iX3RlbXBsYXRlLnByb3BlcnRpZXMuZ2NsSW5qZWN0U1NIQWdlbnQgPSB7XG4gICAgXCJ0eXBlXCI6IFwiYm9vbGVhblwiLFxufTtcbi8vIEB0cy1leHBlY3QtZXJyb3IgdHMtZXhwZWN0LWVycm9yXG5zY2hlbWEuZGVmaW5pdGlvbnMuam9iX3RlbXBsYXRlLnByb3BlcnRpZXMuZ2NsSW50ZXJhY3RpdmUgPSB7XG4gICAgXCJ0eXBlXCI6IFwiYm9vbGVhblwiLFxufTtcbi8vIEB0cy1leHBlY3QtZXJyb3IgdHMtZXhwZWN0LWVycm9yXG5zY2hlbWEuZGVmaW5pdGlvbnMuam9iX3RlbXBsYXRlLnByb3BlcnRpZXMuZ2NsQXJ0aWZhY3RzVG9Tb3VyY2UgPSB7XG4gICAgXCJ0eXBlXCI6IFwiYm9vbGVhblwiLFxufTtcbi8vIEB0cy1leHBlY3QtZXJyb3IgdHMtZXhwZWN0LWVycm9yXG5zY2hlbWEuZGVmaW5pdGlvbnMuam9iX3RlbXBsYXRlLnByb3BlcnRpZXMuZ2NsRGVzY3JpcHRpb24gPSB7XG4gICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBzY2hlbWE7XG4iXX0=
|