@backstage-community/plugin-cicd-statistics-module-gitlab 0.1.31 → 0.1.32

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/CHANGELOG.md CHANGED
@@ -1,5 +1,13 @@
1
1
  # @backstage-community/plugin-cicd-statistics-module-gitlab
2
2
 
3
+ ## 0.1.32
4
+
5
+ ### Patch Changes
6
+
7
+ - 2448d1c: Backstage version bump to v1.29.2
8
+ - Updated dependencies [2448d1c]
9
+ - @backstage-community/plugin-cicd-statistics@0.1.38
10
+
3
11
  ## 0.1.31
4
12
 
5
13
  ### Patch Changes
@@ -0,0 +1,96 @@
1
+ import { Gitlab } from '@gitbeaker/browser';
2
+ import limiterFactory from 'p-limit';
3
+ import { getEntitySourceLocation } from '@backstage/catalog-model';
4
+ import { jobsToStages, pipelinesToBuilds } from './utils.esm.js';
5
+
6
+ class CicdStatisticsApiGitlab {
7
+ #gitLabAuthApi;
8
+ #cicdDefaults;
9
+ constructor(gitLabAuthApi, cicdDefaults = {}) {
10
+ this.#gitLabAuthApi = gitLabAuthApi;
11
+ this.#cicdDefaults = cicdDefaults;
12
+ }
13
+ async createGitlabApi(entity, scopes) {
14
+ const entityInfo = getEntitySourceLocation(entity);
15
+ const url = new URL(entityInfo.target);
16
+ const owner = url.pathname.split("/-/blob/")[0];
17
+ const oauthToken = await this.#gitLabAuthApi.getAccessToken(scopes);
18
+ return {
19
+ api: new Gitlab({
20
+ host: `https://${url.host}`,
21
+ oauthToken
22
+ }),
23
+ owner: owner.substring(1)
24
+ };
25
+ }
26
+ static async updateBuildWithStages(gitbeaker, owner, build) {
27
+ const jobs = await gitbeaker.Jobs.showPipelineJobs(
28
+ owner,
29
+ parseInt(build.id, 10)
30
+ );
31
+ const stages = jobsToStages(jobs);
32
+ return stages;
33
+ }
34
+ static async getDurationOfBuild(gitbeaker, owner, build) {
35
+ const pipeline = await gitbeaker.Pipelines.show(
36
+ owner,
37
+ parseInt(build.id, 10)
38
+ );
39
+ return parseInt(pipeline.duration, 10) * 1e3;
40
+ }
41
+ static async getDefaultBranch(gitbeaker, owner) {
42
+ const branches = await gitbeaker.Branches.all(owner);
43
+ return branches.find((branch) => branch.default)?.name;
44
+ }
45
+ async fetchBuilds(options) {
46
+ const {
47
+ entity,
48
+ updateProgress,
49
+ timeFrom,
50
+ timeTo,
51
+ filterStatus = ["all"],
52
+ filterType = "all"
53
+ } = options;
54
+ const { api, owner } = await this.createGitlabApi(entity, ["read_api"]);
55
+ updateProgress(0, 0, 0);
56
+ const branch = filterType === "master" ? await CicdStatisticsApiGitlab.getDefaultBranch(api, owner) : void 0;
57
+ const pipelines = await api.Pipelines.all(owner, {
58
+ perPage: 25,
59
+ updated_after: timeFrom.toISOString(),
60
+ updated_before: timeTo.toISOString(),
61
+ ref: branch
62
+ });
63
+ const limiter = limiterFactory(10);
64
+ const builds = pipelinesToBuilds(pipelines).map(async (build) => ({
65
+ ...build,
66
+ duration: await limiter(
67
+ () => CicdStatisticsApiGitlab.getDurationOfBuild(api, owner, build)
68
+ ),
69
+ stages: await limiter(
70
+ () => CicdStatisticsApiGitlab.updateBuildWithStages(api, owner, build)
71
+ )
72
+ }));
73
+ const promisedBuilds = (await Promise.all(builds)).filter(
74
+ (b) => filterStatus.includes(b.status)
75
+ );
76
+ return { builds: promisedBuilds };
77
+ }
78
+ async getConfiguration() {
79
+ return {
80
+ availableStatuses: [
81
+ "succeeded",
82
+ "failed",
83
+ "enqueued",
84
+ "running",
85
+ "aborted",
86
+ "stalled",
87
+ "expired",
88
+ "unknown"
89
+ ],
90
+ defaults: this.#cicdDefaults
91
+ };
92
+ }
93
+ }
94
+
95
+ export { CicdStatisticsApiGitlab };
96
+ //# sourceMappingURL=gitlab.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gitlab.esm.js","sources":["../../src/api/gitlab.ts"],"sourcesContent":["/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n CicdStatisticsApi,\n CicdState,\n CicdConfiguration,\n CicdDefaults,\n Build,\n FetchBuildsOptions,\n Stage,\n} from '@backstage-community/plugin-cicd-statistics';\nimport { Gitlab } from '@gitbeaker/browser';\nimport { OAuthApi } from '@backstage/core-plugin-api';\nimport limiterFactory from 'p-limit';\nimport { Entity, getEntitySourceLocation } from '@backstage/catalog-model';\nimport { pipelinesToBuilds, jobsToStages } from './utils';\n\n/**\n * This type represents a initialized gitlab client with gitbeaker\n *\n * @public\n */\nexport type GitlabClient = {\n /* the actual API of gitbeaker */\n api: InstanceType<typeof Gitlab>;\n /* the owner the repository, retrieved from the entity source location */\n owner: string;\n};\n\n/**\n * Extracts the CI/CD statistics from a Gitlab repository\n *\n * @public\n */\nexport class CicdStatisticsApiGitlab implements CicdStatisticsApi {\n readonly #gitLabAuthApi: OAuthApi;\n readonly #cicdDefaults: Partial<CicdDefaults>;\n\n constructor(\n gitLabAuthApi: OAuthApi,\n cicdDefaults: Partial<CicdDefaults> = {},\n ) {\n this.#gitLabAuthApi = gitLabAuthApi;\n this.#cicdDefaults = cicdDefaults;\n }\n\n public async createGitlabApi(\n entity: Entity,\n scopes: string[],\n ): Promise<GitlabClient> {\n const entityInfo = getEntitySourceLocation(entity);\n const url = new URL(entityInfo.target);\n const owner = url.pathname.split('/-/blob/')[0];\n const oauthToken = await this.#gitLabAuthApi.getAccessToken(scopes);\n return {\n api: new Gitlab({\n host: `https://${url.host}`,\n oauthToken,\n }),\n owner: owner.substring(1),\n };\n }\n\n private static async updateBuildWithStages(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n build: Build,\n ): Promise<Stage[]> {\n const jobs = await gitbeaker.Jobs.showPipelineJobs(\n owner,\n parseInt(build.id, 10),\n );\n const stages = jobsToStages(jobs);\n return stages;\n }\n\n private static async getDurationOfBuild(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n build: Build,\n ): Promise<number> {\n const pipeline = await gitbeaker.Pipelines.show(\n owner,\n parseInt(build.id, 10),\n );\n return parseInt(pipeline.duration as string, 10) * 1000;\n }\n\n private static async getDefaultBranch(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n ): Promise<string | undefined> {\n const branches = await gitbeaker.Branches.all(owner);\n return branches.find(branch => branch.default)?.name;\n }\n\n public async fetchBuilds(options: FetchBuildsOptions): Promise<CicdState> {\n const {\n entity,\n updateProgress,\n timeFrom,\n timeTo,\n filterStatus = ['all'],\n filterType = 'all',\n } = options;\n const { api, owner } = await this.createGitlabApi(entity, ['read_api']);\n updateProgress(0, 0, 0);\n\n const branch =\n filterType === 'master'\n ? await CicdStatisticsApiGitlab.getDefaultBranch(api, owner)\n : undefined;\n const pipelines = await api.Pipelines.all(owner, {\n perPage: 25,\n updated_after: timeFrom.toISOString(),\n updated_before: timeTo.toISOString(),\n ref: branch,\n });\n\n const limiter = limiterFactory(10);\n const builds = pipelinesToBuilds(pipelines).map(async build => ({\n ...build,\n duration: await limiter(() =>\n CicdStatisticsApiGitlab.getDurationOfBuild(api, owner, build),\n ),\n stages: await limiter(() =>\n CicdStatisticsApiGitlab.updateBuildWithStages(api, owner, build),\n ),\n }));\n const promisedBuilds = (await Promise.all(builds)).filter(b =>\n filterStatus.includes(b.status),\n );\n\n return { builds: promisedBuilds };\n }\n\n public async getConfiguration(): Promise<Partial<CicdConfiguration>> {\n return {\n availableStatuses: [\n 'succeeded',\n 'failed',\n 'enqueued',\n 'running',\n 'aborted',\n 'stalled',\n 'expired',\n 'unknown',\n ] as const,\n defaults: this.#cicdDefaults,\n };\n }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,54 @@
1
+ const statusMap = {
2
+ manual: "unknown",
3
+ created: "enqueued",
4
+ waiting_for_resource: "stalled",
5
+ preparing: "unknown",
6
+ pending: "scheduled",
7
+ running: "running",
8
+ success: "succeeded",
9
+ failed: "failed",
10
+ canceled: "aborted",
11
+ skipped: "aborted",
12
+ scheduled: "scheduled"
13
+ };
14
+ const triggerReasonMap = {
15
+ push: "scm",
16
+ trigger: "manual",
17
+ merge_request_event: "scm",
18
+ schedule: "internal"
19
+ };
20
+ function pipelinesToBuilds(pipelines) {
21
+ return pipelines.map((pipeline) => {
22
+ return {
23
+ id: pipeline.id.toString(),
24
+ status: statusMap[pipeline.status],
25
+ branchType: "master",
26
+ duration: 0,
27
+ // will get filled in later in a seperate API call
28
+ requestedAt: new Date(pipeline.created_at),
29
+ triggeredBy: triggerReasonMap[pipeline.source] ?? "other",
30
+ stages: []
31
+ };
32
+ });
33
+ }
34
+ function jobsToStages(jobs) {
35
+ return jobs.map((job) => {
36
+ const status = statusMap[job.status] ? statusMap[job.status] : "unknown";
37
+ const duration = job.duration ? job.duration * 1e3 : 0;
38
+ return {
39
+ name: job.stage,
40
+ status,
41
+ duration,
42
+ stages: job.name !== job.stage ? [
43
+ {
44
+ name: job.name,
45
+ status,
46
+ duration
47
+ }
48
+ ] : []
49
+ };
50
+ });
51
+ }
52
+
53
+ export { jobsToStages, pipelinesToBuilds };
54
+ //# sourceMappingURL=utils.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.esm.js","sources":["../../src/api/utils.ts"],"sourcesContent":["/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n Build,\n FilterStatusType,\n TriggerReason,\n Stage,\n} from '@backstage-community/plugin-cicd-statistics';\nimport { Types } from '@gitbeaker/core';\n\nconst statusMap: Record<string, FilterStatusType> = {\n manual: 'unknown',\n created: 'enqueued',\n waiting_for_resource: 'stalled',\n preparing: 'unknown',\n pending: 'scheduled',\n running: 'running',\n success: 'succeeded',\n failed: 'failed',\n canceled: 'aborted',\n skipped: 'aborted',\n scheduled: 'scheduled',\n};\n\n// all gitlab trigger reasons can be found here: https://docs.gitlab.com/ee/api/pipelines.html#list-project-pipelines\nconst triggerReasonMap: Record<string, TriggerReason> = {\n push: 'scm',\n trigger: 'manual',\n merge_request_event: 'scm',\n schedule: 'internal',\n};\n\n/**\n * Takes the Pipeline object from Gitlab and transforms it to the Build object\n *\n * @param pipelines - Pipeline object that gets returned from Gitlab\n *\n * @public\n */\nexport function pipelinesToBuilds(\n pipelines: Array<Types.PipelineSchema>,\n): Build[] {\n return pipelines.map(pipeline => {\n return {\n id: pipeline.id.toString(),\n status: statusMap[pipeline.status],\n branchType: 'master',\n duration: 0, // will get filled in later in a seperate API call\n requestedAt: new Date(pipeline.created_at),\n triggeredBy: triggerReasonMap[pipeline.source as string] ?? 'other',\n stages: [],\n };\n });\n}\n\n/**\n * Takes the Job object from Gitlab and transforms it to the Stage object\n *\n * @param jobs - Job object that gets returned from Gitlab\n *\n * @public\n *\n * @remarks\n *\n * The Gitlab API can only return the job (sub-stage) of a pipeline and not a whole stage\n * The job does return from which stage it is\n * So, for the stage name we use the parent stage name and in the sub-stages we add the current job\n * In the end the cicd-statistics plugin will calculate the right durations for each stage\n *\n * Furthermore, we don't add the job to the sub-stage if it is has the same name as the parent stage\n * We then assume that the stage has no sub-stages\n */\nexport function jobsToStages(jobs: Array<Types.JobSchema>): Stage[] {\n return jobs.map(job => {\n const status = statusMap[job.status] ? statusMap[job.status] : 'unknown';\n const duration = job.duration ? ((job.duration * 1000) as number) : 0;\n return {\n name: job.stage,\n status,\n duration,\n stages:\n job.name !== job.stage\n ? [\n {\n name: job.name,\n status,\n duration,\n },\n ]\n : [],\n };\n });\n}\n"],"names":[],"mappings":"AAwBA,MAAM,SAA8C,GAAA;AAAA,EAClD,MAAQ,EAAA,SAAA;AAAA,EACR,OAAS,EAAA,UAAA;AAAA,EACT,oBAAsB,EAAA,SAAA;AAAA,EACtB,SAAW,EAAA,SAAA;AAAA,EACX,OAAS,EAAA,WAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,WAAA;AAAA,EACT,MAAQ,EAAA,QAAA;AAAA,EACR,QAAU,EAAA,SAAA;AAAA,EACV,OAAS,EAAA,SAAA;AAAA,EACT,SAAW,EAAA,WAAA;AACb,CAAA,CAAA;AAGA,MAAM,gBAAkD,GAAA;AAAA,EACtD,IAAM,EAAA,KAAA;AAAA,EACN,OAAS,EAAA,QAAA;AAAA,EACT,mBAAqB,EAAA,KAAA;AAAA,EACrB,QAAU,EAAA,UAAA;AACZ,CAAA,CAAA;AASO,SAAS,kBACd,SACS,EAAA;AACT,EAAO,OAAA,SAAA,CAAU,IAAI,CAAY,QAAA,KAAA;AAC/B,IAAO,OAAA;AAAA,MACL,EAAA,EAAI,QAAS,CAAA,EAAA,CAAG,QAAS,EAAA;AAAA,MACzB,MAAA,EAAQ,SAAU,CAAA,QAAA,CAAS,MAAM,CAAA;AAAA,MACjC,UAAY,EAAA,QAAA;AAAA,MACZ,QAAU,EAAA,CAAA;AAAA;AAAA,MACV,WAAa,EAAA,IAAI,IAAK,CAAA,QAAA,CAAS,UAAU,CAAA;AAAA,MACzC,WAAa,EAAA,gBAAA,CAAiB,QAAS,CAAA,MAAgB,CAAK,IAAA,OAAA;AAAA,MAC5D,QAAQ,EAAC;AAAA,KACX,CAAA;AAAA,GACD,CAAA,CAAA;AACH,CAAA;AAmBO,SAAS,aAAa,IAAuC,EAAA;AAClE,EAAO,OAAA,IAAA,CAAK,IAAI,CAAO,GAAA,KAAA;AACrB,IAAM,MAAA,MAAA,GAAS,UAAU,GAAI,CAAA,MAAM,IAAI,SAAU,CAAA,GAAA,CAAI,MAAM,CAAI,GAAA,SAAA,CAAA;AAC/D,IAAA,MAAM,QAAW,GAAA,GAAA,CAAI,QAAa,GAAA,GAAA,CAAI,WAAW,GAAmB,GAAA,CAAA,CAAA;AACpE,IAAO,OAAA;AAAA,MACL,MAAM,GAAI,CAAA,KAAA;AAAA,MACV,MAAA;AAAA,MACA,QAAA;AAAA,MACA,MACE,EAAA,GAAA,CAAI,IAAS,KAAA,GAAA,CAAI,KACb,GAAA;AAAA,QACE;AAAA,UACE,MAAM,GAAI,CAAA,IAAA;AAAA,UACV,MAAA;AAAA,UACA,QAAA;AAAA,SACF;AAAA,UAEF,EAAC;AAAA,KACT,CAAA;AAAA,GACD,CAAA,CAAA;AACH;;;;"}
package/dist/index.esm.js CHANGED
@@ -1,171 +1,2 @@
1
- import { Gitlab } from '@gitbeaker/browser';
2
- import limiterFactory from 'p-limit';
3
- import { getEntitySourceLocation } from '@backstage/catalog-model';
4
-
5
- const statusMap = {
6
- manual: "unknown",
7
- created: "enqueued",
8
- waiting_for_resource: "stalled",
9
- preparing: "unknown",
10
- pending: "scheduled",
11
- running: "running",
12
- success: "succeeded",
13
- failed: "failed",
14
- canceled: "aborted",
15
- skipped: "aborted",
16
- scheduled: "scheduled"
17
- };
18
- const triggerReasonMap = {
19
- push: "scm",
20
- trigger: "manual",
21
- merge_request_event: "scm",
22
- schedule: "internal"
23
- };
24
- function pipelinesToBuilds(pipelines) {
25
- return pipelines.map((pipeline) => {
26
- var _a;
27
- return {
28
- id: pipeline.id.toString(),
29
- status: statusMap[pipeline.status],
30
- branchType: "master",
31
- duration: 0,
32
- // will get filled in later in a seperate API call
33
- requestedAt: new Date(pipeline.created_at),
34
- triggeredBy: (_a = triggerReasonMap[pipeline.source]) != null ? _a : "other",
35
- stages: []
36
- };
37
- });
38
- }
39
- function jobsToStages(jobs) {
40
- return jobs.map((job) => {
41
- const status = statusMap[job.status] ? statusMap[job.status] : "unknown";
42
- const duration = job.duration ? job.duration * 1e3 : 0;
43
- return {
44
- name: job.stage,
45
- status,
46
- duration,
47
- stages: job.name !== job.stage ? [
48
- {
49
- name: job.name,
50
- status,
51
- duration
52
- }
53
- ] : []
54
- };
55
- });
56
- }
57
-
58
- var __accessCheck = (obj, member, msg) => {
59
- if (!member.has(obj))
60
- throw TypeError("Cannot " + msg);
61
- };
62
- var __privateGet = (obj, member, getter) => {
63
- __accessCheck(obj, member, "read from private field");
64
- return getter ? getter.call(obj) : member.get(obj);
65
- };
66
- var __privateAdd = (obj, member, value) => {
67
- if (member.has(obj))
68
- throw TypeError("Cannot add the same private member more than once");
69
- member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
70
- };
71
- var __privateSet = (obj, member, value, setter) => {
72
- __accessCheck(obj, member, "write to private field");
73
- setter ? setter.call(obj, value) : member.set(obj, value);
74
- return value;
75
- };
76
- var _gitLabAuthApi, _cicdDefaults;
77
- const _CicdStatisticsApiGitlab = class _CicdStatisticsApiGitlab {
78
- constructor(gitLabAuthApi, cicdDefaults = {}) {
79
- __privateAdd(this, _gitLabAuthApi, void 0);
80
- __privateAdd(this, _cicdDefaults, void 0);
81
- __privateSet(this, _gitLabAuthApi, gitLabAuthApi);
82
- __privateSet(this, _cicdDefaults, cicdDefaults);
83
- }
84
- async createGitlabApi(entity, scopes) {
85
- const entityInfo = getEntitySourceLocation(entity);
86
- const url = new URL(entityInfo.target);
87
- const owner = url.pathname.split("/-/blob/")[0];
88
- const oauthToken = await __privateGet(this, _gitLabAuthApi).getAccessToken(scopes);
89
- return {
90
- api: new Gitlab({
91
- host: `https://${url.host}`,
92
- oauthToken
93
- }),
94
- owner: owner.substring(1)
95
- };
96
- }
97
- static async updateBuildWithStages(gitbeaker, owner, build) {
98
- const jobs = await gitbeaker.Jobs.showPipelineJobs(
99
- owner,
100
- parseInt(build.id, 10)
101
- );
102
- const stages = jobsToStages(jobs);
103
- return stages;
104
- }
105
- static async getDurationOfBuild(gitbeaker, owner, build) {
106
- const pipeline = await gitbeaker.Pipelines.show(
107
- owner,
108
- parseInt(build.id, 10)
109
- );
110
- return parseInt(pipeline.duration, 10) * 1e3;
111
- }
112
- static async getDefaultBranch(gitbeaker, owner) {
113
- var _a;
114
- const branches = await gitbeaker.Branches.all(owner);
115
- return (_a = branches.find((branch) => branch.default)) == null ? void 0 : _a.name;
116
- }
117
- async fetchBuilds(options) {
118
- const {
119
- entity,
120
- updateProgress,
121
- timeFrom,
122
- timeTo,
123
- filterStatus = ["all"],
124
- filterType = "all"
125
- } = options;
126
- const { api, owner } = await this.createGitlabApi(entity, ["read_api"]);
127
- updateProgress(0, 0, 0);
128
- const branch = filterType === "master" ? await _CicdStatisticsApiGitlab.getDefaultBranch(api, owner) : void 0;
129
- const pipelines = await api.Pipelines.all(owner, {
130
- perPage: 25,
131
- updated_after: timeFrom.toISOString(),
132
- updated_before: timeTo.toISOString(),
133
- ref: branch
134
- });
135
- const limiter = limiterFactory(10);
136
- const builds = pipelinesToBuilds(pipelines).map(async (build) => ({
137
- ...build,
138
- duration: await limiter(
139
- () => _CicdStatisticsApiGitlab.getDurationOfBuild(api, owner, build)
140
- ),
141
- stages: await limiter(
142
- () => _CicdStatisticsApiGitlab.updateBuildWithStages(api, owner, build)
143
- )
144
- }));
145
- const promisedBuilds = (await Promise.all(builds)).filter(
146
- (b) => filterStatus.includes(b.status)
147
- );
148
- return { builds: promisedBuilds };
149
- }
150
- async getConfiguration() {
151
- return {
152
- availableStatuses: [
153
- "succeeded",
154
- "failed",
155
- "enqueued",
156
- "running",
157
- "aborted",
158
- "stalled",
159
- "expired",
160
- "unknown"
161
- ],
162
- defaults: __privateGet(this, _cicdDefaults)
163
- };
164
- }
165
- };
166
- _gitLabAuthApi = new WeakMap();
167
- _cicdDefaults = new WeakMap();
168
- let CicdStatisticsApiGitlab = _CicdStatisticsApiGitlab;
169
-
170
- export { CicdStatisticsApiGitlab };
1
+ export { CicdStatisticsApiGitlab } from './api/gitlab.esm.js';
171
2
  //# sourceMappingURL=index.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.esm.js","sources":["../src/api/utils.ts","../src/api/gitlab.ts"],"sourcesContent":["/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n Build,\n FilterStatusType,\n TriggerReason,\n Stage,\n} from '@backstage-community/plugin-cicd-statistics';\nimport { Types } from '@gitbeaker/core';\n\nconst statusMap: Record<string, FilterStatusType> = {\n manual: 'unknown',\n created: 'enqueued',\n waiting_for_resource: 'stalled',\n preparing: 'unknown',\n pending: 'scheduled',\n running: 'running',\n success: 'succeeded',\n failed: 'failed',\n canceled: 'aborted',\n skipped: 'aborted',\n scheduled: 'scheduled',\n};\n\n// all gitlab trigger reasons can be found here: https://docs.gitlab.com/ee/api/pipelines.html#list-project-pipelines\nconst triggerReasonMap: Record<string, TriggerReason> = {\n push: 'scm',\n trigger: 'manual',\n merge_request_event: 'scm',\n schedule: 'internal',\n};\n\n/**\n * Takes the Pipeline object from Gitlab and transforms it to the Build object\n *\n * @param pipelines - Pipeline object that gets returned from Gitlab\n *\n * @public\n */\nexport function pipelinesToBuilds(\n pipelines: Array<Types.PipelineSchema>,\n): Build[] {\n return pipelines.map(pipeline => {\n return {\n id: pipeline.id.toString(),\n status: statusMap[pipeline.status],\n branchType: 'master',\n duration: 0, // will get filled in later in a seperate API call\n requestedAt: new Date(pipeline.created_at),\n triggeredBy: triggerReasonMap[pipeline.source as string] ?? 'other',\n stages: [],\n };\n });\n}\n\n/**\n * Takes the Job object from Gitlab and transforms it to the Stage object\n *\n * @param jobs - Job object that gets returned from Gitlab\n *\n * @public\n *\n * @remarks\n *\n * The Gitlab API can only return the job (sub-stage) of a pipeline and not a whole stage\n * The job does return from which stage it is\n * So, for the stage name we use the parent stage name and in the sub-stages we add the current job\n * In the end the cicd-statistics plugin will calculate the right durations for each stage\n *\n * Furthermore, we don't add the job to the sub-stage if it is has the same name as the parent stage\n * We then assume that the stage has no sub-stages\n */\nexport function jobsToStages(jobs: Array<Types.JobSchema>): Stage[] {\n return jobs.map(job => {\n const status = statusMap[job.status] ? statusMap[job.status] : 'unknown';\n const duration = job.duration ? ((job.duration * 1000) as number) : 0;\n return {\n name: job.stage,\n status,\n duration,\n stages:\n job.name !== job.stage\n ? [\n {\n name: job.name,\n status,\n duration,\n },\n ]\n : [],\n };\n });\n}\n","/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n CicdStatisticsApi,\n CicdState,\n CicdConfiguration,\n CicdDefaults,\n Build,\n FetchBuildsOptions,\n Stage,\n} from '@backstage-community/plugin-cicd-statistics';\nimport { Gitlab } from '@gitbeaker/browser';\nimport { OAuthApi } from '@backstage/core-plugin-api';\nimport limiterFactory from 'p-limit';\nimport { Entity, getEntitySourceLocation } from '@backstage/catalog-model';\nimport { pipelinesToBuilds, jobsToStages } from './utils';\n\n/**\n * This type represents a initialized gitlab client with gitbeaker\n *\n * @public\n */\nexport type GitlabClient = {\n /* the actual API of gitbeaker */\n api: InstanceType<typeof Gitlab>;\n /* the owner the repository, retrieved from the entity source location */\n owner: string;\n};\n\n/**\n * Extracts the CI/CD statistics from a Gitlab repository\n *\n * @public\n */\nexport class CicdStatisticsApiGitlab implements CicdStatisticsApi {\n readonly #gitLabAuthApi: OAuthApi;\n readonly #cicdDefaults: Partial<CicdDefaults>;\n\n constructor(\n gitLabAuthApi: OAuthApi,\n cicdDefaults: Partial<CicdDefaults> = {},\n ) {\n this.#gitLabAuthApi = gitLabAuthApi;\n this.#cicdDefaults = cicdDefaults;\n }\n\n public async createGitlabApi(\n entity: Entity,\n scopes: string[],\n ): Promise<GitlabClient> {\n const entityInfo = getEntitySourceLocation(entity);\n const url = new URL(entityInfo.target);\n const owner = url.pathname.split('/-/blob/')[0];\n const oauthToken = await this.#gitLabAuthApi.getAccessToken(scopes);\n return {\n api: new Gitlab({\n host: `https://${url.host}`,\n oauthToken,\n }),\n owner: owner.substring(1),\n };\n }\n\n private static async updateBuildWithStages(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n build: Build,\n ): Promise<Stage[]> {\n const jobs = await gitbeaker.Jobs.showPipelineJobs(\n owner,\n parseInt(build.id, 10),\n );\n const stages = jobsToStages(jobs);\n return stages;\n }\n\n private static async getDurationOfBuild(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n build: Build,\n ): Promise<number> {\n const pipeline = await gitbeaker.Pipelines.show(\n owner,\n parseInt(build.id, 10),\n );\n return parseInt(pipeline.duration as string, 10) * 1000;\n }\n\n private static async getDefaultBranch(\n gitbeaker: InstanceType<typeof Gitlab>,\n owner: string,\n ): Promise<string | undefined> {\n const branches = await gitbeaker.Branches.all(owner);\n return branches.find(branch => branch.default)?.name;\n }\n\n public async fetchBuilds(options: FetchBuildsOptions): Promise<CicdState> {\n const {\n entity,\n updateProgress,\n timeFrom,\n timeTo,\n filterStatus = ['all'],\n filterType = 'all',\n } = options;\n const { api, owner } = await this.createGitlabApi(entity, ['read_api']);\n updateProgress(0, 0, 0);\n\n const branch =\n filterType === 'master'\n ? await CicdStatisticsApiGitlab.getDefaultBranch(api, owner)\n : undefined;\n const pipelines = await api.Pipelines.all(owner, {\n perPage: 25,\n updated_after: timeFrom.toISOString(),\n updated_before: timeTo.toISOString(),\n ref: branch,\n });\n\n const limiter = limiterFactory(10);\n const builds = pipelinesToBuilds(pipelines).map(async build => ({\n ...build,\n duration: await limiter(() =>\n CicdStatisticsApiGitlab.getDurationOfBuild(api, owner, build),\n ),\n stages: await limiter(() =>\n CicdStatisticsApiGitlab.updateBuildWithStages(api, owner, build),\n ),\n }));\n const promisedBuilds = (await Promise.all(builds)).filter(b =>\n filterStatus.includes(b.status),\n );\n\n return { builds: promisedBuilds };\n }\n\n public async getConfiguration(): Promise<Partial<CicdConfiguration>> {\n return {\n availableStatuses: [\n 'succeeded',\n 'failed',\n 'enqueued',\n 'running',\n 'aborted',\n 'stalled',\n 'expired',\n 'unknown',\n ] as const,\n defaults: this.#cicdDefaults,\n };\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
