gitlab-ci-local 4.26.0 → 4.26.4
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/package.json +15 -15
- package/src/git-data.js +83 -72
- package/src/home-variables.js +3 -3
- package/src/job.js +42 -7
- package/src/parser-includes.js +15 -11
- package/src/parser.js +2 -2
- package/src/utils.js +6 -6
- package/src/types/ci-cache.js +0 -3
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"description": "Tired of pushing to test your .gitlab-ci.yml?",
|
|
4
4
|
"main": "src/index.js",
|
|
5
5
|
"bin": "src/index.js",
|
|
6
|
-
"version": "4.26.
|
|
6
|
+
"version": "4.26.4",
|
|
7
7
|
"scripts": {
|
|
8
8
|
"prepublishOnly": "npm run check-all && chmod +x src/index.js",
|
|
9
9
|
"pkg-linux": "pkg src/index.js --public -t node16-linux-x64 -o bin/linux/gitlab-ci-local && chmod +x bin/linux/gitlab-ci-local && gzip -c bin/linux/gitlab-ci-local > bin/linux.gz",
|
|
@@ -20,39 +20,39 @@
|
|
|
20
20
|
"start": "ts-node --log-error src/index.ts --cwd examples/docker-compose-nodejs"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
|
+
"axios": "^0.24.0",
|
|
23
24
|
"base64url": "^3.0.1",
|
|
24
|
-
"camelcase": "^6.2.
|
|
25
|
+
"camelcase": "^6.2.1",
|
|
25
26
|
"chalk": "^4.1.2",
|
|
26
27
|
"checksum": "^1.0.0",
|
|
27
28
|
"deep-extend": "^0.6.0",
|
|
28
29
|
"dotenv": "^10.0.0",
|
|
29
30
|
"fs-extra": "^10.0.0",
|
|
30
31
|
"js-yaml": "^4.1.0",
|
|
31
|
-
"node-fetch": "^2.6.5",
|
|
32
32
|
"pretty-hrtime": "^1.0.3",
|
|
33
|
-
"source-map-support": "^0.5.
|
|
33
|
+
"source-map-support": "^0.5.21",
|
|
34
34
|
"yargs": "^17.2.1"
|
|
35
35
|
},
|
|
36
36
|
"devDependencies": {
|
|
37
|
-
"@types/chalk": "2.2.0",
|
|
38
37
|
"@types/checksum": "0.1.33",
|
|
39
38
|
"@types/deep-extend": "0.4.32",
|
|
40
39
|
"@types/fs-extra": "9.0.13",
|
|
41
|
-
"@types/jest": "27.0.
|
|
42
|
-
"@types/
|
|
43
|
-
"@types/
|
|
40
|
+
"@types/jest": "27.0.3",
|
|
41
|
+
"@types/jest-when": "2.7.3",
|
|
42
|
+
"@types/js-yaml": "4.0.5",
|
|
44
43
|
"@types/pretty-hrtime": "1.0.1",
|
|
45
44
|
"@types/source-map-support": "0.5.4",
|
|
46
|
-
"@types/yargs": "17.0.
|
|
47
|
-
"@typescript-eslint/eslint-plugin": "5.
|
|
48
|
-
"@typescript-eslint/parser": "5.
|
|
45
|
+
"@types/yargs": "17.0.7",
|
|
46
|
+
"@typescript-eslint/eslint-plugin": "5.5.0",
|
|
47
|
+
"@typescript-eslint/parser": "5.5.0",
|
|
49
48
|
"depcheck": "1.4.2",
|
|
50
|
-
"eslint": "8.
|
|
51
|
-
"jest": "27.
|
|
52
|
-
"
|
|
49
|
+
"eslint": "8.3.0",
|
|
50
|
+
"jest": "27.4.2",
|
|
51
|
+
"jest-when": "3.4.2",
|
|
52
|
+
"pkg": "5.5.1",
|
|
53
53
|
"ts-jest": "27.0.7",
|
|
54
54
|
"ts-node": "10.4.0",
|
|
55
|
-
"typescript": "4.
|
|
55
|
+
"typescript": "4.5.2"
|
|
56
56
|
},
|
|
57
57
|
"engines": {
|
|
58
58
|
"node": ">=16.10.0"
|
package/src/git-data.js
CHANGED
|
@@ -1,29 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
4
|
};
|
|
21
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
6
|
exports.GitData = void 0;
|
|
23
7
|
const utils_1 = require("./utils");
|
|
24
|
-
const fs = __importStar(require("fs-extra"));
|
|
25
|
-
const exit_error_1 = require("./types/exit-error");
|
|
26
8
|
const asserts_1 = require("./asserts");
|
|
9
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
10
|
+
const exit_error_1 = require("./types/exit-error");
|
|
27
11
|
class GitData {
|
|
28
12
|
constructor(data) {
|
|
29
13
|
this.remote = data.remote;
|
|
@@ -34,7 +18,7 @@ class GitData {
|
|
|
34
18
|
return `${this.remote.group}/${this.remote.project}`;
|
|
35
19
|
}
|
|
36
20
|
get CI_REGISTRY() {
|
|
37
|
-
return `local-registry.${this.remote.
|
|
21
|
+
return `local-registry.${this.remote.host}`;
|
|
38
22
|
}
|
|
39
23
|
get CI_REGISTRY_IMAGE() {
|
|
40
24
|
return `${this.CI_REGISTRY}/${this.CI_PROJECT_PATH}`;
|
|
@@ -42,69 +26,96 @@ class GitData {
|
|
|
42
26
|
get CI_PROJECT_PATH_SLUG() {
|
|
43
27
|
return `${this.remote.group.replace(/\//g, "-")}-${this.remote.project}`;
|
|
44
28
|
}
|
|
45
|
-
static async init(cwd) {
|
|
46
|
-
let gitlabUserEmail, gitlabUserName;
|
|
29
|
+
static async init(cwd, writeStreams) {
|
|
47
30
|
try {
|
|
48
|
-
const
|
|
49
|
-
|
|
31
|
+
const gitVersion = (await utils_1.Utils.spawn("git --version", cwd)).stdout.trimEnd();
|
|
32
|
+
(0, asserts_1.assert)(gitVersion != null, "We do not think it is safe to use git without a proper version string!");
|
|
50
33
|
}
|
|
51
34
|
catch (e) {
|
|
52
|
-
|
|
35
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Git not available using fallback}\n`);
|
|
36
|
+
return this.defaultData;
|
|
53
37
|
}
|
|
54
|
-
|
|
38
|
+
return new GitData({
|
|
39
|
+
user: await GitData.getUserData(cwd, writeStreams),
|
|
40
|
+
remote: await GitData.getRemoteData(cwd, writeStreams),
|
|
41
|
+
commit: await GitData.getCommitData(cwd, writeStreams),
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
static async getCommitData(cwd, writeStreams) {
|
|
55
45
|
try {
|
|
56
|
-
const
|
|
57
|
-
|
|
46
|
+
const gitLogStdout = (await utils_1.Utils.spawn("git log -1 --pretty=format:'%h %H %D'", cwd)).stdout.replace(/\r?\n/g, "");
|
|
47
|
+
const gitLogMatch = gitLogStdout.match(/(?<short_sha>\S*?) (?<sha>\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);
|
|
48
|
+
(0, asserts_1.assert)(gitLogMatch?.groups != null, "git log -1 didn't provide valid matches");
|
|
49
|
+
return {
|
|
50
|
+
REF_NAME: gitLogMatch.groups.ref_name,
|
|
51
|
+
SHA: gitLogMatch.groups.sha,
|
|
52
|
+
SHORT_SHA: gitLogMatch.groups.short_sha,
|
|
53
|
+
};
|
|
58
54
|
}
|
|
59
55
|
catch (e) {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
56
|
+
if (e instanceof exit_error_1.ExitError) {
|
|
57
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
58
|
+
return this.defaultData.commit;
|
|
59
|
+
}
|
|
60
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git commit data}\n`);
|
|
61
|
+
return this.defaultData.commit;
|
|
65
62
|
}
|
|
66
|
-
|
|
67
|
-
|
|
63
|
+
}
|
|
64
|
+
static async getRemoteData(cwd, writeStreams) {
|
|
65
|
+
try {
|
|
66
|
+
const { stdout: gitRemote } = await utils_1.Utils.spawn("git remote -v", cwd);
|
|
67
|
+
const gitRemoteMatch = gitRemote.match(/.*(?:\/\/|@)(?<host>[^:/]*)(:(?<port>\d+)\/|:|\/)(?<group>.*)\/(?<project>.*?)(?:\r?\n|\.git)/);
|
|
68
|
+
(0, asserts_1.assert)(gitRemoteMatch?.groups != null, "git remote -v didn't provide valid matches");
|
|
69
|
+
return {
|
|
70
|
+
port: gitRemoteMatch.groups.port ?? "22",
|
|
71
|
+
host: gitRemoteMatch.groups.host,
|
|
72
|
+
group: gitRemoteMatch.groups.group,
|
|
73
|
+
project: gitRemoteMatch.groups.project,
|
|
74
|
+
};
|
|
68
75
|
}
|
|
69
|
-
|
|
70
|
-
|
|
76
|
+
catch (e) {
|
|
77
|
+
if (e instanceof exit_error_1.ExitError) {
|
|
78
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
79
|
+
return this.defaultData.remote;
|
|
80
|
+
}
|
|
81
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git remote data}\n`);
|
|
82
|
+
return this.defaultData.remote;
|
|
71
83
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
84
|
+
}
|
|
85
|
+
static async getUserData(cwd, writeStreams) {
|
|
86
|
+
try {
|
|
87
|
+
const email = (await utils_1.Utils.spawn("git config user.email", cwd)).stdout.trimEnd();
|
|
88
|
+
return {
|
|
89
|
+
GITLAB_USER_NAME: (await utils_1.Utils.spawn("git config user.name", cwd)).stdout.trimEnd(),
|
|
90
|
+
GITLAB_USER_ID: (await utils_1.Utils.spawn("id -u", cwd)).stdout.trimEnd(),
|
|
91
|
+
GITLAB_USER_EMAIL: email,
|
|
92
|
+
GITLAB_USER_LOGIN: email.replace(/@.*/, ""),
|
|
93
|
+
};
|
|
82
94
|
}
|
|
83
|
-
|
|
84
|
-
|
|
95
|
+
catch (e) {
|
|
96
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user data}\n`);
|
|
97
|
+
return this.defaultData.user;
|
|
85
98
|
}
|
|
86
|
-
(0, asserts_1.assert)(gitLogMatch?.groups != null, "git log -1 didn't provide valid matches");
|
|
87
|
-
(0, asserts_1.assert)(gitLogMatch.groups.ref_name != null, "<ref_name> not found in git log -1");
|
|
88
|
-
(0, asserts_1.assert)(gitLogMatch.groups.sha != null, "<sha> not found in git log -1");
|
|
89
|
-
(0, asserts_1.assert)(gitLogMatch.groups.short_sha != null, "<short_sha> not found in git log -1");
|
|
90
|
-
return new GitData({
|
|
91
|
-
user: {
|
|
92
|
-
GITLAB_USER_LOGIN: gitlabUserLogin,
|
|
93
|
-
GITLAB_USER_EMAIL: gitlabUserEmail,
|
|
94
|
-
GITLAB_USER_NAME: gitlabUserName,
|
|
95
|
-
},
|
|
96
|
-
remote: {
|
|
97
|
-
domain: gitRemoteMatch.groups.domain,
|
|
98
|
-
group: gitRemoteMatch.groups.group,
|
|
99
|
-
project: gitRemoteMatch.groups.project,
|
|
100
|
-
},
|
|
101
|
-
commit: {
|
|
102
|
-
REF_NAME: gitLogMatch.groups.ref_name,
|
|
103
|
-
SHA: gitLogMatch.groups.sha,
|
|
104
|
-
SHORT_SHA: gitLogMatch.groups.short_sha,
|
|
105
|
-
},
|
|
106
|
-
});
|
|
107
99
|
}
|
|
108
100
|
}
|
|
109
101
|
exports.GitData = GitData;
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"git-data.js","sourceRoot":"","sources":["git-data.ts"],"names":[],"mappings":"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","sourcesContent":["import {Utils} from \"./utils\";\nimport * as fs from \"fs-extra\";\nimport {ExitError} from \"./types/exit-error\";\nimport {assert} from \"./asserts\";\n\ninterface GitRemote {\n    domain: string;\n    group: string;\n    project: string;\n}\n\ninterface GitCommit {\n    SHA: string;\n    SHORT_SHA: string;\n    REF_NAME: string;\n}\n\ninterface GitUser {\n    GITLAB_USER_EMAIL: string;\n    GITLAB_USER_LOGIN: string;\n    GITLAB_USER_NAME: string;\n}\n\nexport class GitData {\n\n    readonly remote: GitRemote;\n    readonly commit: GitCommit;\n    readonly user: GitUser;\n\n    constructor(data: {remote: GitRemote; commit: GitCommit; user: GitUser}) {\n        this.remote = data.remote;\n        this.commit = data.commit;\n        this.user = data.user;\n    }\n\n    get CI_PROJECT_PATH() {\n        return `${this.remote.group}/${this.remote.project}`;\n    }\n\n    get CI_REGISTRY() {\n        return `local-registry.${this.remote.domain}`;\n    }\n\n    get CI_REGISTRY_IMAGE() {\n        return `${this.CI_REGISTRY}/${this.CI_PROJECT_PATH}`;\n    }\n\n    get CI_PROJECT_PATH_SLUG() {\n        return `${this.remote.group.replace(/\\//g, \"-\")}-${this.remote.project}`;\n    }\n\n    static async init(cwd: string): Promise<GitData> {\n        let gitlabUserEmail, gitlabUserName;\n\n        try {\n            const {stdout: gitConfigEmail} = await Utils.spawn(\"git config user.email\", cwd);\n            gitlabUserEmail = gitConfigEmail.trimEnd();\n        } catch (e) {\n            gitlabUserEmail = \"local@gitlab.com\";\n        }\n        const gitlabUserLogin = gitlabUserEmail.replace(/@.*/, \"\");\n        try {\n            const {stdout: gitConfigUserName} = await Utils.spawn(\"git config user.name\", cwd);\n            gitlabUserName = gitConfigUserName.trimEnd();\n        } catch (e) {\n            gitlabUserName = \"Bob Local\";\n        }\n\n        let gitConfig;\n        if (fs.existsSync(`${cwd}/.git/config`)) {\n            gitConfig = fs.readFileSync(`${cwd}/.git/config`, \"utf8\");\n        } else if (fs.existsSync(`${cwd}/.gitconfig`)) {\n            gitConfig = fs.readFileSync(`${cwd}/.gitconfig`, \"utf8\");\n        } else {\n            throw new ExitError(\"Could not locate.gitconfig or .git/config file\");\n        }\n        const gitRemoteMatch = gitConfig.match(/url = .*(?:http[s]?:\\/\\/|@)(?<domain>.*?)[:|/](?<group>.*)\\/(?<project>.*?)(?:\\r?\\n|\\.git)/);\n        assert(gitRemoteMatch?.groups != null, \"git config didn't provide valid matches\");\n        assert(gitRemoteMatch.groups.domain != null, \"<domain> not found in git config\");\n        assert(gitRemoteMatch.groups.group != null, \"<group> not found in git config\");\n        assert(gitRemoteMatch.groups.project != null, \"<project> not found in git config\");\n\n        const {stdout: gitLogStdout} = await Utils.spawn(\"git log -1 --pretty=format:'%h %H %D'\", cwd);\n        const gitLogOutput = gitLogStdout.replace(/\\r?\\n/g, \"\");\n        let gitLogMatch;\n        if (gitLogOutput.match(/HEAD, tag/)) {\n            gitLogMatch = gitLogOutput.match(/(?<short_sha>.*?) (?<sha>.*?) HEAD, tag: (?<ref_name>.*?),/);\n        } else {\n            gitLogMatch = gitLogOutput.match(/(?<short_sha>.*?) (?<sha>.*?) HEAD -> (?<ref_name>.*?)(?:,|$)/);\n        }\n        assert(gitLogMatch?.groups != null, \"git log -1 didn't provide valid matches\");\n        assert(gitLogMatch.groups.ref_name != null, \"<ref_name> not found in git log -1\");\n        assert(gitLogMatch.groups.sha != null, \"<sha> not found in git log -1\");\n        assert(gitLogMatch.groups.short_sha != null, \"<short_sha> not found in git log -1\");\n\n        return new GitData({\n            user: {\n                GITLAB_USER_LOGIN: gitlabUserLogin,\n                GITLAB_USER_EMAIL: gitlabUserEmail,\n                GITLAB_USER_NAME: gitlabUserName,\n            },\n            remote: {\n                domain: gitRemoteMatch.groups.domain,\n                group: gitRemoteMatch.groups.group,\n                project: gitRemoteMatch.groups.project,\n            },\n            commit: {\n                REF_NAME: gitLogMatch.groups.ref_name,\n                SHA: gitLogMatch.groups.sha,\n                SHORT_SHA: gitLogMatch.groups.short_sha,\n            },\n        });\n    }\n}\n"]}
|
|
102
|
+
GitData.defaultData = new GitData({
|
|
103
|
+
user: {
|
|
104
|
+
GITLAB_USER_LOGIN: "local",
|
|
105
|
+
GITLAB_USER_EMAIL: "local@gitlab.com",
|
|
106
|
+
GITLAB_USER_NAME: "Bob Local",
|
|
107
|
+
GITLAB_USER_ID: "1000",
|
|
108
|
+
},
|
|
109
|
+
remote: {
|
|
110
|
+
port: "22",
|
|
111
|
+
host: "gitlab.com",
|
|
112
|
+
group: "fallback.group",
|
|
113
|
+
project: "fallback.project",
|
|
114
|
+
},
|
|
115
|
+
commit: {
|
|
116
|
+
REF_NAME: "main",
|
|
117
|
+
SHA: "0000000000000000000000000000000000000000",
|
|
118
|
+
SHORT_SHA: "00000000",
|
|
119
|
+
},
|
|
120
|
+
});
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"git-data.js","sourceRoot":"","sources":["git-data.ts"],"names":[],"mappings":";;;;;;AAAA,mCAAgC;AAChC,uCAAmC;AAEnC,kDAA0B;AAC1B,mDAA6C;AAsB7C,MAAa,OAAO;IA2BhB,YAAY,IAA6D;QACrE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;IAC1B,CAAC;IAED,IAAI,eAAe;QACf,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IACzD,CAAC;IAED,IAAI,WAAW;QACX,OAAO,kBAAkB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAChD,CAAC;IAED,IAAI,iBAAiB;QACjB,OAAO,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;IACzD,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IAC7E,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAW,EAAE,YAA0B;QACrD,IAAI;YACA,MAAM,UAAU,GAAG,CAAC,MAAM,aAAK,CAAC,KAAK,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAC9E,IAAA,gBAAM,EAAC,UAAU,IAAI,IAAI,EAAE,wEAAwE,CAAC,CAAC;SACxG;QAAC,OAAO,CAAC,EAAE;YACR,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,6CAA6C,CAAC,CAAC;YACxE,OAAO,IAAI,CAAC,WAAW,CAAC;SAC3B;QAED,OAAO,IAAI,OAAO,CAAC;YACf,IAAI,EAAE,MAAM,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,YAAY,CAAC;YAClD,MAAM,EAAE,MAAM,OAAO,CAAC,aAAa,CAAC,GAAG,EAAE,YAAY,CAAC;YACtD,MAAM,EAAE,MAAM,OAAO,CAAC,aAAa,CAAC,GAAG,EAAE,YAAY,CAAC;SACzD,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,GAAW,EAAE,YAA0B;QAC9D,IAAI;YACA,MAAM,YAAY,GAAG,CAAC,MAAM,aAAK,CAAC,KAAK,CAAC,uCAAuC,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YACpH,MAAM,WAAW,GAAG,YAAY,CAAC,KAAK,CAAC,+EAA+E,CAAC,CAAC;YAExH,IAAA,gBAAM,EAAC,WAAW,EAAE,MAAM,IAAI,IAAI,EAAE,yCAAyC,CAAC,CAAC;YAE/E,OAAO;gBACH,QAAQ,EAAE,WAAW,CAAC,MAAM,CAAC,QAAQ;gBACrC,GAAG,EAAE,WAAW,CAAC,MAAM,CAAC,GAAG;gBAC3B,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,SAAS;aAC1C,CAAC;SACL;QAAC,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,YAAY,sBAAS,EAAE;gBACxB,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,WAAW,CAAC,CAAC,OAAO,KAAK,CAAC,CAAC;gBACpD,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;aAClC;YACD,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,2CAA2C,CAAC,CAAC;YACtE,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;SAClC;IACL,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,GAAW,EAAE,YAA0B;QAC9D,IAAI;YACA,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,aAAK,CAAC,KAAK,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;YACtE,MAAM,cAAc,GAAG,SAAS,CAAC,KAAK,CAAC,+FAA+F,CAAC,CAAC;YAExI,IAAA,gBAAM,EAAC,cAAc,EAAE,MAAM,IAAI,IAAI,EAAE,4CAA4C,CAAC,CAAC;YAErF,OAAO;gBACH,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI;gBACxC,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC,IAAI;gBAChC,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,KAAK;gBAClC,OAAO,EAAE,cAAc,CAAC,MAAM,CAAC,OAAO;aACzC,CAAC;SACL;QAAC,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,YAAY,sBAAS,EAAE;gBACxB,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,WAAW,CAAC,CAAC,OAAO,KAAK,CAAC,CAAC;gBACpD,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;aAClC;YACD,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,2CAA2C,CAAC,CAAC;YACtE,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;SAClC;IACL,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,GAAW,EAAE,YAA0B;QAC5D,IAAI;YACA,MAAM,KAAK,GAAG,CAAC,MAAM,aAAK,CAAC,KAAK,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAEjF,OAAO;gBACH,gBAAgB,EAAE,CAAC,MAAM,aAAK,CAAC,KAAK,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE;gBACnF,cAAc,EAAE,CAAC,MAAM,aAAK,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE;gBAClE,iBAAiB,EAAE,KAAK;gBACxB,iBAAiB,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;aAC9C,CAAC;SACL;QAAC,OAAO,CAAC,EAAE;YACR,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,yCAAyC,CAAC,CAAC;YACpE,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;SAChC;IACL,CAAC;;AA5HL,0BA6HC;AA3HmB,mBAAW,GACvB,IAAI,OAAO,CAAC;IACR,IAAI,EAAE;QACF,iBAAiB,EAAE,OAAO;QAC1B,iBAAiB,EAAE,kBAAkB;QACrC,gBAAgB,EAAE,WAAW;QAC7B,cAAc,EAAE,MAAM;KACzB;IACD,MAAM,EAAE;QACJ,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,YAAY;QAClB,KAAK,EAAE,gBAAgB;QACvB,OAAO,EAAE,kBAAkB;KAC9B;IACD,MAAM,EAAE;QACJ,QAAQ,EAAE,MAAM;QAChB,GAAG,EAAE,0CAA0C;QAC/C,SAAS,EAAE,UAAU;KACxB;CACJ,CAAC,CAAC","sourcesContent":["import { Utils } from \"./utils\";\nimport { assert } from \"./asserts\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport chalk from \"chalk\";\nimport {ExitError} from \"./types/exit-error\";\n\ninterface GitRemote {\n    port: string;\n    host: string;\n    group: string;\n    project: string;\n}\n\ninterface GitCommit {\n    SHA: string;\n    SHORT_SHA: string;\n    REF_NAME: string;\n}\n\ninterface GitUser {\n    GITLAB_USER_EMAIL: string;\n    GITLAB_USER_LOGIN: string;\n    GITLAB_USER_NAME: string;\n    GITLAB_USER_ID: string;\n}\n\nexport class GitData {\n\n    static readonly defaultData: GitData =\n        new GitData({\n            user: {\n                GITLAB_USER_LOGIN: \"local\",\n                GITLAB_USER_EMAIL: \"local@gitlab.com\",\n                GITLAB_USER_NAME: \"Bob Local\",\n                GITLAB_USER_ID: \"1000\",\n            },\n            remote: {\n                port: \"22\",\n                host: \"gitlab.com\",\n                group: \"fallback.group\",\n                project: \"fallback.project\",\n            },\n            commit: {\n                REF_NAME: \"main\",\n                SHA: \"0000000000000000000000000000000000000000\",\n                SHORT_SHA: \"00000000\",\n            },\n        });\n\n    readonly remote: GitRemote;\n    readonly commit: GitCommit;\n    readonly user: GitUser;\n\n    constructor(data: { remote: GitRemote; commit: GitCommit; user: GitUser }) {\n        this.remote = data.remote;\n        this.commit = data.commit;\n        this.user = data.user;\n    }\n\n    get CI_PROJECT_PATH() {\n        return `${this.remote.group}/${this.remote.project}`;\n    }\n\n    get CI_REGISTRY() {\n        return `local-registry.${this.remote.host}`;\n    }\n\n    get CI_REGISTRY_IMAGE() {\n        return `${this.CI_REGISTRY}/${this.CI_PROJECT_PATH}`;\n    }\n\n    get CI_PROJECT_PATH_SLUG() {\n        return `${this.remote.group.replace(/\\//g, \"-\")}-${this.remote.project}`;\n    }\n\n    static async init(cwd: string, writeStreams: WriteStreams): Promise<GitData> {\n        try {\n            const gitVersion = (await Utils.spawn(\"git --version\", cwd)).stdout.trimEnd();\n            assert(gitVersion != null, \"We do not think it is safe to use git without a proper version string!\");\n        } catch (e) {\n            writeStreams.stderr(chalk`{yellow Git not available using fallback}\\n`);\n            return this.defaultData;\n        }\n\n        return new GitData({\n            user: await GitData.getUserData(cwd, writeStreams),\n            remote: await GitData.getRemoteData(cwd, writeStreams),\n            commit: await GitData.getCommitData(cwd, writeStreams),\n        });\n    }\n\n    static async getCommitData(cwd: string, writeStreams: WriteStreams): Promise<GitCommit> {\n        try {\n            const gitLogStdout = (await Utils.spawn(\"git log -1 --pretty=format:'%h %H %D'\", cwd)).stdout.replace(/\\r?\\n/g, \"\");\n            const gitLogMatch = gitLogStdout.match(/(?<short_sha>\\S*?) (?<sha>\\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);\n\n            assert(gitLogMatch?.groups != null, \"git log -1 didn't provide valid matches\");\n\n            return {\n                REF_NAME: gitLogMatch.groups.ref_name,\n                SHA: gitLogMatch.groups.sha,\n                SHORT_SHA: gitLogMatch.groups.short_sha,\n            };\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return this.defaultData.commit;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git commit data}\\n`);\n            return this.defaultData.commit;\n        }\n    }\n\n    static async getRemoteData(cwd: string, writeStreams: WriteStreams): Promise<GitRemote> {\n        try {\n            const { stdout: gitRemote } = await Utils.spawn(\"git remote -v\", cwd);\n            const gitRemoteMatch = gitRemote.match(/.*(?:\\/\\/|@)(?<host>[^:/]*)(:(?<port>\\d+)\\/|:|\\/)(?<group>.*)\\/(?<project>.*?)(?:\\r?\\n|\\.git)/);\n\n            assert(gitRemoteMatch?.groups != null, \"git remote -v didn't provide valid matches\");\n\n            return {\n                port: gitRemoteMatch.groups.port ?? \"22\",\n                host: gitRemoteMatch.groups.host,\n                group: gitRemoteMatch.groups.group,\n                project: gitRemoteMatch.groups.project,\n            };\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return this.defaultData.remote;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git remote data}\\n`);\n            return this.defaultData.remote;\n        }\n    }\n\n    static async getUserData(cwd: string, writeStreams: WriteStreams): Promise<GitUser> {\n        try {\n            const email = (await Utils.spawn(\"git config user.email\", cwd)).stdout.trimEnd();\n\n            return {\n                GITLAB_USER_NAME: (await Utils.spawn(\"git config user.name\", cwd)).stdout.trimEnd(),\n                GITLAB_USER_ID: (await Utils.spawn(\"id -u\", cwd)).stdout.trimEnd(),\n                GITLAB_USER_EMAIL: email,\n                GITLAB_USER_LOGIN: email.replace(/@.*/, \"\"),\n            };\n        } catch (e) {\n            writeStreams.stderr(chalk`{yellow Using fallback git user data}\\n`);\n            return this.defaultData.user;\n        }\n    }\n}\n"]}
|
package/src/home-variables.js
CHANGED
|
@@ -42,7 +42,7 @@ class HomeVariables {
|
|
|
42
42
|
}
|
|
43
43
|
variables[globalKey] = globalEntry;
|
|
44
44
|
}
|
|
45
|
-
const groupUrl = `${gitData.remote.
|
|
45
|
+
const groupUrl = `${gitData.remote.host}/${gitData.remote.group}/`;
|
|
46
46
|
for (const [groupKey, groupEntries] of Object.entries(data?.group ?? [])) {
|
|
47
47
|
if (!groupUrl.includes(this.normalizeProjectKey(groupKey, writeStreams))) {
|
|
48
48
|
continue;
|
|
@@ -52,7 +52,7 @@ class HomeVariables {
|
|
|
52
52
|
}
|
|
53
53
|
variables = { ...variables, ...groupEntries };
|
|
54
54
|
}
|
|
55
|
-
const projectUrl = `${gitData.remote.
|
|
55
|
+
const projectUrl = `${gitData.remote.host}/${gitData.remote.group}/${gitData.remote.project}.git`;
|
|
56
56
|
for (const [projectKey, projectEntries] of Object.entries(data?.project ?? [])) {
|
|
57
57
|
if (!projectUrl.includes(this.normalizeProjectKey(projectKey, writeStreams))) {
|
|
58
58
|
continue;
|
|
@@ -97,4 +97,4 @@ class HomeVariables {
|
|
|
97
97
|
}
|
|
98
98
|
}
|
|
99
99
|
exports.HomeVariables = HomeVariables;
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"home-variables.js","sourceRoot":"","sources":["home-variables.ts"],"names":[],"mappings":"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","sourcesContent":["import {WriteStreams} from \"./types/write-streams\";\nimport {GitData} from \"./git-data\";\nimport * as fs from \"fs-extra\";\nimport * as yaml from \"js-yaml\";\nimport path from \"path\";\nimport chalk from \"chalk\";\n\nexport class HomeVariables {\n\n    static async init(cwd: string, writeStreams: WriteStreams, gitData: GitData, home: string): Promise<{ [key: string]: string }> {\n        const homeDir = home.replace(/\\/$/, \"\");\n        const variablesFile = `${homeDir}/.gitlab-ci-local/variables.yml`;\n        if (!fs.existsSync(variablesFile)) {\n            return {};\n        }\n\n        const data: any = yaml.load(await fs.readFile(variablesFile, \"utf8\"), {schema: yaml.FAILSAFE_SCHEMA});\n        let variables: { [key: string]: string } = {};\n\n        for (const [globalKey, globalEntry] of Object.entries(data?.global ?? [])) {\n            if (typeof globalEntry !== \"string\") {\n                continue;\n            }\n            variables[globalKey] = globalEntry;\n        }\n\n        const groupUrl = `${gitData.remote.host}/${gitData.remote.group}/`;\n        for (const [groupKey, groupEntries] of Object.entries(data?.group ?? [])) {\n            if (!groupUrl.includes(this.normalizeProjectKey(groupKey, writeStreams))) {\n                continue;\n            }\n            if (typeof groupEntries !== \"object\") {\n                continue;\n            }\n            variables = {...variables, ...groupEntries};\n        }\n\n        const projectUrl = `${gitData.remote.host}/${gitData.remote.group}/${gitData.remote.project}.git`;\n        for (const [projectKey, projectEntries] of Object.entries(data?.project ?? [])) {\n            if (!projectUrl.includes(this.normalizeProjectKey(projectKey, writeStreams))) {\n                continue;\n            }\n            if (typeof projectEntries !== \"object\") {\n                continue;\n            }\n            variables = {...variables, ...projectEntries};\n        }\n\n        const projectVariablesFile = `${cwd}/.gitlab-ci-local/variables.yml`;\n\n        if (fs.existsSync(projectVariablesFile)) {\n            const projectEntries: any = yaml.load(await fs.readFile(projectVariablesFile, \"utf8\"), {schema: yaml.FAILSAFE_SCHEMA}) ?? {};\n            if (typeof projectEntries === \"object\") {\n                variables = {...variables, ...projectEntries};\n            }\n        }\n\n        // Generate files for file type variables\n        for (const [key, value] of Object.entries(variables)) {\n            if (typeof value !== \"string\") {\n                continue;\n            }\n            if (!value.match(/^[/|~]/)) {\n                continue;\n            }\n\n            if (value.match(/\\/$/)) {\n                continue;\n            }\n\n            const fromFilePath = value.replace(/^~\\/(.*)/, `${homeDir}/$1`);\n            if (fs.existsSync(fromFilePath)) {\n                await fs.ensureDir(`/tmp/gitlab-ci-local-file-variables-${gitData.CI_PROJECT_PATH_SLUG}/`);\n                await fs.copyFile(fromFilePath, `/tmp/gitlab-ci-local-file-variables-${gitData.CI_PROJECT_PATH_SLUG}/${path.basename(fromFilePath)}`);\n                variables[key] = `/tmp/gitlab-ci-local-file-variables-${gitData.CI_PROJECT_PATH_SLUG}/${path.basename(fromFilePath)}`;\n            }\n        }\n\n        return variables;\n    }\n\n    static normalizeProjectKey(key: string, writeStreams: WriteStreams): string {\n        if (!key.includes(\":\")) return key;\n        writeStreams.stderr(chalk`{yellow WARNING: Interpreting '${key}' as '${key.replace(\":\", \"/\")}'}\\n`);\n        return key.replace(\":\", \"/\");\n    }\n}\n"]}
|