@backstage/integration 1.11.0 → 1.12.0-next.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/CHANGELOG.md +12 -0
- package/dist/ScmIntegrations.esm.js +4 -10
- package/dist/ScmIntegrations.esm.js.map +1 -1
- package/dist/awsCodeCommit/AwsCodeCommitIntegration.esm.js +13 -21
- package/dist/awsCodeCommit/AwsCodeCommitIntegration.esm.js.map +1 -1
- package/dist/awsCodeCommit/config.esm.js +1 -2
- package/dist/awsCodeCommit/config.esm.js.map +1 -1
- package/dist/awsS3/AwsS3Integration.esm.js +11 -19
- package/dist/awsS3/AwsS3Integration.esm.js.map +1 -1
- package/dist/awsS3/config.esm.js +2 -3
- package/dist/awsS3/config.esm.js.map +1 -1
- package/dist/azure/AzureIntegration.esm.js +12 -21
- package/dist/azure/AzureIntegration.esm.js.map +1 -1
- package/dist/azure/AzureUrl.esm.js +72 -76
- package/dist/azure/AzureUrl.esm.js.map +1 -1
- package/dist/azure/CachedAzureDevOpsCredentialsProvider.esm.js +2 -8
- package/dist/azure/CachedAzureDevOpsCredentialsProvider.esm.js.map +1 -1
- package/dist/azure/DefaultAzureDevOpsCredentialsProvider.esm.js +3 -6
- package/dist/azure/DefaultAzureDevOpsCredentialsProvider.esm.js.map +1 -1
- package/dist/azure/config.esm.js +12 -15
- package/dist/azure/config.esm.js.map +1 -1
- package/dist/azure/deprecated.esm.js +2 -3
- package/dist/azure/deprecated.esm.js.map +1 -1
- package/dist/bitbucket/BitbucketIntegration.esm.js +19 -27
- package/dist/bitbucket/BitbucketIntegration.esm.js.map +1 -1
- package/dist/bitbucket/config.esm.js +3 -4
- package/dist/bitbucket/config.esm.js.map +1 -1
- package/dist/bitbucketCloud/BitbucketCloudIntegration.esm.js +13 -21
- package/dist/bitbucketCloud/BitbucketCloudIntegration.esm.js.map +1 -1
- package/dist/bitbucketCloud/config.esm.js +1 -2
- package/dist/bitbucketCloud/config.esm.js.map +1 -1
- package/dist/bitbucketServer/BitbucketServerIntegration.esm.js +13 -21
- package/dist/bitbucketServer/BitbucketServerIntegration.esm.js.map +1 -1
- package/dist/bitbucketServer/config.esm.js +1 -2
- package/dist/bitbucketServer/config.esm.js.map +1 -1
- package/dist/gerrit/GerritIntegration.esm.js +11 -19
- package/dist/gerrit/GerritIntegration.esm.js.map +1 -1
- package/dist/gerrit/config.esm.js +1 -2
- package/dist/gerrit/config.esm.js.map +1 -1
- package/dist/gitea/GiteaIntegration.esm.js +10 -18
- package/dist/gitea/GiteaIntegration.esm.js.map +1 -1
- package/dist/gitea/config.esm.js +1 -2
- package/dist/gitea/config.esm.js.map +1 -1
- package/dist/gitea/core.esm.js +1 -2
- package/dist/gitea/core.esm.js.map +1 -1
- package/dist/github/GithubIntegration.esm.js +11 -19
- package/dist/github/GithubIntegration.esm.js.map +1 -1
- package/dist/github/SingleInstanceGithubCredentialsProvider.esm.js +22 -40
- package/dist/github/SingleInstanceGithubCredentialsProvider.esm.js.map +1 -1
- package/dist/github/config.esm.js +3 -4
- package/dist/github/config.esm.js.map +1 -1
- package/dist/github/deprecated.esm.js +1 -7
- package/dist/github/deprecated.esm.js.map +1 -1
- package/dist/gitlab/GitLabIntegration.esm.js +11 -19
- package/dist/gitlab/GitLabIntegration.esm.js.map +1 -1
- package/dist/gitlab/SingleInstanceGitlabCredentialsProvider.esm.js +5 -12
- package/dist/gitlab/SingleInstanceGitlabCredentialsProvider.esm.js.map +1 -1
- package/dist/gitlab/config.esm.js +1 -2
- package/dist/gitlab/config.esm.js.map +1 -1
- package/dist/harness/HarnessIntegration.esm.js +10 -18
- package/dist/harness/HarnessIntegration.esm.js.map +1 -1
- package/dist/harness/core.esm.js +48 -46
- package/dist/harness/core.esm.js.map +1 -1
- package/dist/index.cjs.js +323 -471
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.d.ts +50 -2
- package/dist/index.esm.js +1 -1
- package/package.json +2 -2
|
@@ -1,50 +1,11 @@
|
|
|
1
|
-
var __accessCheck = (obj, member, msg) => {
|
|
2
|
-
if (!member.has(obj))
|
|
3
|
-
throw TypeError("Cannot " + msg);
|
|
4
|
-
};
|
|
5
|
-
var __privateGet = (obj, member, getter) => {
|
|
6
|
-
__accessCheck(obj, member, "read from private field");
|
|
7
|
-
return member.get(obj);
|
|
8
|
-
};
|
|
9
|
-
var __privateAdd = (obj, member, value) => {
|
|
10
|
-
if (member.has(obj))
|
|
11
|
-
throw TypeError("Cannot add the same private member more than once");
|
|
12
|
-
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
13
|
-
};
|
|
14
|
-
var __privateSet = (obj, member, value, setter) => {
|
|
15
|
-
__accessCheck(obj, member, "write to private field");
|
|
16
|
-
member.set(obj, value);
|
|
17
|
-
return value;
|
|
18
|
-
};
|
|
19
|
-
var _origin, _owner, _project, _repo, _path, _ref, _baseUrl;
|
|
20
1
|
const VERSION_PREFIX_GIT_BRANCH = "GB";
|
|
21
|
-
|
|
22
|
-
constructor(origin, owner, project, repo, path, ref) {
|
|
23
|
-
__privateAdd(this, _origin, void 0);
|
|
24
|
-
__privateAdd(this, _owner, void 0);
|
|
25
|
-
__privateAdd(this, _project, void 0);
|
|
26
|
-
__privateAdd(this, _repo, void 0);
|
|
27
|
-
__privateAdd(this, _path, void 0);
|
|
28
|
-
__privateAdd(this, _ref, void 0);
|
|
29
|
-
__privateAdd(this, _baseUrl, (...parts) => {
|
|
30
|
-
const url = new URL(__privateGet(this, _origin));
|
|
31
|
-
url.pathname = parts.map((part) => encodeURIComponent(part)).join("/");
|
|
32
|
-
return url;
|
|
33
|
-
});
|
|
34
|
-
__privateSet(this, _origin, origin);
|
|
35
|
-
__privateSet(this, _owner, owner);
|
|
36
|
-
__privateSet(this, _project, project);
|
|
37
|
-
__privateSet(this, _repo, repo);
|
|
38
|
-
__privateSet(this, _path, path);
|
|
39
|
-
__privateSet(this, _ref, ref);
|
|
40
|
-
}
|
|
2
|
+
class AzureUrl {
|
|
41
3
|
/**
|
|
42
4
|
* Parses an azure URL as copied from the browser address bar.
|
|
43
5
|
*
|
|
44
6
|
* Throws an error if the URL is not a valid azure repo URL.
|
|
45
7
|
*/
|
|
46
8
|
static fromRepoUrl(repoUrl) {
|
|
47
|
-
var _a;
|
|
48
9
|
const url = new URL(repoUrl);
|
|
49
10
|
let owner;
|
|
50
11
|
let project;
|
|
@@ -65,7 +26,7 @@ const _AzureUrl = class _AzureUrl {
|
|
|
65
26
|
if (!owner || !project || !repo) {
|
|
66
27
|
throw new Error("Azure URL must point to a git repository");
|
|
67
28
|
}
|
|
68
|
-
const path =
|
|
29
|
+
const path = url.searchParams.get("path") ?? void 0;
|
|
69
30
|
let ref;
|
|
70
31
|
const version = url.searchParams.get("version");
|
|
71
32
|
if (version) {
|
|
@@ -75,8 +36,27 @@ const _AzureUrl = class _AzureUrl {
|
|
|
75
36
|
}
|
|
76
37
|
ref = version.slice(2);
|
|
77
38
|
}
|
|
78
|
-
return new
|
|
39
|
+
return new AzureUrl(url.origin, owner, project, repo, path, ref);
|
|
40
|
+
}
|
|
41
|
+
#origin;
|
|
42
|
+
#owner;
|
|
43
|
+
#project;
|
|
44
|
+
#repo;
|
|
45
|
+
#path;
|
|
46
|
+
#ref;
|
|
47
|
+
constructor(origin, owner, project, repo, path, ref) {
|
|
48
|
+
this.#origin = origin;
|
|
49
|
+
this.#owner = owner;
|
|
50
|
+
this.#project = project;
|
|
51
|
+
this.#repo = repo;
|
|
52
|
+
this.#path = path;
|
|
53
|
+
this.#ref = ref;
|
|
79
54
|
}
|
|
55
|
+
#baseUrl = (...parts) => {
|
|
56
|
+
const url = new URL(this.#origin);
|
|
57
|
+
url.pathname = parts.map((part) => encodeURIComponent(part)).join("/");
|
|
58
|
+
return url;
|
|
59
|
+
};
|
|
80
60
|
/**
|
|
81
61
|
* Returns a repo URL that can be used to navigate to the resource in azure.
|
|
82
62
|
*
|
|
@@ -84,16 +64,16 @@ const _AzureUrl = class _AzureUrl {
|
|
|
84
64
|
*/
|
|
85
65
|
toRepoUrl() {
|
|
86
66
|
let url;
|
|
87
|
-
if (
|
|
88
|
-
url =
|
|
67
|
+
if (this.#project === this.#repo) {
|
|
68
|
+
url = this.#baseUrl(this.#owner, "_git", this.#repo);
|
|
89
69
|
} else {
|
|
90
|
-
url =
|
|
70
|
+
url = this.#baseUrl(this.#owner, this.#project, "_git", this.#repo);
|
|
91
71
|
}
|
|
92
|
-
if (
|
|
93
|
-
url.searchParams.set("path",
|
|
72
|
+
if (this.#path) {
|
|
73
|
+
url.searchParams.set("path", this.#path);
|
|
94
74
|
}
|
|
95
|
-
if (
|
|
96
|
-
url.searchParams.set("version", VERSION_PREFIX_GIT_BRANCH +
|
|
75
|
+
if (this.#ref) {
|
|
76
|
+
url.searchParams.set("version", VERSION_PREFIX_GIT_BRANCH + this.#ref);
|
|
97
77
|
}
|
|
98
78
|
return url.toString();
|
|
99
79
|
}
|
|
@@ -103,16 +83,24 @@ const _AzureUrl = class _AzureUrl {
|
|
|
103
83
|
* Throws an error if the URL does not point to a file.
|
|
104
84
|
*/
|
|
105
85
|
toFileUrl() {
|
|
106
|
-
if (!
|
|
86
|
+
if (!this.#path) {
|
|
107
87
|
throw new Error(
|
|
108
88
|
"Azure URL must point to a specific path to be able to download a file"
|
|
109
89
|
);
|
|
110
90
|
}
|
|
111
|
-
const url =
|
|
91
|
+
const url = this.#baseUrl(
|
|
92
|
+
this.#owner,
|
|
93
|
+
this.#project,
|
|
94
|
+
"_apis",
|
|
95
|
+
"git",
|
|
96
|
+
"repositories",
|
|
97
|
+
this.#repo,
|
|
98
|
+
"items"
|
|
99
|
+
);
|
|
112
100
|
url.searchParams.set("api-version", "6.0");
|
|
113
|
-
url.searchParams.set("path",
|
|
114
|
-
if (
|
|
115
|
-
url.searchParams.set("version",
|
|
101
|
+
url.searchParams.set("path", this.#path);
|
|
102
|
+
if (this.#ref) {
|
|
103
|
+
url.searchParams.set("version", this.#ref);
|
|
116
104
|
}
|
|
117
105
|
return url.toString();
|
|
118
106
|
}
|
|
@@ -122,15 +110,23 @@ const _AzureUrl = class _AzureUrl {
|
|
|
122
110
|
* Throws an error if the URL does not point to a repo.
|
|
123
111
|
*/
|
|
124
112
|
toArchiveUrl() {
|
|
125
|
-
const url =
|
|
113
|
+
const url = this.#baseUrl(
|
|
114
|
+
this.#owner,
|
|
115
|
+
this.#project,
|
|
116
|
+
"_apis",
|
|
117
|
+
"git",
|
|
118
|
+
"repositories",
|
|
119
|
+
this.#repo,
|
|
120
|
+
"items"
|
|
121
|
+
);
|
|
126
122
|
url.searchParams.set("recursionLevel", "full");
|
|
127
123
|
url.searchParams.set("download", "true");
|
|
128
124
|
url.searchParams.set("api-version", "6.0");
|
|
129
|
-
if (
|
|
130
|
-
url.searchParams.set("scopePath",
|
|
125
|
+
if (this.#path) {
|
|
126
|
+
url.searchParams.set("scopePath", this.#path);
|
|
131
127
|
}
|
|
132
|
-
if (
|
|
133
|
-
url.searchParams.set("version",
|
|
128
|
+
if (this.#ref) {
|
|
129
|
+
url.searchParams.set("version", this.#ref);
|
|
134
130
|
}
|
|
135
131
|
return url.toString();
|
|
136
132
|
}
|
|
@@ -140,10 +136,18 @@ const _AzureUrl = class _AzureUrl {
|
|
|
140
136
|
* Throws an error if the URL does not point to a commit.
|
|
141
137
|
*/
|
|
142
138
|
toCommitsUrl() {
|
|
143
|
-
const url =
|
|
139
|
+
const url = this.#baseUrl(
|
|
140
|
+
this.#owner,
|
|
141
|
+
this.#project,
|
|
142
|
+
"_apis",
|
|
143
|
+
"git",
|
|
144
|
+
"repositories",
|
|
145
|
+
this.#repo,
|
|
146
|
+
"commits"
|
|
147
|
+
);
|
|
144
148
|
url.searchParams.set("api-version", "6.0");
|
|
145
|
-
if (
|
|
146
|
-
url.searchParams.set("searchCriteria.itemVersion.version",
|
|
149
|
+
if (this.#ref) {
|
|
150
|
+
url.searchParams.set("searchCriteria.itemVersion.version", this.#ref);
|
|
147
151
|
}
|
|
148
152
|
return url.toString();
|
|
149
153
|
}
|
|
@@ -151,41 +155,33 @@ const _AzureUrl = class _AzureUrl {
|
|
|
151
155
|
* Returns the name of the owner, a user or an organization.
|
|
152
156
|
*/
|
|
153
157
|
getOwner() {
|
|
154
|
-
return
|
|
158
|
+
return this.#owner;
|
|
155
159
|
}
|
|
156
160
|
/**
|
|
157
161
|
* Returns the name of the project.
|
|
158
162
|
*/
|
|
159
163
|
getProject() {
|
|
160
|
-
return
|
|
164
|
+
return this.#project;
|
|
161
165
|
}
|
|
162
166
|
/**
|
|
163
167
|
* Returns the name of the repo.
|
|
164
168
|
*/
|
|
165
169
|
getRepo() {
|
|
166
|
-
return
|
|
170
|
+
return this.#repo;
|
|
167
171
|
}
|
|
168
172
|
/**
|
|
169
173
|
* Returns the file path within the repo if the URL contains one.
|
|
170
174
|
*/
|
|
171
175
|
getPath() {
|
|
172
|
-
return
|
|
176
|
+
return this.#path;
|
|
173
177
|
}
|
|
174
178
|
/**
|
|
175
179
|
* Returns the git ref in the repo if the URL contains one.
|
|
176
180
|
*/
|
|
177
181
|
getRef() {
|
|
178
|
-
return
|
|
182
|
+
return this.#ref;
|
|
179
183
|
}
|
|
180
|
-
}
|
|
181
|
-
_origin = new WeakMap();
|
|
182
|
-
_owner = new WeakMap();
|
|
183
|
-
_project = new WeakMap();
|
|
184
|
-
_repo = new WeakMap();
|
|
185
|
-
_path = new WeakMap();
|
|
186
|
-
_ref = new WeakMap();
|
|
187
|
-
_baseUrl = new WeakMap();
|
|
188
|
-
let AzureUrl = _AzureUrl;
|
|
184
|
+
}
|
|
189
185
|
|
|
190
186
|
export { AzureUrl };
|
|
191
187
|
//# sourceMappingURL=AzureUrl.esm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AzureUrl.esm.js","sources":["../../src/azure/AzureUrl.ts"],"sourcesContent":["/*\n * Copyright 2021 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\nconst VERSION_PREFIX_GIT_BRANCH = 'GB';\n\nexport class AzureUrl {\n /**\n * Parses an azure URL as copied from the browser address bar.\n *\n * Throws an error if the URL is not a valid azure repo URL.\n */\n static fromRepoUrl(repoUrl: string): AzureUrl {\n const url = new URL(repoUrl);\n\n let owner;\n let project;\n let repo;\n\n const parts = url.pathname.split('/').map(part => decodeURIComponent(part));\n if (parts[2] === '_git') {\n owner = parts[1];\n project = repo = parts[3];\n } else if (parts[3] === '_git') {\n owner = parts[1];\n project = parts[2];\n repo = parts[4];\n } else if (parts[4] === '_git') {\n owner = `${parts[1]}/${parts[2]}`;\n project = parts[3];\n repo = parts[5];\n }\n\n if (!owner || !project || !repo) {\n throw new Error('Azure URL must point to a git repository');\n }\n\n const path = url.searchParams.get('path') ?? undefined;\n\n let ref;\n const version = url.searchParams.get('version');\n if (version) {\n const prefix = version.slice(0, 2);\n if (prefix !== 'GB') {\n throw new Error('Azure URL version must point to a git branch');\n }\n ref = version.slice(2);\n }\n\n return new AzureUrl(url.origin, owner, project, repo, path, ref);\n }\n\n #origin: string;\n #owner: string;\n #project: string;\n #repo: string;\n #path?: string;\n #ref?: string;\n\n private constructor(\n origin: string,\n owner: string,\n project: string,\n repo: string,\n path?: string,\n ref?: string,\n ) {\n this.#origin = origin;\n this.#owner = owner;\n this.#project = project;\n this.#repo = repo;\n this.#path = path;\n this.#ref = ref;\n }\n\n #baseUrl = (...parts: string[]): URL => {\n const url = new URL(this.#origin);\n url.pathname = parts.map(part => encodeURIComponent(part)).join('/');\n return url;\n };\n\n /**\n * Returns a repo URL that can be used to navigate to the resource in azure.\n *\n * Throws an error if the URL is not a valid azure repo URL.\n */\n toRepoUrl(): string {\n let url;\n if (this.#project === this.#repo) {\n url = this.#baseUrl(this.#owner, '_git', this.#repo);\n } else {\n url = this.#baseUrl(this.#owner, this.#project, '_git', this.#repo);\n }\n\n if (this.#path) {\n url.searchParams.set('path', this.#path);\n }\n if (this.#ref) {\n url.searchParams.set('version', VERSION_PREFIX_GIT_BRANCH + this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the file download URL for this azure resource.\n *\n * Throws an error if the URL does not point to a file.\n */\n toFileUrl(): string {\n if (!this.#path) {\n throw new Error(\n 'Azure URL must point to a specific path to be able to download a file',\n );\n }\n\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'items',\n );\n url.searchParams.set('api-version', '6.0');\n url.searchParams.set('path', this.#path);\n\n if (this.#ref) {\n url.searchParams.set('version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the archive download URL for this azure resource.\n *\n * Throws an error if the URL does not point to a repo.\n */\n toArchiveUrl(): string {\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'items',\n );\n url.searchParams.set('recursionLevel', 'full');\n url.searchParams.set('download', 'true');\n url.searchParams.set('api-version', '6.0');\n\n if (this.#path) {\n url.searchParams.set('scopePath', this.#path);\n }\n if (this.#ref) {\n url.searchParams.set('version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the API url for fetching commits from a branch for this azure resource.\n *\n * Throws an error if the URL does not point to a commit.\n */\n toCommitsUrl(): string {\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'commits',\n );\n url.searchParams.set('api-version', '6.0');\n\n if (this.#ref) {\n url.searchParams.set('searchCriteria.itemVersion.version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the name of the owner, a user or an organization.\n */\n getOwner(): string {\n return this.#owner;\n }\n\n /**\n * Returns the name of the project.\n */\n getProject(): string {\n return this.#project;\n }\n\n /**\n * Returns the name of the repo.\n */\n getRepo(): string {\n return this.#repo;\n }\n\n /**\n * Returns the file path within the repo if the URL contains one.\n */\n getPath(): string | undefined {\n return this.#path;\n }\n\n /**\n * Returns the git ref in the repo if the URL contains one.\n */\n getRef(): string | undefined {\n return this.#ref;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"AzureUrl.esm.js","sources":["../../src/azure/AzureUrl.ts"],"sourcesContent":["/*\n * Copyright 2021 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\nconst VERSION_PREFIX_GIT_BRANCH = 'GB';\n\nexport class AzureUrl {\n /**\n * Parses an azure URL as copied from the browser address bar.\n *\n * Throws an error if the URL is not a valid azure repo URL.\n */\n static fromRepoUrl(repoUrl: string): AzureUrl {\n const url = new URL(repoUrl);\n\n let owner;\n let project;\n let repo;\n\n const parts = url.pathname.split('/').map(part => decodeURIComponent(part));\n if (parts[2] === '_git') {\n owner = parts[1];\n project = repo = parts[3];\n } else if (parts[3] === '_git') {\n owner = parts[1];\n project = parts[2];\n repo = parts[4];\n } else if (parts[4] === '_git') {\n owner = `${parts[1]}/${parts[2]}`;\n project = parts[3];\n repo = parts[5];\n }\n\n if (!owner || !project || !repo) {\n throw new Error('Azure URL must point to a git repository');\n }\n\n const path = url.searchParams.get('path') ?? undefined;\n\n let ref;\n const version = url.searchParams.get('version');\n if (version) {\n const prefix = version.slice(0, 2);\n if (prefix !== 'GB') {\n throw new Error('Azure URL version must point to a git branch');\n }\n ref = version.slice(2);\n }\n\n return new AzureUrl(url.origin, owner, project, repo, path, ref);\n }\n\n #origin: string;\n #owner: string;\n #project: string;\n #repo: string;\n #path?: string;\n #ref?: string;\n\n private constructor(\n origin: string,\n owner: string,\n project: string,\n repo: string,\n path?: string,\n ref?: string,\n ) {\n this.#origin = origin;\n this.#owner = owner;\n this.#project = project;\n this.#repo = repo;\n this.#path = path;\n this.#ref = ref;\n }\n\n #baseUrl = (...parts: string[]): URL => {\n const url = new URL(this.#origin);\n url.pathname = parts.map(part => encodeURIComponent(part)).join('/');\n return url;\n };\n\n /**\n * Returns a repo URL that can be used to navigate to the resource in azure.\n *\n * Throws an error if the URL is not a valid azure repo URL.\n */\n toRepoUrl(): string {\n let url;\n if (this.#project === this.#repo) {\n url = this.#baseUrl(this.#owner, '_git', this.#repo);\n } else {\n url = this.#baseUrl(this.#owner, this.#project, '_git', this.#repo);\n }\n\n if (this.#path) {\n url.searchParams.set('path', this.#path);\n }\n if (this.#ref) {\n url.searchParams.set('version', VERSION_PREFIX_GIT_BRANCH + this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the file download URL for this azure resource.\n *\n * Throws an error if the URL does not point to a file.\n */\n toFileUrl(): string {\n if (!this.#path) {\n throw new Error(\n 'Azure URL must point to a specific path to be able to download a file',\n );\n }\n\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'items',\n );\n url.searchParams.set('api-version', '6.0');\n url.searchParams.set('path', this.#path);\n\n if (this.#ref) {\n url.searchParams.set('version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the archive download URL for this azure resource.\n *\n * Throws an error if the URL does not point to a repo.\n */\n toArchiveUrl(): string {\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'items',\n );\n url.searchParams.set('recursionLevel', 'full');\n url.searchParams.set('download', 'true');\n url.searchParams.set('api-version', '6.0');\n\n if (this.#path) {\n url.searchParams.set('scopePath', this.#path);\n }\n if (this.#ref) {\n url.searchParams.set('version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the API url for fetching commits from a branch for this azure resource.\n *\n * Throws an error if the URL does not point to a commit.\n */\n toCommitsUrl(): string {\n const url = this.#baseUrl(\n this.#owner,\n this.#project,\n '_apis',\n 'git',\n 'repositories',\n this.#repo,\n 'commits',\n );\n url.searchParams.set('api-version', '6.0');\n\n if (this.#ref) {\n url.searchParams.set('searchCriteria.itemVersion.version', this.#ref);\n }\n\n return url.toString();\n }\n\n /**\n * Returns the name of the owner, a user or an organization.\n */\n getOwner(): string {\n return this.#owner;\n }\n\n /**\n * Returns the name of the project.\n */\n getProject(): string {\n return this.#project;\n }\n\n /**\n * Returns the name of the repo.\n */\n getRepo(): string {\n return this.#repo;\n }\n\n /**\n * Returns the file path within the repo if the URL contains one.\n */\n getPath(): string | undefined {\n return this.#path;\n }\n\n /**\n * Returns the git ref in the repo if the URL contains one.\n */\n getRef(): string | undefined {\n return this.#ref;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +1,12 @@
|
|
|
1
1
|
import { ManagedIdentityCredential, ClientSecretCredential } from '@azure/identity';
|
|
2
2
|
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
|
-
var __publicField = (obj, key, value) => {
|
|
6
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
7
|
-
return value;
|
|
8
|
-
};
|
|
9
3
|
const tenMinutes = 1e3 * 60 * 10;
|
|
10
4
|
class CachedAzureDevOpsCredentialsProvider {
|
|
11
5
|
constructor(credential) {
|
|
12
6
|
this.credential = credential;
|
|
13
|
-
__publicField(this, "azureDevOpsScope", "499b84ac-1321-427f-aa17-267ca6975798/.default");
|
|
14
|
-
__publicField(this, "cached");
|
|
15
7
|
}
|
|
8
|
+
azureDevOpsScope = "499b84ac-1321-427f-aa17-267ca6975798/.default";
|
|
9
|
+
cached;
|
|
16
10
|
static fromAzureDevOpsCredential(credential) {
|
|
17
11
|
switch (credential.kind) {
|
|
18
12
|
case "PersonalAccessToken":
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CachedAzureDevOpsCredentialsProvider.esm.js","sources":["../../src/azure/CachedAzureDevOpsCredentialsProvider.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport { AzureDevOpsCredential, PersonalAccessTokenCredential } from './config';\nimport {\n ClientSecretCredential,\n ManagedIdentityCredential,\n TokenCredential,\n} from '@azure/identity';\nimport {\n AzureDevOpsCredentials,\n AzureDevOpsCredentialsProvider,\n} from './types';\n\ntype CachedAzureDevOpsCredentials = AzureDevOpsCredentials & {\n expiresAt?: number;\n};\n\nfunction exhaustiveCheck(_param: never) {}\n\nconst tenMinutes = 1000 * 60 * 10;\n\n/**\n * A credentials provider that caches the credentials for as long as it is valid.\n *\n * @public\n */\nexport class CachedAzureDevOpsCredentialsProvider\n implements AzureDevOpsCredentialsProvider\n{\n azureDevOpsScope = '499b84ac-1321-427f-aa17-267ca6975798/.default';\n cached: CachedAzureDevOpsCredentials | undefined;\n\n static fromAzureDevOpsCredential(\n credential: AzureDevOpsCredential,\n ): CachedAzureDevOpsCredentialsProvider {\n switch (credential.kind) {\n case 'PersonalAccessToken':\n return CachedAzureDevOpsCredentialsProvider.fromPersonalAccessTokenCredential(\n credential,\n );\n case 'ClientSecret':\n return CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new ClientSecretCredential(\n credential.tenantId,\n credential.clientId,\n credential.clientSecret,\n ),\n );\n case 'ManagedIdentity':\n return CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new ManagedIdentityCredential(credential.clientId),\n );\n default:\n exhaustiveCheck(credential);\n\n throw new Error(\n `Credential kind '${(credential as any).kind}' not supported`,\n );\n }\n }\n\n static fromTokenCredential(\n credential: TokenCredential,\n ): CachedAzureDevOpsCredentialsProvider {\n return new CachedAzureDevOpsCredentialsProvider(credential);\n }\n\n static fromPersonalAccessTokenCredential(\n credential: PersonalAccessTokenCredential,\n ) {\n return new CachedAzureDevOpsCredentialsProvider(\n credential.personalAccessToken,\n );\n }\n\n private constructor(private readonly credential: TokenCredential | string) {}\n\n async getCredentials(): Promise<AzureDevOpsCredentials> {\n if (\n this.cached === undefined ||\n (this.cached.expiresAt !== undefined &&\n Date.now() > this.cached.expiresAt)\n ) {\n if (typeof this.credential === 'string') {\n this.cached = {\n headers: {\n Authorization: `Basic ${btoa(`:${this.credential}`)}`,\n },\n type: 'pat',\n token: this.credential,\n };\n } else {\n const accessToken = await this.credential.getToken(\n this.azureDevOpsScope,\n );\n\n if (!accessToken) {\n throw new Error('Failed to retrieve access token');\n }\n\n this.cached = {\n expiresAt: accessToken.expiresOnTimestamp - tenMinutes,\n headers: {\n Authorization: `Bearer ${accessToken.token}`,\n },\n type: 'bearer',\n token: accessToken.token,\n };\n }\n }\n\n return this.cached;\n }\n}\n"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CachedAzureDevOpsCredentialsProvider.esm.js","sources":["../../src/azure/CachedAzureDevOpsCredentialsProvider.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport { AzureDevOpsCredential, PersonalAccessTokenCredential } from './config';\nimport {\n ClientSecretCredential,\n ManagedIdentityCredential,\n TokenCredential,\n} from '@azure/identity';\nimport {\n AzureDevOpsCredentials,\n AzureDevOpsCredentialsProvider,\n} from './types';\n\ntype CachedAzureDevOpsCredentials = AzureDevOpsCredentials & {\n expiresAt?: number;\n};\n\nfunction exhaustiveCheck(_param: never) {}\n\nconst tenMinutes = 1000 * 60 * 10;\n\n/**\n * A credentials provider that caches the credentials for as long as it is valid.\n *\n * @public\n */\nexport class CachedAzureDevOpsCredentialsProvider\n implements AzureDevOpsCredentialsProvider\n{\n azureDevOpsScope = '499b84ac-1321-427f-aa17-267ca6975798/.default';\n cached: CachedAzureDevOpsCredentials | undefined;\n\n static fromAzureDevOpsCredential(\n credential: AzureDevOpsCredential,\n ): CachedAzureDevOpsCredentialsProvider {\n switch (credential.kind) {\n case 'PersonalAccessToken':\n return CachedAzureDevOpsCredentialsProvider.fromPersonalAccessTokenCredential(\n credential,\n );\n case 'ClientSecret':\n return CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new ClientSecretCredential(\n credential.tenantId,\n credential.clientId,\n credential.clientSecret,\n ),\n );\n case 'ManagedIdentity':\n return CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new ManagedIdentityCredential(credential.clientId),\n );\n default:\n exhaustiveCheck(credential);\n\n throw new Error(\n `Credential kind '${(credential as any).kind}' not supported`,\n );\n }\n }\n\n static fromTokenCredential(\n credential: TokenCredential,\n ): CachedAzureDevOpsCredentialsProvider {\n return new CachedAzureDevOpsCredentialsProvider(credential);\n }\n\n static fromPersonalAccessTokenCredential(\n credential: PersonalAccessTokenCredential,\n ) {\n return new CachedAzureDevOpsCredentialsProvider(\n credential.personalAccessToken,\n );\n }\n\n private constructor(private readonly credential: TokenCredential | string) {}\n\n async getCredentials(): Promise<AzureDevOpsCredentials> {\n if (\n this.cached === undefined ||\n (this.cached.expiresAt !== undefined &&\n Date.now() > this.cached.expiresAt)\n ) {\n if (typeof this.credential === 'string') {\n this.cached = {\n headers: {\n Authorization: `Basic ${btoa(`:${this.credential}`)}`,\n },\n type: 'pat',\n token: this.credential,\n };\n } else {\n const accessToken = await this.credential.getToken(\n this.azureDevOpsScope,\n );\n\n if (!accessToken) {\n throw new Error('Failed to retrieve access token');\n }\n\n this.cached = {\n expiresAt: accessToken.expiresOnTimestamp - tenMinutes,\n headers: {\n Authorization: `Bearer ${accessToken.token}`,\n },\n type: 'bearer',\n token: accessToken.token,\n };\n }\n }\n\n return this.cached;\n }\n}\n"],"names":[],"mappings":";;AAgCA,MAAM,UAAA,GAAa,MAAO,EAAK,GAAA,EAAA,CAAA;AAOxB,MAAM,oCAEb,CAAA;AAAA,EA+CU,YAA6B,UAAsC,EAAA;AAAtC,IAAA,IAAA,CAAA,UAAA,GAAA,UAAA,CAAA;AAAA,GAAuC;AAAA,EA9C5E,gBAAmB,GAAA,+CAAA,CAAA;AAAA,EACnB,MAAA,CAAA;AAAA,EAEA,OAAO,0BACL,UACsC,EAAA;AACtC,IAAA,QAAQ,WAAW,IAAM;AAAA,MACvB,KAAK,qBAAA;AACH,QAAA,OAAO,oCAAqC,CAAA,iCAAA;AAAA,UAC1C,UAAA;AAAA,SACF,CAAA;AAAA,MACF,KAAK,cAAA;AACH,QAAA,OAAO,oCAAqC,CAAA,mBAAA;AAAA,UAC1C,IAAI,sBAAA;AAAA,YACF,UAAW,CAAA,QAAA;AAAA,YACX,UAAW,CAAA,QAAA;AAAA,YACX,UAAW,CAAA,YAAA;AAAA,WACb;AAAA,SACF,CAAA;AAAA,MACF,KAAK,iBAAA;AACH,QAAA,OAAO,oCAAqC,CAAA,mBAAA;AAAA,UAC1C,IAAI,yBAA0B,CAAA,UAAA,CAAW,QAAQ,CAAA;AAAA,SACnD,CAAA;AAAA,MACF;AAGE,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,CAAA,iBAAA,EAAqB,WAAmB,IAAI,CAAA,eAAA,CAAA;AAAA,SAC9C,CAAA;AAAA,KACJ;AAAA,GACF;AAAA,EAEA,OAAO,oBACL,UACsC,EAAA;AACtC,IAAO,OAAA,IAAI,qCAAqC,UAAU,CAAA,CAAA;AAAA,GAC5D;AAAA,EAEA,OAAO,kCACL,UACA,EAAA;AACA,IAAA,OAAO,IAAI,oCAAA;AAAA,MACT,UAAW,CAAA,mBAAA;AAAA,KACb,CAAA;AAAA,GACF;AAAA,EAIA,MAAM,cAAkD,GAAA;AACtD,IAAA,IACE,IAAK,CAAA,MAAA,KAAW,KACf,CAAA,IAAA,IAAA,CAAK,MAAO,CAAA,SAAA,KAAc,KACzB,CAAA,IAAA,IAAA,CAAK,GAAI,EAAA,GAAI,IAAK,CAAA,MAAA,CAAO,SAC3B,EAAA;AACA,MAAI,IAAA,OAAO,IAAK,CAAA,UAAA,KAAe,QAAU,EAAA;AACvC,QAAA,IAAA,CAAK,MAAS,GAAA;AAAA,UACZ,OAAS,EAAA;AAAA,YACP,eAAe,CAAS,MAAA,EAAA,IAAA,CAAK,IAAI,IAAK,CAAA,UAAU,EAAE,CAAC,CAAA,CAAA;AAAA,WACrD;AAAA,UACA,IAAM,EAAA,KAAA;AAAA,UACN,OAAO,IAAK,CAAA,UAAA;AAAA,SACd,CAAA;AAAA,OACK,MAAA;AACL,QAAM,MAAA,WAAA,GAAc,MAAM,IAAA,CAAK,UAAW,CAAA,QAAA;AAAA,UACxC,IAAK,CAAA,gBAAA;AAAA,SACP,CAAA;AAEA,QAAA,IAAI,CAAC,WAAa,EAAA;AAChB,UAAM,MAAA,IAAI,MAAM,iCAAiC,CAAA,CAAA;AAAA,SACnD;AAEA,QAAA,IAAA,CAAK,MAAS,GAAA;AAAA,UACZ,SAAA,EAAW,YAAY,kBAAqB,GAAA,UAAA;AAAA,UAC5C,OAAS,EAAA;AAAA,YACP,aAAA,EAAe,CAAU,OAAA,EAAA,WAAA,CAAY,KAAK,CAAA,CAAA;AAAA,WAC5C;AAAA,UACA,IAAM,EAAA,QAAA;AAAA,UACN,OAAO,WAAY,CAAA,KAAA;AAAA,SACrB,CAAA;AAAA,OACF;AAAA,KACF;AAEA,IAAA,OAAO,IAAK,CAAA,MAAA,CAAA;AAAA,GACd;AACF;;;;"}
|
|
@@ -7,9 +7,7 @@ class DefaultAzureDevOpsCredentialsProvider {
|
|
|
7
7
|
}
|
|
8
8
|
static fromIntegrations(integrations) {
|
|
9
9
|
const providers = integrations.azure.list().reduce((acc, integration) => {
|
|
10
|
-
|
|
11
|
-
(_a = integration.config.credentials) == null ? void 0 : _a.forEach((credential) => {
|
|
12
|
-
var _a2;
|
|
10
|
+
integration.config.credentials?.forEach((credential) => {
|
|
13
11
|
if (credential.organizations === void 0 || credential.organizations.length === 0) {
|
|
14
12
|
if (acc.get(integration.config.host) === void 0) {
|
|
15
13
|
acc.set(
|
|
@@ -23,7 +21,7 @@ class DefaultAzureDevOpsCredentialsProvider {
|
|
|
23
21
|
const provider = CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(
|
|
24
22
|
credential
|
|
25
23
|
);
|
|
26
|
-
|
|
24
|
+
credential.organizations?.forEach((organization) => {
|
|
27
25
|
acc.set(`${integration.config.host}/${organization}`, provider);
|
|
28
26
|
});
|
|
29
27
|
}
|
|
@@ -62,9 +60,8 @@ class DefaultAzureDevOpsCredentialsProvider {
|
|
|
62
60
|
return this.providers.get(url.host);
|
|
63
61
|
}
|
|
64
62
|
async getCredentials(opts) {
|
|
65
|
-
var _a, _b;
|
|
66
63
|
const url = new URL(opts.url);
|
|
67
|
-
const provider =
|
|
64
|
+
const provider = this.forAzureDevOpsOrganization(url) ?? this.forAzureDevOpsServerOrganization(url) ?? this.forHost(url);
|
|
68
65
|
if (provider === void 0) {
|
|
69
66
|
return void 0;
|
|
70
67
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DefaultAzureDevOpsCredentialsProvider.esm.js","sources":["../../src/azure/DefaultAzureDevOpsCredentialsProvider.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport {\n AzureDevOpsCredentials,\n AzureDevOpsCredentialsProvider,\n} from './types';\nimport { CachedAzureDevOpsCredentialsProvider } from './CachedAzureDevOpsCredentialsProvider';\nimport { ScmIntegrationRegistry } from '../registry';\nimport { DefaultAzureCredential } from '@azure/identity';\n\n/**\n * Default implementation of AzureDevOpsCredentialsProvider.\n * @public\n */\nexport class DefaultAzureDevOpsCredentialsProvider\n implements AzureDevOpsCredentialsProvider\n{\n static fromIntegrations(\n integrations: ScmIntegrationRegistry,\n ): DefaultAzureDevOpsCredentialsProvider {\n const providers = integrations.azure.list().reduce((acc, integration) => {\n integration.config.credentials?.forEach(credential => {\n if (\n credential.organizations === undefined ||\n credential.organizations.length === 0\n ) {\n if (acc.get(integration.config.host) === undefined) {\n acc.set(\n integration.config.host,\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credential,\n ),\n );\n }\n } else {\n const provider =\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credential,\n );\n credential.organizations?.forEach(organization => {\n acc.set(`${integration.config.host}/${organization}`, provider);\n });\n }\n });\n\n if (\n integration.config.host === 'dev.azure.com' &&\n acc.get(integration.config.host) === undefined\n ) {\n acc.set(\n integration.config.host,\n CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new DefaultAzureCredential(),\n ),\n );\n }\n\n return acc;\n }, new Map<string, CachedAzureDevOpsCredentialsProvider>());\n\n return new DefaultAzureDevOpsCredentialsProvider(providers);\n }\n\n private constructor(\n private readonly providers: Map<\n string,\n CachedAzureDevOpsCredentialsProvider\n >,\n ) {}\n\n private forAzureDevOpsServerOrganization(\n url: URL,\n ): AzureDevOpsCredentialsProvider | undefined {\n const parts = url.pathname.split('/').filter(part => part !== '');\n if (url.host !== 'dev.azure.com' && parts.length > 0) {\n if (parts[0] !== 'tfs') {\n // url format: https://{host}/{organization}\n return this.providers.get(`${url.host}/${parts[0]}`);\n } else if (parts[0] === 'tfs' && parts.length > 1) {\n // url format: https://{host}/tfs/{organization}\n return this.providers.get(`${url.host}/${parts[1]}`);\n }\n }\n\n return undefined;\n }\n\n private forAzureDevOpsOrganization(\n url: URL,\n ): AzureDevOpsCredentialsProvider | undefined {\n const parts = url.pathname.split('/').filter(part => part !== '');\n if (url.host === 'dev.azure.com' && parts.length > 0) {\n // url format: https://{host}/{organization}\n return this.providers.get(`${url.host}/${parts[0]}`);\n }\n\n return undefined;\n }\n\n private forHost(url: URL): AzureDevOpsCredentialsProvider | undefined {\n return this.providers.get(url.host);\n }\n\n async getCredentials(opts: {\n url: string;\n }): Promise<AzureDevOpsCredentials | undefined> {\n const url = new URL(opts.url);\n const provider =\n this.forAzureDevOpsOrganization(url) ??\n this.forAzureDevOpsServerOrganization(url) ??\n this.forHost(url);\n\n if (provider === undefined) {\n return undefined;\n }\n\n return provider.getCredentials(opts);\n }\n}\n"],"names":[
|
|
1
|
+
{"version":3,"file":"DefaultAzureDevOpsCredentialsProvider.esm.js","sources":["../../src/azure/DefaultAzureDevOpsCredentialsProvider.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport {\n AzureDevOpsCredentials,\n AzureDevOpsCredentialsProvider,\n} from './types';\nimport { CachedAzureDevOpsCredentialsProvider } from './CachedAzureDevOpsCredentialsProvider';\nimport { ScmIntegrationRegistry } from '../registry';\nimport { DefaultAzureCredential } from '@azure/identity';\n\n/**\n * Default implementation of AzureDevOpsCredentialsProvider.\n * @public\n */\nexport class DefaultAzureDevOpsCredentialsProvider\n implements AzureDevOpsCredentialsProvider\n{\n static fromIntegrations(\n integrations: ScmIntegrationRegistry,\n ): DefaultAzureDevOpsCredentialsProvider {\n const providers = integrations.azure.list().reduce((acc, integration) => {\n integration.config.credentials?.forEach(credential => {\n if (\n credential.organizations === undefined ||\n credential.organizations.length === 0\n ) {\n if (acc.get(integration.config.host) === undefined) {\n acc.set(\n integration.config.host,\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credential,\n ),\n );\n }\n } else {\n const provider =\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credential,\n );\n credential.organizations?.forEach(organization => {\n acc.set(`${integration.config.host}/${organization}`, provider);\n });\n }\n });\n\n if (\n integration.config.host === 'dev.azure.com' &&\n acc.get(integration.config.host) === undefined\n ) {\n acc.set(\n integration.config.host,\n CachedAzureDevOpsCredentialsProvider.fromTokenCredential(\n new DefaultAzureCredential(),\n ),\n );\n }\n\n return acc;\n }, new Map<string, CachedAzureDevOpsCredentialsProvider>());\n\n return new DefaultAzureDevOpsCredentialsProvider(providers);\n }\n\n private constructor(\n private readonly providers: Map<\n string,\n CachedAzureDevOpsCredentialsProvider\n >,\n ) {}\n\n private forAzureDevOpsServerOrganization(\n url: URL,\n ): AzureDevOpsCredentialsProvider | undefined {\n const parts = url.pathname.split('/').filter(part => part !== '');\n if (url.host !== 'dev.azure.com' && parts.length > 0) {\n if (parts[0] !== 'tfs') {\n // url format: https://{host}/{organization}\n return this.providers.get(`${url.host}/${parts[0]}`);\n } else if (parts[0] === 'tfs' && parts.length > 1) {\n // url format: https://{host}/tfs/{organization}\n return this.providers.get(`${url.host}/${parts[1]}`);\n }\n }\n\n return undefined;\n }\n\n private forAzureDevOpsOrganization(\n url: URL,\n ): AzureDevOpsCredentialsProvider | undefined {\n const parts = url.pathname.split('/').filter(part => part !== '');\n if (url.host === 'dev.azure.com' && parts.length > 0) {\n // url format: https://{host}/{organization}\n return this.providers.get(`${url.host}/${parts[0]}`);\n }\n\n return undefined;\n }\n\n private forHost(url: URL): AzureDevOpsCredentialsProvider | undefined {\n return this.providers.get(url.host);\n }\n\n async getCredentials(opts: {\n url: string;\n }): Promise<AzureDevOpsCredentials | undefined> {\n const url = new URL(opts.url);\n const provider =\n this.forAzureDevOpsOrganization(url) ??\n this.forAzureDevOpsServerOrganization(url) ??\n this.forHost(url);\n\n if (provider === undefined) {\n return undefined;\n }\n\n return provider.getCredentials(opts);\n }\n}\n"],"names":[],"mappings":"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"}
|
package/dist/azure/config.esm.js
CHANGED
|
@@ -32,20 +32,18 @@ function asAzureDevOpsCredential(credential) {
|
|
|
32
32
|
throw new Error("is not a valid credential");
|
|
33
33
|
}
|
|
34
34
|
function readAzureIntegrationConfig(config) {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
let credentialConfigs = (_b = config.getOptionalConfigArray("credentials")) == null ? void 0 : _b.map((credential) => {
|
|
38
|
-
var _a2, _b2;
|
|
35
|
+
const host = config.getOptionalString("host") ?? AZURE_HOST;
|
|
36
|
+
let credentialConfigs = config.getOptionalConfigArray("credentials")?.map((credential) => {
|
|
39
37
|
const result = {
|
|
40
38
|
organizations: credential.getOptionalStringArray("organizations"),
|
|
41
|
-
personalAccessToken:
|
|
39
|
+
personalAccessToken: credential.getOptionalString("personalAccessToken")?.trim(),
|
|
42
40
|
tenantId: credential.getOptionalString("tenantId"),
|
|
43
41
|
clientId: credential.getOptionalString("clientId"),
|
|
44
|
-
clientSecret:
|
|
42
|
+
clientSecret: credential.getOptionalString("clientSecret")?.trim()
|
|
45
43
|
};
|
|
46
44
|
return result;
|
|
47
45
|
});
|
|
48
|
-
const token =
|
|
46
|
+
const token = config.getOptionalString("token")?.trim();
|
|
49
47
|
if (config.getOptional("credential") !== void 0 && config.getOptional("credentials") !== void 0) {
|
|
50
48
|
throw new Error(
|
|
51
49
|
`Invalid Azure integration config, 'credential' and 'credentials' cannot be used together. Use 'credentials' instead.`
|
|
@@ -58,7 +56,7 @@ function readAzureIntegrationConfig(config) {
|
|
|
58
56
|
}
|
|
59
57
|
if (token !== void 0) {
|
|
60
58
|
const mapped = [{ personalAccessToken: token }];
|
|
61
|
-
credentialConfigs =
|
|
59
|
+
credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;
|
|
62
60
|
}
|
|
63
61
|
if (config.getOptional("credential") !== void 0) {
|
|
64
62
|
const mapped = [
|
|
@@ -66,13 +64,13 @@ function readAzureIntegrationConfig(config) {
|
|
|
66
64
|
organizations: config.getOptionalStringArray(
|
|
67
65
|
"credential.organizations"
|
|
68
66
|
),
|
|
69
|
-
token:
|
|
67
|
+
token: config.getOptionalString("credential.token")?.trim(),
|
|
70
68
|
tenantId: config.getOptionalString("credential.tenantId"),
|
|
71
69
|
clientId: config.getOptionalString("credential.clientId"),
|
|
72
|
-
clientSecret:
|
|
70
|
+
clientSecret: config.getOptionalString("credential.clientSecret")?.trim()
|
|
73
71
|
}
|
|
74
72
|
];
|
|
75
|
-
credentialConfigs =
|
|
73
|
+
credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;
|
|
76
74
|
}
|
|
77
75
|
if (!isValidHost(host)) {
|
|
78
76
|
throw new Error(
|
|
@@ -81,7 +79,7 @@ function readAzureIntegrationConfig(config) {
|
|
|
81
79
|
}
|
|
82
80
|
let credentials = void 0;
|
|
83
81
|
if (credentialConfigs !== void 0) {
|
|
84
|
-
const errors = credentialConfigs
|
|
82
|
+
const errors = credentialConfigs?.reduce((acc, credentialConfig, index) => {
|
|
85
83
|
let error = void 0;
|
|
86
84
|
try {
|
|
87
85
|
asAzureDevOpsCredential(credentialConfig);
|
|
@@ -97,8 +95,7 @@ function readAzureIntegrationConfig(config) {
|
|
|
97
95
|
credentialConfigs.filter(
|
|
98
96
|
(credential) => credential.organizations !== void 0 && credential.organizations.length > 0
|
|
99
97
|
).reduce((acc, credential, index) => {
|
|
100
|
-
|
|
101
|
-
(_a2 = credential.organizations) == null ? void 0 : _a2.forEach((organization) => {
|
|
98
|
+
credential.organizations?.forEach((organization) => {
|
|
102
99
|
if (!acc[organization]) {
|
|
103
100
|
acc[organization] = [];
|
|
104
101
|
}
|
|
@@ -113,7 +110,7 @@ function readAzureIntegrationConfig(config) {
|
|
|
113
110
|
return acc;
|
|
114
111
|
}, Array.of())
|
|
115
112
|
);
|
|
116
|
-
if (
|
|
113
|
+
if (errors?.length > 0) {
|
|
117
114
|
throw new Error(
|
|
118
115
|
`Invalid Azure integration config for ${host}: ${errors.join("; ")}`
|
|
119
116
|
);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.esm.js","sources":["../../src/azure/config.ts"],"sourcesContent":["/*\n * Copyright 2020 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 { Config } from '@backstage/config';\nimport { isValidHost } from '../helpers';\n\nconst AZURE_HOST = 'dev.azure.com';\n\n/**\n * The configuration parameters for a single Azure provider.\n *\n * @public\n */\nexport type AzureIntegrationConfig = {\n /**\n * The host of the target that this matches on, e.g. \"dev.azure.com\".\n *\n * Currently only \"dev.azure.com\" is supported.\n */\n host: string;\n\n /**\n * The authorization token to use for requests.\n *\n * If no token is specified, anonymous access is used.\n *\n * @deprecated Use `credentials` instead.\n */\n token?: string;\n\n /**\n * The credential to use for requests.\n *\n * If no credential is specified anonymous access is used.\n *\n * @deprecated Use `credentials` instead.\n */\n credential?: AzureDevOpsCredential;\n\n /**\n * The credentials to use for requests. If multiple credentials are specified the first one that matches the organization is used.\n * If not organization matches the first credential without an organization is used.\n *\n * If no credentials are specified at all, either a default credential (for Azure DevOps) or anonymous access (for Azure DevOps Server) is used.\n */\n credentials?: AzureDevOpsCredential[];\n};\n\n/**\n * The kind of Azure DevOps credential.\n * @public\n */\nexport type AzureDevOpsCredentialKind =\n | 'PersonalAccessToken'\n | 'ClientSecret'\n | 'ManagedIdentity';\n\n/**\n * Common fields for the Azure DevOps credentials.\n * @public\n */\nexport type AzureCredentialBase = {\n /**\n * The kind of credential.\n */\n kind: AzureDevOpsCredentialKind;\n /**\n * The Azure DevOps organizations for which to use this credential.\n */\n organizations?: string[];\n};\n\n/**\n * A client secret credential that was generated for an App Registration.\n * @public\n */\nexport type AzureClientSecretCredential = AzureCredentialBase & {\n kind: 'ClientSecret';\n /**\n * The Entra ID tenant\n */\n tenantId: string;\n /**\n * The client id\n */\n clientId: string;\n\n /**\n * The client secret\n */\n clientSecret: string;\n};\n\n/**\n * A managed identity credential.\n * @public\n */\nexport type AzureManagedIdentityCredential = AzureCredentialBase & {\n kind: 'ManagedIdentity';\n /**\n * The clientId\n */\n clientId: string;\n};\n\n/**\n * A personal access token credential.\n * @public\n */\nexport type PersonalAccessTokenCredential = AzureCredentialBase & {\n kind: 'PersonalAccessToken';\n personalAccessToken: string;\n};\n\n/**\n * The general shape of a credential that can be used to authenticate to Azure DevOps.\n * @public\n */\nexport type AzureDevOpsCredentialLike = Omit<\n Partial<AzureClientSecretCredential> &\n Partial<AzureManagedIdentityCredential> &\n Partial<PersonalAccessTokenCredential>,\n 'kind'\n>;\n\n/**\n * Credential used to authenticate to Azure DevOps.\n * @public\n */\nexport type AzureDevOpsCredential =\n | AzureClientSecretCredential\n | AzureManagedIdentityCredential\n | PersonalAccessTokenCredential;\n\nconst AzureDevOpsCredentialFields = [\n 'clientId',\n 'clientSecret',\n 'tenantId',\n 'personalAccessToken',\n] as const;\ntype AzureDevOpsCredentialField = (typeof AzureDevOpsCredentialFields)[number];\n\nconst AzureDevopsCredentialFieldMap = new Map<\n AzureDevOpsCredentialKind,\n AzureDevOpsCredentialField[]\n>([\n ['ClientSecret', ['clientId', 'clientSecret', 'tenantId']],\n ['ManagedIdentity', ['clientId']],\n ['PersonalAccessToken', ['personalAccessToken']],\n]);\n\nfunction asAzureDevOpsCredential(\n credential: AzureDevOpsCredentialLike,\n): AzureDevOpsCredential {\n for (const entry of AzureDevopsCredentialFieldMap.entries()) {\n const [kind, requiredFields] = entry;\n\n const forbiddenFields = AzureDevOpsCredentialFields.filter(\n field => !requiredFields.includes(field as AzureDevOpsCredentialField),\n );\n\n if (\n requiredFields.every(field => credential[field] !== undefined) &&\n forbiddenFields.every(field => credential[field] === undefined)\n ) {\n return {\n kind,\n organizations: credential.organizations,\n ...requiredFields.reduce((acc, field) => {\n acc[field] = credential[field];\n return acc;\n }, {} as Record<string, any>),\n } as AzureDevOpsCredential;\n }\n }\n throw new Error('is not a valid credential');\n}\n\n/**\n * Reads a single Azure integration config.\n *\n * @param config - The config object of a single integration\n * @public\n */\nexport function readAzureIntegrationConfig(\n config: Config,\n): AzureIntegrationConfig {\n const host = config.getOptionalString('host') ?? AZURE_HOST;\n\n let credentialConfigs = config\n .getOptionalConfigArray('credentials')\n ?.map(credential => {\n const result: Partial<AzureDevOpsCredentialLike> = {\n organizations: credential.getOptionalStringArray('organizations'),\n personalAccessToken: credential\n .getOptionalString('personalAccessToken')\n ?.trim(),\n tenantId: credential.getOptionalString('tenantId'),\n clientId: credential.getOptionalString('clientId'),\n clientSecret: credential.getOptionalString('clientSecret')?.trim(),\n };\n\n return result;\n });\n\n const token = config.getOptionalString('token')?.trim();\n\n if (\n config.getOptional('credential') !== undefined &&\n config.getOptional('credentials') !== undefined\n ) {\n throw new Error(\n `Invalid Azure integration config, 'credential' and 'credentials' cannot be used together. Use 'credentials' instead.`,\n );\n }\n\n if (\n config.getOptional('token') !== undefined &&\n config.getOptional('credentials') !== undefined\n ) {\n throw new Error(\n `Invalid Azure integration config, 'token' and 'credentials' cannot be used together. Use 'credentials' instead.`,\n );\n }\n\n if (token !== undefined) {\n const mapped = [{ personalAccessToken: token }];\n credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;\n }\n\n if (config.getOptional('credential') !== undefined) {\n const mapped = [\n {\n organizations: config.getOptionalStringArray(\n 'credential.organizations',\n ),\n token: config.getOptionalString('credential.token')?.trim(),\n tenantId: config.getOptionalString('credential.tenantId'),\n clientId: config.getOptionalString('credential.clientId'),\n clientSecret: config\n .getOptionalString('credential.clientSecret')\n ?.trim(),\n },\n ];\n credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;\n }\n\n if (!isValidHost(host)) {\n throw new Error(\n `Invalid Azure integration config, '${host}' is not a valid host`,\n );\n }\n\n let credentials: AzureDevOpsCredential[] | undefined = undefined;\n if (credentialConfigs !== undefined) {\n const errors = credentialConfigs\n ?.reduce((acc, credentialConfig, index) => {\n let error: string | undefined = undefined;\n try {\n asAzureDevOpsCredential(credentialConfig);\n } catch (e) {\n error = e.message;\n }\n\n if (error !== undefined) {\n acc.push(`credential at position ${index + 1} ${error}`);\n }\n\n return acc;\n }, Array.of<string>())\n .concat(\n Object.entries(\n credentialConfigs\n .filter(\n credential =>\n credential.organizations !== undefined &&\n credential.organizations.length > 0,\n )\n .reduce((acc, credential, index) => {\n credential.organizations?.forEach(organization => {\n if (!acc[organization]) {\n acc[organization] = [];\n }\n\n acc[organization].push(index + 1);\n });\n\n return acc;\n }, {} as Record<string, number[]>),\n )\n .filter(([_, indexes]) => indexes.length > 1)\n .reduce((acc, [org, indexes]) => {\n acc.push(\n `organization ${org} is specified multiple times in credentials at positions ${indexes\n .slice(0, indexes.length - 1)\n .join(', ')} and ${indexes[indexes.length - 1]}`,\n );\n return acc;\n }, Array.of<string>()),\n );\n\n if (errors?.length > 0) {\n throw new Error(\n `Invalid Azure integration config for ${host}: ${errors.join('; ')}`,\n );\n }\n\n credentials = credentialConfigs.map(credentialConfig =>\n asAzureDevOpsCredential(credentialConfig),\n );\n\n if (\n credentials.some(\n credential => credential.kind !== 'PersonalAccessToken',\n ) &&\n host !== AZURE_HOST\n ) {\n throw new Error(\n `Invalid Azure integration config for ${host}, only personal access tokens can be used with hosts other than ${AZURE_HOST}`,\n );\n }\n\n if (\n credentials.filter(\n credential =>\n credential.organizations === undefined ||\n credential.organizations.length === 0,\n ).length > 1\n ) {\n throw new Error(\n `Invalid Azure integration config for ${host}, you cannot specify multiple credentials without organizations`,\n );\n }\n }\n\n return {\n host,\n credentials,\n };\n}\n\n/**\n * Reads a set of Azure integration configs, and inserts some defaults for\n * public Azure if not specified.\n *\n * @param configs - All of the integration config objects\n * @public\n */\nexport function readAzureIntegrationConfigs(\n configs: Config[],\n): AzureIntegrationConfig[] {\n // First read all the explicit integrations\n const result = configs.map(readAzureIntegrationConfig);\n\n // If no explicit dev.azure.com integration was added, put one in the list as\n // a convenience\n if (!result.some(c => c.host === AZURE_HOST)) {\n result.push({ host: AZURE_HOST });\n }\n\n return result;\n}\n"],"names":["_a","_b"],"mappings":";;AAmBA,MAAM,UAAa,GAAA,eAAA,CAAA;AAgInB,MAAM,2BAA8B,GAAA;AAAA,EAClC,UAAA;AAAA,EACA,cAAA;AAAA,EACA,UAAA;AAAA,EACA,qBAAA;AACF,CAAA,CAAA;AAGA,MAAM,6BAAA,uBAAoC,GAGxC,CAAA;AAAA,EACA,CAAC,cAAgB,EAAA,CAAC,UAAY,EAAA,cAAA,EAAgB,UAAU,CAAC,CAAA;AAAA,EACzD,CAAC,iBAAA,EAAmB,CAAC,UAAU,CAAC,CAAA;AAAA,EAChC,CAAC,qBAAA,EAAuB,CAAC,qBAAqB,CAAC,CAAA;AACjD,CAAC,CAAA,CAAA;AAED,SAAS,wBACP,UACuB,EAAA;AACvB,EAAW,KAAA,MAAA,KAAA,IAAS,6BAA8B,CAAA,OAAA,EAAW,EAAA;AAC3D,IAAM,MAAA,CAAC,IAAM,EAAA,cAAc,CAAI,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,kBAAkB,2BAA4B,CAAA,MAAA;AAAA,MAClD,CAAS,KAAA,KAAA,CAAC,cAAe,CAAA,QAAA,CAAS,KAAmC,CAAA;AAAA,KACvE,CAAA;AAEA,IAAA,IACE,cAAe,CAAA,KAAA,CAAM,CAAS,KAAA,KAAA,UAAA,CAAW,KAAK,CAAM,KAAA,KAAA,CAAS,CAC7D,IAAA,eAAA,CAAgB,MAAM,CAAS,KAAA,KAAA,UAAA,CAAW,KAAK,CAAA,KAAM,MAAS,CAC9D,EAAA;AACA,MAAO,OAAA;AAAA,QACL,IAAA;AAAA,QACA,eAAe,UAAW,CAAA,aAAA;AAAA,QAC1B,GAAG,cAAA,CAAe,MAAO,CAAA,CAAC,KAAK,KAAU,KAAA;AACvC,UAAI,GAAA,CAAA,KAAK,CAAI,GAAA,UAAA,CAAW,KAAK,CAAA,CAAA;AAC7B,UAAO,OAAA,GAAA,CAAA;AAAA,SACT,EAAG,EAAyB,CAAA;AAAA,OAC9B,CAAA;AAAA,KACF;AAAA,GACF;AACA,EAAM,MAAA,IAAI,MAAM,2BAA2B,CAAA,CAAA;AAC7C,CAAA;AAQO,SAAS,2BACd,MACwB,EAAA;AAvM1B,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,CAAA;AAwME,EAAA,MAAM,IAAO,GAAA,CAAA,EAAA,GAAA,MAAA,CAAO,iBAAkB,CAAA,MAAM,MAA/B,IAAoC,GAAA,EAAA,GAAA,UAAA,CAAA;AAEjD,EAAA,IAAI,qBAAoB,EACrB,GAAA,MAAA,CAAA,sBAAA,CAAuB,aAAa,CADf,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAEpB,IAAI,CAAc,UAAA,KAAA;AA5MxB,IAAA,IAAAA,GAAAC,EAAAA,GAAAA,CAAAA;AA6MM,IAAA,MAAM,MAA6C,GAAA;AAAA,MACjD,aAAA,EAAe,UAAW,CAAA,sBAAA,CAAuB,eAAe,CAAA;AAAA,MAChE,sBAAqBD,GAAA,GAAA,UAAA,CAClB,kBAAkB,qBAAqB,CAAA,KADrB,gBAAAA,GAEjB,CAAA,IAAA,EAAA;AAAA,MACJ,QAAA,EAAU,UAAW,CAAA,iBAAA,CAAkB,UAAU,CAAA;AAAA,MACjD,QAAA,EAAU,UAAW,CAAA,iBAAA,CAAkB,UAAU,CAAA;AAAA,MACjD,eAAcC,GAAA,GAAA,UAAA,CAAW,kBAAkB,cAAc,CAAA,KAA3C,gBAAAA,GAA8C,CAAA,IAAA,EAAA;AAAA,KAC9D,CAAA;AAEA,IAAO,OAAA,MAAA,CAAA;AAAA,GACT,CAAA,CAAA;AAEF,EAAA,MAAM,KAAQ,GAAA,CAAA,EAAA,GAAA,MAAA,CAAO,iBAAkB,CAAA,OAAO,MAAhC,IAAmC,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,EAAA,CAAA;AAEjD,EACE,IAAA,MAAA,CAAO,YAAY,YAAY,CAAA,KAAM,UACrC,MAAO,CAAA,WAAA,CAAY,aAAa,CAAA,KAAM,KACtC,CAAA,EAAA;AACA,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,oHAAA,CAAA;AAAA,KACF,CAAA;AAAA,GACF;AAEA,EACE,IAAA,MAAA,CAAO,YAAY,OAAO,CAAA,KAAM,UAChC,MAAO,CAAA,WAAA,CAAY,aAAa,CAAA,KAAM,KACtC,CAAA,EAAA;AACA,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,+GAAA,CAAA;AAAA,KACF,CAAA;AAAA,GACF;AAEA,EAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,IAAA,MAAM,MAAS,GAAA,CAAC,EAAE,mBAAA,EAAqB,OAAO,CAAA,CAAA;AAC9C,IAAoB,iBAAA,GAAA,CAAA,EAAA,GAAA,iBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,iBAAA,CAAmB,MAAO,CAAA,MAAA,CAAA,KAA1B,IAAqC,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,GAC3D;AAEA,EAAA,IAAI,MAAO,CAAA,WAAA,CAAY,YAAY,CAAA,KAAM,KAAW,CAAA,EAAA;AAClD,IAAA,MAAM,MAAS,GAAA;AAAA,MACb;AAAA,QACE,eAAe,MAAO,CAAA,sBAAA;AAAA,UACpB,0BAAA;AAAA,SACF;AAAA,QACA,KAAO,EAAA,CAAA,EAAA,GAAA,MAAA,CAAO,iBAAkB,CAAA,kBAAkB,MAA3C,IAA8C,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,EAAA;AAAA,QACrD,QAAA,EAAU,MAAO,CAAA,iBAAA,CAAkB,qBAAqB,CAAA;AAAA,QACxD,QAAA,EAAU,MAAO,CAAA,iBAAA,CAAkB,qBAAqB,CAAA;AAAA,QACxD,YAAc,EAAA,CAAA,EAAA,GAAA,MAAA,CACX,iBAAkB,CAAA,yBAAyB,MADhC,IAEV,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,EAAA;AAAA,OACN;AAAA,KACF,CAAA;AACA,IAAoB,iBAAA,GAAA,CAAA,EAAA,GAAA,iBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,iBAAA,CAAmB,MAAO,CAAA,MAAA,CAAA,KAA1B,IAAqC,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,GAC3D;AAEA,EAAI,IAAA,CAAC,WAAY,CAAA,IAAI,CAAG,EAAA;AACtB,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,sCAAsC,IAAI,CAAA,qBAAA,CAAA;AAAA,KAC5C,CAAA;AAAA,GACF;AAEA,EAAA,IAAI,WAAmD,GAAA,KAAA,CAAA,CAAA;AACvD,EAAA,IAAI,sBAAsB,KAAW,CAAA,EAAA;AACnC,IAAA,MAAM,SAAS,iBACX,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,iBAAA,CAAA,MAAA,CAAO,CAAC,GAAA,EAAK,kBAAkB,KAAU,KAAA;AACzC,MAAA,IAAI,KAA4B,GAAA,KAAA,CAAA,CAAA;AAChC,MAAI,IAAA;AACF,QAAA,uBAAA,CAAwB,gBAAgB,CAAA,CAAA;AAAA,eACjC,CAAG,EAAA;AACV,QAAA,KAAA,GAAQ,CAAE,CAAA,OAAA,CAAA;AAAA,OACZ;AAEA,MAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,QAAA,GAAA,CAAI,KAAK,CAA0B,uBAAA,EAAA,KAAA,GAAQ,CAAC,CAAA,CAAA,EAAI,KAAK,CAAE,CAAA,CAAA,CAAA;AAAA,OACzD;AAEA,MAAO,OAAA,GAAA,CAAA;AAAA,KACT,EAAG,KAAM,CAAA,EAAA,EACR,CAAA,CAAA,MAAA;AAAA,MACC,MAAO,CAAA,OAAA;AAAA,QACL,iBACG,CAAA,MAAA;AAAA,UACC,gBACE,UAAW,CAAA,aAAA,KAAkB,KAC7B,CAAA,IAAA,UAAA,CAAW,cAAc,MAAS,GAAA,CAAA;AAAA,SAErC,CAAA,MAAA,CAAO,CAAC,GAAA,EAAK,YAAY,KAAU,KAAA;AAnShD,UAAAD,IAAAA,GAAAA,CAAAA;AAoSc,UAAA,CAAAA,MAAA,UAAW,CAAA,aAAA,KAAX,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,GAAAA,CAA0B,QAAQ,CAAgB,YAAA,KAAA;AAChD,YAAI,IAAA,CAAC,GAAI,CAAA,YAAY,CAAG,EAAA;AACtB,cAAI,GAAA,CAAA,YAAY,IAAI,EAAC,CAAA;AAAA,aACvB;AAEA,YAAA,GAAA,CAAI,YAAY,CAAA,CAAE,IAAK,CAAA,KAAA,GAAQ,CAAC,CAAA,CAAA;AAAA,WAClC,CAAA,CAAA;AAEA,UAAO,OAAA,GAAA,CAAA;AAAA,SACT,EAAG,EAA8B,CAAA;AAAA,QAElC,MAAO,CAAA,CAAC,CAAC,CAAA,EAAG,OAAO,CAAM,KAAA,OAAA,CAAQ,MAAS,GAAA,CAAC,EAC3C,MAAO,CAAA,CAAC,KAAK,CAAC,GAAA,EAAK,OAAO,CAAM,KAAA;AAC/B,QAAI,GAAA,CAAA,IAAA;AAAA,UACF,gBAAgB,GAAG,CAAA,yDAAA,EAA4D,QAC5E,KAAM,CAAA,CAAA,EAAG,QAAQ,MAAS,GAAA,CAAC,CAC3B,CAAA,IAAA,CAAK,IAAI,CAAC,CAAA,KAAA,EAAQ,QAAQ,OAAQ,CAAA,MAAA,GAAS,CAAC,CAAC,CAAA,CAAA;AAAA,SAClD,CAAA;AACA,QAAO,OAAA,GAAA,CAAA;AAAA,OACT,EAAG,KAAM,CAAA,EAAA,EAAY,CAAA;AAAA,KAAA,CAAA;AAG3B,IAAI,IAAA,CAAA,MAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAQ,UAAS,CAAG,EAAA;AACtB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,wCAAwC,IAAI,CAAA,EAAA,EAAK,MAAO,CAAA,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA;AAAA,OACpE,CAAA;AAAA,KACF;AAEA,IAAA,WAAA,GAAc,iBAAkB,CAAA,GAAA;AAAA,MAAI,CAAA,gBAAA,KAClC,wBAAwB,gBAAgB,CAAA;AAAA,KAC1C,CAAA;AAEA,IAAA,IACE,WAAY,CAAA,IAAA;AAAA,MACV,CAAA,UAAA,KAAc,WAAW,IAAS,KAAA,qBAAA;AAAA,KACpC,IACA,SAAS,UACT,EAAA;AACA,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,qCAAA,EAAwC,IAAI,CAAA,gEAAA,EAAmE,UAAU,CAAA,CAAA;AAAA,OAC3H,CAAA;AAAA,KACF;AAEA,IAAA,IACE,WAAY,CAAA,MAAA;AAAA,MACV,gBACE,UAAW,CAAA,aAAA,KAAkB,KAC7B,CAAA,IAAA,UAAA,CAAW,cAAc,MAAW,KAAA,CAAA;AAAA,KACxC,CAAE,SAAS,CACX,EAAA;AACA,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,wCAAwC,IAAI,CAAA,+DAAA,CAAA;AAAA,OAC9C,CAAA;AAAA,KACF;AAAA,GACF;AAEA,EAAO,OAAA;AAAA,IACL,IAAA;AAAA,IACA,WAAA;AAAA,GACF,CAAA;AACF,CAAA;AASO,SAAS,4BACd,OAC0B,EAAA;AAE1B,EAAM,MAAA,MAAA,GAAS,OAAQ,CAAA,GAAA,CAAI,0BAA0B,CAAA,CAAA;AAIrD,EAAA,IAAI,CAAC,MAAO,CAAA,IAAA,CAAK,OAAK,CAAE,CAAA,IAAA,KAAS,UAAU,CAAG,EAAA;AAC5C,IAAA,MAAA,CAAO,IAAK,CAAA,EAAE,IAAM,EAAA,UAAA,EAAY,CAAA,CAAA;AAAA,GAClC;AAEA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
|
|
1
|
+
{"version":3,"file":"config.esm.js","sources":["../../src/azure/config.ts"],"sourcesContent":["/*\n * Copyright 2020 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 { Config } from '@backstage/config';\nimport { isValidHost } from '../helpers';\n\nconst AZURE_HOST = 'dev.azure.com';\n\n/**\n * The configuration parameters for a single Azure provider.\n *\n * @public\n */\nexport type AzureIntegrationConfig = {\n /**\n * The host of the target that this matches on, e.g. \"dev.azure.com\".\n *\n * Currently only \"dev.azure.com\" is supported.\n */\n host: string;\n\n /**\n * The authorization token to use for requests.\n *\n * If no token is specified, anonymous access is used.\n *\n * @deprecated Use `credentials` instead.\n */\n token?: string;\n\n /**\n * The credential to use for requests.\n *\n * If no credential is specified anonymous access is used.\n *\n * @deprecated Use `credentials` instead.\n */\n credential?: AzureDevOpsCredential;\n\n /**\n * The credentials to use for requests. If multiple credentials are specified the first one that matches the organization is used.\n * If not organization matches the first credential without an organization is used.\n *\n * If no credentials are specified at all, either a default credential (for Azure DevOps) or anonymous access (for Azure DevOps Server) is used.\n */\n credentials?: AzureDevOpsCredential[];\n};\n\n/**\n * The kind of Azure DevOps credential.\n * @public\n */\nexport type AzureDevOpsCredentialKind =\n | 'PersonalAccessToken'\n | 'ClientSecret'\n | 'ManagedIdentity';\n\n/**\n * Common fields for the Azure DevOps credentials.\n * @public\n */\nexport type AzureCredentialBase = {\n /**\n * The kind of credential.\n */\n kind: AzureDevOpsCredentialKind;\n /**\n * The Azure DevOps organizations for which to use this credential.\n */\n organizations?: string[];\n};\n\n/**\n * A client secret credential that was generated for an App Registration.\n * @public\n */\nexport type AzureClientSecretCredential = AzureCredentialBase & {\n kind: 'ClientSecret';\n /**\n * The Entra ID tenant\n */\n tenantId: string;\n /**\n * The client id\n */\n clientId: string;\n\n /**\n * The client secret\n */\n clientSecret: string;\n};\n\n/**\n * A managed identity credential.\n * @public\n */\nexport type AzureManagedIdentityCredential = AzureCredentialBase & {\n kind: 'ManagedIdentity';\n /**\n * The clientId\n */\n clientId: string;\n};\n\n/**\n * A personal access token credential.\n * @public\n */\nexport type PersonalAccessTokenCredential = AzureCredentialBase & {\n kind: 'PersonalAccessToken';\n personalAccessToken: string;\n};\n\n/**\n * The general shape of a credential that can be used to authenticate to Azure DevOps.\n * @public\n */\nexport type AzureDevOpsCredentialLike = Omit<\n Partial<AzureClientSecretCredential> &\n Partial<AzureManagedIdentityCredential> &\n Partial<PersonalAccessTokenCredential>,\n 'kind'\n>;\n\n/**\n * Credential used to authenticate to Azure DevOps.\n * @public\n */\nexport type AzureDevOpsCredential =\n | AzureClientSecretCredential\n | AzureManagedIdentityCredential\n | PersonalAccessTokenCredential;\n\nconst AzureDevOpsCredentialFields = [\n 'clientId',\n 'clientSecret',\n 'tenantId',\n 'personalAccessToken',\n] as const;\ntype AzureDevOpsCredentialField = (typeof AzureDevOpsCredentialFields)[number];\n\nconst AzureDevopsCredentialFieldMap = new Map<\n AzureDevOpsCredentialKind,\n AzureDevOpsCredentialField[]\n>([\n ['ClientSecret', ['clientId', 'clientSecret', 'tenantId']],\n ['ManagedIdentity', ['clientId']],\n ['PersonalAccessToken', ['personalAccessToken']],\n]);\n\nfunction asAzureDevOpsCredential(\n credential: AzureDevOpsCredentialLike,\n): AzureDevOpsCredential {\n for (const entry of AzureDevopsCredentialFieldMap.entries()) {\n const [kind, requiredFields] = entry;\n\n const forbiddenFields = AzureDevOpsCredentialFields.filter(\n field => !requiredFields.includes(field as AzureDevOpsCredentialField),\n );\n\n if (\n requiredFields.every(field => credential[field] !== undefined) &&\n forbiddenFields.every(field => credential[field] === undefined)\n ) {\n return {\n kind,\n organizations: credential.organizations,\n ...requiredFields.reduce((acc, field) => {\n acc[field] = credential[field];\n return acc;\n }, {} as Record<string, any>),\n } as AzureDevOpsCredential;\n }\n }\n throw new Error('is not a valid credential');\n}\n\n/**\n * Reads a single Azure integration config.\n *\n * @param config - The config object of a single integration\n * @public\n */\nexport function readAzureIntegrationConfig(\n config: Config,\n): AzureIntegrationConfig {\n const host = config.getOptionalString('host') ?? AZURE_HOST;\n\n let credentialConfigs = config\n .getOptionalConfigArray('credentials')\n ?.map(credential => {\n const result: Partial<AzureDevOpsCredentialLike> = {\n organizations: credential.getOptionalStringArray('organizations'),\n personalAccessToken: credential\n .getOptionalString('personalAccessToken')\n ?.trim(),\n tenantId: credential.getOptionalString('tenantId'),\n clientId: credential.getOptionalString('clientId'),\n clientSecret: credential.getOptionalString('clientSecret')?.trim(),\n };\n\n return result;\n });\n\n const token = config.getOptionalString('token')?.trim();\n\n if (\n config.getOptional('credential') !== undefined &&\n config.getOptional('credentials') !== undefined\n ) {\n throw new Error(\n `Invalid Azure integration config, 'credential' and 'credentials' cannot be used together. Use 'credentials' instead.`,\n );\n }\n\n if (\n config.getOptional('token') !== undefined &&\n config.getOptional('credentials') !== undefined\n ) {\n throw new Error(\n `Invalid Azure integration config, 'token' and 'credentials' cannot be used together. Use 'credentials' instead.`,\n );\n }\n\n if (token !== undefined) {\n const mapped = [{ personalAccessToken: token }];\n credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;\n }\n\n if (config.getOptional('credential') !== undefined) {\n const mapped = [\n {\n organizations: config.getOptionalStringArray(\n 'credential.organizations',\n ),\n token: config.getOptionalString('credential.token')?.trim(),\n tenantId: config.getOptionalString('credential.tenantId'),\n clientId: config.getOptionalString('credential.clientId'),\n clientSecret: config\n .getOptionalString('credential.clientSecret')\n ?.trim(),\n },\n ];\n credentialConfigs = credentialConfigs?.concat(mapped) ?? mapped;\n }\n\n if (!isValidHost(host)) {\n throw new Error(\n `Invalid Azure integration config, '${host}' is not a valid host`,\n );\n }\n\n let credentials: AzureDevOpsCredential[] | undefined = undefined;\n if (credentialConfigs !== undefined) {\n const errors = credentialConfigs\n ?.reduce((acc, credentialConfig, index) => {\n let error: string | undefined = undefined;\n try {\n asAzureDevOpsCredential(credentialConfig);\n } catch (e) {\n error = e.message;\n }\n\n if (error !== undefined) {\n acc.push(`credential at position ${index + 1} ${error}`);\n }\n\n return acc;\n }, Array.of<string>())\n .concat(\n Object.entries(\n credentialConfigs\n .filter(\n credential =>\n credential.organizations !== undefined &&\n credential.organizations.length > 0,\n )\n .reduce((acc, credential, index) => {\n credential.organizations?.forEach(organization => {\n if (!acc[organization]) {\n acc[organization] = [];\n }\n\n acc[organization].push(index + 1);\n });\n\n return acc;\n }, {} as Record<string, number[]>),\n )\n .filter(([_, indexes]) => indexes.length > 1)\n .reduce((acc, [org, indexes]) => {\n acc.push(\n `organization ${org} is specified multiple times in credentials at positions ${indexes\n .slice(0, indexes.length - 1)\n .join(', ')} and ${indexes[indexes.length - 1]}`,\n );\n return acc;\n }, Array.of<string>()),\n );\n\n if (errors?.length > 0) {\n throw new Error(\n `Invalid Azure integration config for ${host}: ${errors.join('; ')}`,\n );\n }\n\n credentials = credentialConfigs.map(credentialConfig =>\n asAzureDevOpsCredential(credentialConfig),\n );\n\n if (\n credentials.some(\n credential => credential.kind !== 'PersonalAccessToken',\n ) &&\n host !== AZURE_HOST\n ) {\n throw new Error(\n `Invalid Azure integration config for ${host}, only personal access tokens can be used with hosts other than ${AZURE_HOST}`,\n );\n }\n\n if (\n credentials.filter(\n credential =>\n credential.organizations === undefined ||\n credential.organizations.length === 0,\n ).length > 1\n ) {\n throw new Error(\n `Invalid Azure integration config for ${host}, you cannot specify multiple credentials without organizations`,\n );\n }\n }\n\n return {\n host,\n credentials,\n };\n}\n\n/**\n * Reads a set of Azure integration configs, and inserts some defaults for\n * public Azure if not specified.\n *\n * @param configs - All of the integration config objects\n * @public\n */\nexport function readAzureIntegrationConfigs(\n configs: Config[],\n): AzureIntegrationConfig[] {\n // First read all the explicit integrations\n const result = configs.map(readAzureIntegrationConfig);\n\n // If no explicit dev.azure.com integration was added, put one in the list as\n // a convenience\n if (!result.some(c => c.host === AZURE_HOST)) {\n result.push({ host: AZURE_HOST });\n }\n\n return result;\n}\n"],"names":[],"mappings":";;AAmBA,MAAM,UAAa,GAAA,eAAA,CAAA;AAgInB,MAAM,2BAA8B,GAAA;AAAA,EAClC,UAAA;AAAA,EACA,cAAA;AAAA,EACA,UAAA;AAAA,EACA,qBAAA;AACF,CAAA,CAAA;AAGA,MAAM,6BAAA,uBAAoC,GAGxC,CAAA;AAAA,EACA,CAAC,cAAgB,EAAA,CAAC,UAAY,EAAA,cAAA,EAAgB,UAAU,CAAC,CAAA;AAAA,EACzD,CAAC,iBAAA,EAAmB,CAAC,UAAU,CAAC,CAAA;AAAA,EAChC,CAAC,qBAAA,EAAuB,CAAC,qBAAqB,CAAC,CAAA;AACjD,CAAC,CAAA,CAAA;AAED,SAAS,wBACP,UACuB,EAAA;AACvB,EAAW,KAAA,MAAA,KAAA,IAAS,6BAA8B,CAAA,OAAA,EAAW,EAAA;AAC3D,IAAM,MAAA,CAAC,IAAM,EAAA,cAAc,CAAI,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,kBAAkB,2BAA4B,CAAA,MAAA;AAAA,MAClD,CAAS,KAAA,KAAA,CAAC,cAAe,CAAA,QAAA,CAAS,KAAmC,CAAA;AAAA,KACvE,CAAA;AAEA,IAAA,IACE,cAAe,CAAA,KAAA,CAAM,CAAS,KAAA,KAAA,UAAA,CAAW,KAAK,CAAM,KAAA,KAAA,CAAS,CAC7D,IAAA,eAAA,CAAgB,MAAM,CAAS,KAAA,KAAA,UAAA,CAAW,KAAK,CAAA,KAAM,MAAS,CAC9D,EAAA;AACA,MAAO,OAAA;AAAA,QACL,IAAA;AAAA,QACA,eAAe,UAAW,CAAA,aAAA;AAAA,QAC1B,GAAG,cAAA,CAAe,MAAO,CAAA,CAAC,KAAK,KAAU,KAAA;AACvC,UAAI,GAAA,CAAA,KAAK,CAAI,GAAA,UAAA,CAAW,KAAK,CAAA,CAAA;AAC7B,UAAO,OAAA,GAAA,CAAA;AAAA,SACT,EAAG,EAAyB,CAAA;AAAA,OAC9B,CAAA;AAAA,KACF;AAAA,GACF;AACA,EAAM,MAAA,IAAI,MAAM,2BAA2B,CAAA,CAAA;AAC7C,CAAA;AAQO,SAAS,2BACd,MACwB,EAAA;AACxB,EAAA,MAAM,IAAO,GAAA,MAAA,CAAO,iBAAkB,CAAA,MAAM,CAAK,IAAA,UAAA,CAAA;AAEjD,EAAA,IAAI,oBAAoB,MACrB,CAAA,sBAAA,CAAuB,aAAa,CAAA,EACnC,IAAI,CAAc,UAAA,KAAA;AAClB,IAAA,MAAM,MAA6C,GAAA;AAAA,MACjD,aAAA,EAAe,UAAW,CAAA,sBAAA,CAAuB,eAAe,CAAA;AAAA,MAChE,mBAAqB,EAAA,UAAA,CAClB,iBAAkB,CAAA,qBAAqB,GACtC,IAAK,EAAA;AAAA,MACT,QAAA,EAAU,UAAW,CAAA,iBAAA,CAAkB,UAAU,CAAA;AAAA,MACjD,QAAA,EAAU,UAAW,CAAA,iBAAA,CAAkB,UAAU,CAAA;AAAA,MACjD,YAAc,EAAA,UAAA,CAAW,iBAAkB,CAAA,cAAc,GAAG,IAAK,EAAA;AAAA,KACnE,CAAA;AAEA,IAAO,OAAA,MAAA,CAAA;AAAA,GACR,CAAA,CAAA;AAEH,EAAA,MAAM,KAAQ,GAAA,MAAA,CAAO,iBAAkB,CAAA,OAAO,GAAG,IAAK,EAAA,CAAA;AAEtD,EACE,IAAA,MAAA,CAAO,YAAY,YAAY,CAAA,KAAM,UACrC,MAAO,CAAA,WAAA,CAAY,aAAa,CAAA,KAAM,KACtC,CAAA,EAAA;AACA,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,oHAAA,CAAA;AAAA,KACF,CAAA;AAAA,GACF;AAEA,EACE,IAAA,MAAA,CAAO,YAAY,OAAO,CAAA,KAAM,UAChC,MAAO,CAAA,WAAA,CAAY,aAAa,CAAA,KAAM,KACtC,CAAA,EAAA;AACA,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,+GAAA,CAAA;AAAA,KACF,CAAA;AAAA,GACF;AAEA,EAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,IAAA,MAAM,MAAS,GAAA,CAAC,EAAE,mBAAA,EAAqB,OAAO,CAAA,CAAA;AAC9C,IAAoB,iBAAA,GAAA,iBAAA,EAAmB,MAAO,CAAA,MAAM,CAAK,IAAA,MAAA,CAAA;AAAA,GAC3D;AAEA,EAAA,IAAI,MAAO,CAAA,WAAA,CAAY,YAAY,CAAA,KAAM,KAAW,CAAA,EAAA;AAClD,IAAA,MAAM,MAAS,GAAA;AAAA,MACb;AAAA,QACE,eAAe,MAAO,CAAA,sBAAA;AAAA,UACpB,0BAAA;AAAA,SACF;AAAA,QACA,KAAO,EAAA,MAAA,CAAO,iBAAkB,CAAA,kBAAkB,GAAG,IAAK,EAAA;AAAA,QAC1D,QAAA,EAAU,MAAO,CAAA,iBAAA,CAAkB,qBAAqB,CAAA;AAAA,QACxD,QAAA,EAAU,MAAO,CAAA,iBAAA,CAAkB,qBAAqB,CAAA;AAAA,QACxD,YAAc,EAAA,MAAA,CACX,iBAAkB,CAAA,yBAAyB,GAC1C,IAAK,EAAA;AAAA,OACX;AAAA,KACF,CAAA;AACA,IAAoB,iBAAA,GAAA,iBAAA,EAAmB,MAAO,CAAA,MAAM,CAAK,IAAA,MAAA,CAAA;AAAA,GAC3D;AAEA,EAAI,IAAA,CAAC,WAAY,CAAA,IAAI,CAAG,EAAA;AACtB,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,sCAAsC,IAAI,CAAA,qBAAA,CAAA;AAAA,KAC5C,CAAA;AAAA,GACF;AAEA,EAAA,IAAI,WAAmD,GAAA,KAAA,CAAA,CAAA;AACvD,EAAA,IAAI,sBAAsB,KAAW,CAAA,EAAA;AACnC,IAAA,MAAM,SAAS,iBACX,EAAA,MAAA,CAAO,CAAC,GAAA,EAAK,kBAAkB,KAAU,KAAA;AACzC,MAAA,IAAI,KAA4B,GAAA,KAAA,CAAA,CAAA;AAChC,MAAI,IAAA;AACF,QAAA,uBAAA,CAAwB,gBAAgB,CAAA,CAAA;AAAA,eACjC,CAAG,EAAA;AACV,QAAA,KAAA,GAAQ,CAAE,CAAA,OAAA,CAAA;AAAA,OACZ;AAEA,MAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,QAAA,GAAA,CAAI,KAAK,CAA0B,uBAAA,EAAA,KAAA,GAAQ,CAAC,CAAA,CAAA,EAAI,KAAK,CAAE,CAAA,CAAA,CAAA;AAAA,OACzD;AAEA,MAAO,OAAA,GAAA,CAAA;AAAA,KACN,EAAA,KAAA,CAAM,EAAW,EAAC,CACpB,CAAA,MAAA;AAAA,MACC,MAAO,CAAA,OAAA;AAAA,QACL,iBACG,CAAA,MAAA;AAAA,UACC,gBACE,UAAW,CAAA,aAAA,KAAkB,KAC7B,CAAA,IAAA,UAAA,CAAW,cAAc,MAAS,GAAA,CAAA;AAAA,SAErC,CAAA,MAAA,CAAO,CAAC,GAAA,EAAK,YAAY,KAAU,KAAA;AAClC,UAAW,UAAA,CAAA,aAAA,EAAe,QAAQ,CAAgB,YAAA,KAAA;AAChD,YAAI,IAAA,CAAC,GAAI,CAAA,YAAY,CAAG,EAAA;AACtB,cAAI,GAAA,CAAA,YAAY,IAAI,EAAC,CAAA;AAAA,aACvB;AAEA,YAAA,GAAA,CAAI,YAAY,CAAA,CAAE,IAAK,CAAA,KAAA,GAAQ,CAAC,CAAA,CAAA;AAAA,WACjC,CAAA,CAAA;AAED,UAAO,OAAA,GAAA,CAAA;AAAA,SACT,EAAG,EAA8B,CAAA;AAAA,QAElC,MAAO,CAAA,CAAC,CAAC,CAAA,EAAG,OAAO,CAAM,KAAA,OAAA,CAAQ,MAAS,GAAA,CAAC,EAC3C,MAAO,CAAA,CAAC,KAAK,CAAC,GAAA,EAAK,OAAO,CAAM,KAAA;AAC/B,QAAI,GAAA,CAAA,IAAA;AAAA,UACF,gBAAgB,GAAG,CAAA,yDAAA,EAA4D,QAC5E,KAAM,CAAA,CAAA,EAAG,QAAQ,MAAS,GAAA,CAAC,CAC3B,CAAA,IAAA,CAAK,IAAI,CAAC,CAAA,KAAA,EAAQ,QAAQ,OAAQ,CAAA,MAAA,GAAS,CAAC,CAAC,CAAA,CAAA;AAAA,SAClD,CAAA;AACA,QAAO,OAAA,GAAA,CAAA;AAAA,OACT,EAAG,KAAM,CAAA,EAAA,EAAY,CAAA;AAAA,KACzB,CAAA;AAEF,IAAI,IAAA,MAAA,EAAQ,SAAS,CAAG,EAAA;AACtB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,wCAAwC,IAAI,CAAA,EAAA,EAAK,MAAO,CAAA,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA;AAAA,OACpE,CAAA;AAAA,KACF;AAEA,IAAA,WAAA,GAAc,iBAAkB,CAAA,GAAA;AAAA,MAAI,CAAA,gBAAA,KAClC,wBAAwB,gBAAgB,CAAA;AAAA,KAC1C,CAAA;AAEA,IAAA,IACE,WAAY,CAAA,IAAA;AAAA,MACV,CAAA,UAAA,KAAc,WAAW,IAAS,KAAA,qBAAA;AAAA,KACpC,IACA,SAAS,UACT,EAAA;AACA,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,qCAAA,EAAwC,IAAI,CAAA,gEAAA,EAAmE,UAAU,CAAA,CAAA;AAAA,OAC3H,CAAA;AAAA,KACF;AAEA,IAAA,IACE,WAAY,CAAA,MAAA;AAAA,MACV,gBACE,UAAW,CAAA,aAAA,KAAkB,KAC7B,CAAA,IAAA,UAAA,CAAW,cAAc,MAAW,KAAA,CAAA;AAAA,KACxC,CAAE,SAAS,CACX,EAAA;AACA,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,wCAAwC,IAAI,CAAA,+DAAA,CAAA;AAAA,OAC9C,CAAA;AAAA,KACF;AAAA,GACF;AAEA,EAAO,OAAA;AAAA,IACL,IAAA;AAAA,IACA,WAAA;AAAA,GACF,CAAA;AACF,CAAA;AASO,SAAS,4BACd,OAC0B,EAAA;AAE1B,EAAM,MAAA,MAAA,GAAS,OAAQ,CAAA,GAAA,CAAI,0BAA0B,CAAA,CAAA;AAIrD,EAAA,IAAI,CAAC,MAAO,CAAA,IAAA,CAAK,OAAK,CAAE,CAAA,IAAA,KAAS,UAAU,CAAG,EAAA;AAC5C,IAAA,MAAA,CAAO,IAAK,CAAA,EAAE,IAAM,EAAA,UAAA,EAAY,CAAA,CAAA;AAAA,GAClC;AAEA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { CachedAzureDevOpsCredentialsProvider } from './CachedAzureDevOpsCredentialsProvider.esm.js';
|
|
2
2
|
|
|
3
3
|
async function getAzureRequestOptions(config, additionalHeaders) {
|
|
4
|
-
var _a;
|
|
5
4
|
const headers = additionalHeaders ? { ...additionalHeaders } : {};
|
|
6
|
-
const credentialConfig =
|
|
5
|
+
const credentialConfig = config.credentials?.filter(
|
|
7
6
|
(credential) => credential.organizations === void 0 || credential.organizations.length === 0
|
|
8
7
|
)[0];
|
|
9
8
|
if (credentialConfig) {
|
|
@@ -13,7 +12,7 @@ async function getAzureRequestOptions(config, additionalHeaders) {
|
|
|
13
12
|
const credentials = await credentialsProvider.getCredentials();
|
|
14
13
|
return {
|
|
15
14
|
headers: {
|
|
16
|
-
...credentials
|
|
15
|
+
...credentials?.headers,
|
|
17
16
|
...headers
|
|
18
17
|
}
|
|
19
18
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deprecated.esm.js","sources":["../../src/azure/deprecated.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport { AzureIntegrationConfig } from './config';\nimport { CachedAzureDevOpsCredentialsProvider } from './CachedAzureDevOpsCredentialsProvider';\n\n/**\n * Gets the request options necessary to make requests to a given provider.\n *\n * @param config - The relevant provider config\n * @param additionalHeaders - Additional headers for the request\n * @public\n * @deprecated Use {@link AzureDevOpsCredentialsProvider} instead.\n */\nexport async function getAzureRequestOptions(\n config: AzureIntegrationConfig,\n additionalHeaders?: Record<string, string>,\n): Promise<{ headers: Record<string, string> }> {\n const headers: Record<string, string> = additionalHeaders\n ? { ...additionalHeaders }\n : {};\n\n /*\n * Since we do not have a way to determine which organization the request is for,\n * we will use the first credential that does not have an organization specified.\n */\n const credentialConfig = config.credentials?.filter(\n credential =>\n credential.organizations === undefined ||\n credential.organizations.length === 0,\n )[0];\n\n if (credentialConfig) {\n const credentialsProvider =\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credentialConfig,\n );\n const credentials = await credentialsProvider.getCredentials();\n\n return {\n headers: {\n ...credentials?.headers,\n ...headers,\n },\n };\n }\n\n return { headers };\n}\n"],"names":[],"mappings":";;AA0BsB,eAAA,sBAAA,CACpB,QACA,iBAC8C,EAAA;
|
|
1
|
+
{"version":3,"file":"deprecated.esm.js","sources":["../../src/azure/deprecated.ts"],"sourcesContent":["/*\n * Copyright 2023 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 */\nimport { AzureIntegrationConfig } from './config';\nimport { CachedAzureDevOpsCredentialsProvider } from './CachedAzureDevOpsCredentialsProvider';\n\n/**\n * Gets the request options necessary to make requests to a given provider.\n *\n * @param config - The relevant provider config\n * @param additionalHeaders - Additional headers for the request\n * @public\n * @deprecated Use {@link AzureDevOpsCredentialsProvider} instead.\n */\nexport async function getAzureRequestOptions(\n config: AzureIntegrationConfig,\n additionalHeaders?: Record<string, string>,\n): Promise<{ headers: Record<string, string> }> {\n const headers: Record<string, string> = additionalHeaders\n ? { ...additionalHeaders }\n : {};\n\n /*\n * Since we do not have a way to determine which organization the request is for,\n * we will use the first credential that does not have an organization specified.\n */\n const credentialConfig = config.credentials?.filter(\n credential =>\n credential.organizations === undefined ||\n credential.organizations.length === 0,\n )[0];\n\n if (credentialConfig) {\n const credentialsProvider =\n CachedAzureDevOpsCredentialsProvider.fromAzureDevOpsCredential(\n credentialConfig,\n );\n const credentials = await credentialsProvider.getCredentials();\n\n return {\n headers: {\n ...credentials?.headers,\n ...headers,\n },\n };\n }\n\n return { headers };\n}\n"],"names":[],"mappings":";;AA0BsB,eAAA,sBAAA,CACpB,QACA,iBAC8C,EAAA;AAC9C,EAAA,MAAM,UAAkC,iBACpC,GAAA,EAAE,GAAG,iBAAA,KACL,EAAC,CAAA;AAML,EAAM,MAAA,gBAAA,GAAmB,OAAO,WAAa,EAAA,MAAA;AAAA,IAC3C,gBACE,UAAW,CAAA,aAAA,KAAkB,KAC7B,CAAA,IAAA,UAAA,CAAW,cAAc,MAAW,KAAA,CAAA;AAAA,IACtC,CAAC,CAAA,CAAA;AAEH,EAAA,IAAI,gBAAkB,EAAA;AACpB,IAAA,MAAM,sBACJ,oCAAqC,CAAA,yBAAA;AAAA,MACnC,gBAAA;AAAA,KACF,CAAA;AACF,IAAM,MAAA,WAAA,GAAc,MAAM,mBAAA,CAAoB,cAAe,EAAA,CAAA;AAE7D,IAAO,OAAA;AAAA,MACL,OAAS,EAAA;AAAA,QACP,GAAG,WAAa,EAAA,OAAA;AAAA,QAChB,GAAG,OAAA;AAAA,OACL;AAAA,KACF,CAAA;AAAA,GACF;AAEA,EAAA,OAAO,EAAE,OAAQ,EAAA,CAAA;AACnB;;;;"}
|