package/package.json CHANGED
@@ -1,9 +1,11 @@
1
1
  {
2
2
  "name": "@backstage-community/plugin-cicd-statistics-module-gitlab",
3
- "version": "0.1.31",
3
+ "version": "0.1.32",
4
4
  "description": "CI/CD Statistics plugin module; Gitlab CICD",
5
5
  "backstage": {
6
- "role": "frontend-plugin-module"
6
+ "role": "frontend-plugin-module",
7
+ "pluginId": "cicd-statistics",
8
+ "pluginPackage": "@backstage-community/plugin-cicd-statistics"
7
9
  },
8
10
  "publishConfig": {
9
11
  "access": "public",
@@ -37,16 +39,16 @@
37
39
  "test": "backstage-cli package test"
38
40
  },
39
41
  "dependencies": {
40
- "@backstage-community/plugin-cicd-statistics": "^0.1.37",
41
- "@backstage/catalog-model": "^1.4.5",
42
- "@backstage/core-plugin-api": "^1.9.2",
42
+ "@backstage-community/plugin-cicd-statistics": "^0.1.38",
43
+ "@backstage/catalog-model": "^1.5.0",
44
+ "@backstage/core-plugin-api": "^1.9.3",
43
45
  "@gitbeaker/browser": "^35.6.0",
44
46
  "@gitbeaker/core": "^35.6.0",
45
47
  "luxon": "^3.0.0",
46
48
  "p-limit": "^3.1.0"
47
49
  },
48
50
  "devDependencies": {
49
- "@backstage/cli": "^0.26.3",
51
+ "@backstage/cli": "^0.26.11",
50
52
  "@types/react": "^16.13.1 || ^17.0.0",
51
53
  "@types/react-dom": "^18.2.19",
52
54
  "react": "^16.13.1 || ^17.0.0 || ^18.0.0",