@backstage/backend-defaults 0.8.2-next.2 → 0.8.2

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,32 @@
1
1
  # @backstage/backend-defaults
2
2
 
3
+ ## 0.8.2
4
+
5
+ ### Patch Changes
6
+
7
+ - e293b66: The default auditor service implementation will now log low severity events with `debug` level instead of `info`.
8
+ - f422984: Remove unused dependencies
9
+ - ecb9bab: Explicitly stringify extra logger fields with `JSON.stringify` to prevent `[object Object]` errors.
10
+ - 12f8e01: The `discovery.endpoints` configuration no longer requires both `internal` and `external` target when using the object form, instead falling back to the default.
11
+ - 89db8b8: `GerritUrlReader` is now able to `search` files matching a given pattern URL (using `minimatch` glob patterns).
12
+
13
+ This allows the Gerrit Discovery to find all Backstage manifests inside a repository using the `**/catalog-info.yaml` pattern.
14
+
15
+ - Updated dependencies
16
+ - @backstage/config-loader@1.10.0
17
+ - @backstage/integration@1.16.2
18
+ - @backstage/plugin-permission-node@0.9.0
19
+ - @backstage/plugin-auth-node@0.6.1
20
+ - @backstage/plugin-events-node@0.4.9
21
+ - @backstage/backend-app-api@1.2.1
22
+ - @backstage/integration-aws-node@0.1.15
23
+ - @backstage/backend-dev-utils@0.1.5
24
+ - @backstage/backend-plugin-api@1.2.1
25
+ - @backstage/cli-node@0.2.13
26
+ - @backstage/config@1.3.2
27
+ - @backstage/errors@1.2.7
28
+ - @backstage/types@1.2.1
29
+
3
30
  ## 0.8.2-next.2
4
31
 
5
32
  ### Patch Changes
@@ -5,6 +5,7 @@ var fetch = require('node-fetch');
5
5
  var stream = require('stream');
6
6
  var integration = require('@backstage/integration');
7
7
  var errors = require('@backstage/errors');
8
+ var minimatch = require('minimatch');
8
9
 
9
10
  function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
10
11
 
@@ -78,32 +79,34 @@ class GerritUrlReader {
78
79
  return this.readTreeFromGitiles(url, urlRevision, options);
79
80
  }
80
81
  async search(url, options) {
81
- const { pathname } = new URL(url);
82
- if (pathname.match(/[*?]/)) {
83
- throw new Error("Unsupported search pattern URL");
84
- }
85
- try {
86
- const data = await this.readUrl(url, options);
87
- return {
88
- files: [
89
- {
90
- url,
91
- content: data.buffer,
92
- lastModifiedAt: data.lastModifiedAt
93
- }
94
- ],
95
- etag: data.etag ?? ""
96
- };
97
- } catch (error) {
98
- errors.assertError(error);
99
- if (error.name === "NotFoundError") {
82
+ const { path } = integration.parseGitilesUrlRef(this.integration.config, url);
83
+ if (!path.match(/[*?]/)) {
84
+ try {
85
+ const data = await this.readUrl(url, options);
100
86
  return {
101
- files: [],
102
- etag: ""
87
+ files: [
88
+ {
89
+ url,
90
+ content: data.buffer,
91
+ lastModifiedAt: data.lastModifiedAt
92
+ }
93
+ ],
94
+ etag: data.etag ?? ""
103
95
  };
96
+ } catch (error) {
97
+ errors.assertError(error);
98
+ if (error.name === "NotFoundError") {
99
+ return {
100
+ files: [],
101
+ etag: ""
102
+ };
103
+ }
104
+ throw error;
104
105
  }
105
- throw error;
106
106
  }
107
+ const urlRevision = await this.getRevisionForUrl(url, options);
108
+ const files = await this.searchFilesFromGitiles(url, options);
109
+ return { files, etag: urlRevision };
107
110
  }
108
111
  toString() {
109
112
  const { host, password } = this.integration.config;
@@ -166,6 +169,53 @@ class GerritUrlReader {
166
169
  }
167
170
  return branchInfo.revision;
168
171
  }
172
+ async searchFilesFromGitiles(url, options) {
173
+ const { path, basePath } = integration.parseGitilesUrlRef(this.integration.config, url);
174
+ const treeUrl = `${basePath}/?format=JSON&recursive`.replace(
175
+ this.integration.config.gitilesBaseUrl,
176
+ integration.getGitilesAuthenticationUrl(this.integration.config)
177
+ );
178
+ const treeResponse = await fetch__default.default(treeUrl, {
179
+ ...integration.getGerritRequestOptions(this.integration.config),
180
+ // TODO(freben): The signal cast is there because pre-3.x versions of
181
+ // node-fetch have a very slightly deviating AbortSignal type signature.
182
+ // The difference does not affect us in practice however. The cast can
183
+ // be removed after we support ESM for CLI dependencies and migrate to
184
+ // version 3 of node-fetch.
185
+ // https://github.com/backstage/backstage/issues/8242
186
+ signal: options?.signal
187
+ });
188
+ if (!treeResponse.ok) {
189
+ throw await errors.ResponseError.fromResponse(treeResponse);
190
+ }
191
+ const res = await integration.parseGerritJsonResponse(treeResponse);
192
+ const matcher = new minimatch.Minimatch(decodeURIComponent(path).replace(/^\/+/, ""));
193
+ const matching = res.entries.filter(
194
+ (item) => item.type === "blob" && item.name && matcher.match(item.name)
195
+ );
196
+ return matching.map((item) => ({
197
+ url: `${basePath}/${item.name}`,
198
+ content: async () => {
199
+ const apiUrl = integration.getGerritFileContentsApiUrl(
200
+ this.integration.config,
201
+ `${basePath}/${item.name}`
202
+ );
203
+ const response = await fetch__default.default(apiUrl, {
204
+ method: "GET",
205
+ ...integration.getGerritRequestOptions(this.integration.config),
206
+ // TODO(freben): The signal cast is there because pre-3.x versions of
207
+ // node-fetch have a very slightly deviating AbortSignal type signature.
208
+ // The difference does not affect us in practice however. The cast can
209
+ // be removed after we support ESM for CLI dependencies and migrate to
210
+ // version 3 of node-fetch.
211
+ // https://github.com/backstage/backstage/issues/8242
212
+ signal: options?.signal
213
+ });
214
+ const responseBody = await response.text();
215
+ return Buffer.from(responseBody, "base64");
216
+ }
217
+ }));
218
+ }
169
219
  }
170
220
 
171
221
  exports.GerritUrlReader = GerritUrlReader;
@@ -1 +1 @@
1
- {"version":3,"file":"GerritUrlReader.cjs.js","sources":["../../../../src/entrypoints/urlReader/lib/GerritUrlReader.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 UrlReaderService,\n UrlReaderServiceReadTreeOptions,\n UrlReaderServiceReadTreeResponse,\n UrlReaderServiceReadUrlOptions,\n UrlReaderServiceReadUrlResponse,\n UrlReaderServiceSearchOptions,\n UrlReaderServiceSearchResponse,\n} from '@backstage/backend-plugin-api';\nimport { Base64Decode } from 'base64-stream';\nimport fetch, { Response } from 'node-fetch';\nimport { Readable } from 'stream';\nimport {\n GerritIntegration,\n ScmIntegrations,\n buildGerritGitilesArchiveUrlFromLocation,\n getGerritBranchApiUrl,\n getGerritFileContentsApiUrl,\n getGerritRequestOptions,\n parseGerritJsonResponse,\n parseGitilesUrlRef,\n} from '@backstage/integration';\nimport {\n NotFoundError,\n NotModifiedError,\n ResponseError,\n assertError,\n} from '@backstage/errors';\nimport { ReadTreeResponseFactory, ReaderFactory } from './types';\n\n/**\n * Implements a {@link @backstage/backend-plugin-api#UrlReaderService} for files in Gerrit.\n *\n * @remarks\n * To be able to link to Git contents for Gerrit providers in a user friendly\n * way we are depending on that there is a Gitiles installation somewhere\n * that we can link to. It is perfectly possible to integrate Gerrit with\n * Backstage without Gitiles since all API calls goes directly to Gerrit.\n * However if Gitiles is configured, readTree will use it to fetch\n * an archive instead of cloning the repository.\n *\n * The \"host\" variable in the config is the Gerrit host. The address where\n * Gitiles is installed may be on the same host but it could be on a\n * separate host. For example a Gerrit instance could be hosted on\n * \"gerrit-review.company.com\" but the repos could be browsable on a separate\n * host, e.g. \"gerrit.company.com\" and the human readable URL would then\n * not point to the API host.\n *\n * @public\n */\nexport class GerritUrlReader implements UrlReaderService {\n static factory: ReaderFactory = ({ config, treeResponseFactory }) => {\n const integrations = ScmIntegrations.fromConfig(config);\n if (!integrations.gerrit) {\n return [];\n }\n return integrations.gerrit.list().map(integration => {\n const reader = new GerritUrlReader(integration, { treeResponseFactory });\n const predicate = (url: URL) => {\n const gitilesUrl = new URL(integration.config.gitilesBaseUrl!);\n // If gitilesUrl is not specified it will default to\n // \"integration.config.host\".\n return url.host === gitilesUrl.host;\n };\n return { reader, predicate };\n });\n };\n\n constructor(\n private readonly integration: GerritIntegration,\n private readonly deps: { treeResponseFactory: ReadTreeResponseFactory },\n ) {}\n\n async read(url: string): Promise<Buffer> {\n const response = await this.readUrl(url);\n return response.buffer();\n }\n\n async readUrl(\n url: string,\n options?: UrlReaderServiceReadUrlOptions,\n ): Promise<UrlReaderServiceReadUrlResponse> {\n const apiUrl = getGerritFileContentsApiUrl(this.integration.config, url);\n let response: Response;\n try {\n response = await fetch(apiUrl, {\n method: 'GET',\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n } catch (e) {\n throw new Error(`Unable to read gerrit file ${url}, ${e}`);\n }\n\n if (response.ok) {\n let responseBody: string;\n return {\n buffer: async () => {\n if (responseBody === undefined) {\n responseBody = await response.text();\n }\n return Buffer.from(responseBody, 'base64');\n },\n stream: () => {\n const readable = Readable.from(response.body);\n return readable.pipe(new Base64Decode());\n },\n };\n }\n if (response.status === 404) {\n throw new NotFoundError(`File ${url} not found.`);\n }\n throw new Error(\n `${url} could not be read as ${apiUrl}, ${response.status} ${response.statusText}`,\n );\n }\n\n async readTree(\n url: string,\n options?: UrlReaderServiceReadTreeOptions,\n ): Promise<UrlReaderServiceReadTreeResponse> {\n const urlRevision = await this.getRevisionForUrl(url, options);\n\n return this.readTreeFromGitiles(url, urlRevision, options);\n }\n\n async search(\n url: string,\n options?: UrlReaderServiceSearchOptions,\n ): Promise<UrlReaderServiceSearchResponse> {\n const { pathname } = new URL(url);\n\n if (pathname.match(/[*?]/)) {\n throw new Error('Unsupported search pattern URL');\n }\n\n try {\n const data = await this.readUrl(url, options);\n\n return {\n files: [\n {\n url: url,\n content: data.buffer,\n lastModifiedAt: data.lastModifiedAt,\n },\n ],\n etag: data.etag ?? '',\n };\n } catch (error) {\n assertError(error);\n if (error.name === 'NotFoundError') {\n return {\n files: [],\n etag: '',\n };\n }\n throw error;\n }\n }\n\n toString() {\n const { host, password } = this.integration.config;\n return `gerrit{host=${host},authed=${Boolean(password)}}`;\n }\n\n private async readTreeFromGitiles(\n url: string,\n revision: string,\n options?: UrlReaderServiceReadTreeOptions,\n ) {\n const archiveUrl = buildGerritGitilesArchiveUrlFromLocation(\n this.integration.config,\n url,\n );\n const archiveResponse = await fetch(archiveUrl, {\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n\n if (archiveResponse.status === 404) {\n throw new NotFoundError(`Not found: ${archiveUrl}`);\n }\n\n if (!archiveResponse.ok) {\n throw new Error(\n `${url} could not be read as ${archiveUrl}, ${archiveResponse.status} ${archiveResponse.statusText}`,\n );\n }\n\n return await this.deps.treeResponseFactory.fromTarArchive({\n stream: archiveResponse.body as unknown as Readable,\n etag: revision,\n filter: options?.filter,\n stripFirstDirectory: false,\n });\n }\n\n private async getRevisionForUrl(\n url: string,\n options?: UrlReaderServiceReadTreeOptions,\n ): Promise<string> {\n const { ref, refType } = parseGitilesUrlRef(this.integration.config, url);\n // The url points to a static revision.\n if (refType === 'sha') {\n if (options?.etag === ref) {\n throw new NotModifiedError();\n }\n return ref;\n }\n\n const apiUrl = getGerritBranchApiUrl(this.integration.config, url);\n let response: Response;\n try {\n response = await fetch(apiUrl, {\n method: 'GET',\n ...getGerritRequestOptions(this.integration.config),\n });\n } catch (e) {\n throw new Error(`Unable to read branch state ${url}, ${e}`);\n }\n\n if (!response.ok) {\n throw await ResponseError.fromResponse(response);\n }\n\n const branchInfo = (await parseGerritJsonResponse(response as any)) as {\n revision: string;\n };\n if (options?.etag === branchInfo.revision) {\n throw new NotModifiedError();\n }\n return branchInfo.revision;\n }\n}\n"],"names":["ScmIntegrations","getGerritFileContentsApiUrl","fetch","getGerritRequestOptions","Readable","Base64Decode","NotFoundError","assertError","buildGerritGitilesArchiveUrlFromLocation","parseGitilesUrlRef","NotModifiedError","getGerritBranchApiUrl","ResponseError","parseGerritJsonResponse"],"mappings":"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"}
1
+ {"version":3,"file":"GerritUrlReader.cjs.js","sources":["../../../../src/entrypoints/urlReader/lib/GerritUrlReader.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 UrlReaderService,\n UrlReaderServiceReadTreeOptions,\n UrlReaderServiceReadTreeResponse,\n UrlReaderServiceReadUrlOptions,\n UrlReaderServiceReadUrlResponse,\n UrlReaderServiceSearchOptions,\n UrlReaderServiceSearchResponse,\n} from '@backstage/backend-plugin-api';\nimport { Base64Decode } from 'base64-stream';\nimport fetch, { Response } from 'node-fetch';\nimport { Readable } from 'stream';\nimport {\n GerritIntegration,\n ScmIntegrations,\n buildGerritGitilesArchiveUrlFromLocation,\n getGerritBranchApiUrl,\n getGerritFileContentsApiUrl,\n getGerritRequestOptions,\n parseGerritJsonResponse,\n parseGitilesUrlRef,\n} from '@backstage/integration';\nimport {\n NotFoundError,\n NotModifiedError,\n ResponseError,\n assertError,\n} from '@backstage/errors';\nimport { ReadTreeResponseFactory, ReaderFactory } from './types';\nimport { Minimatch } from 'minimatch';\nimport { getGitilesAuthenticationUrl } from '@backstage/integration';\n\n/**\n * Implements a {@link @backstage/backend-plugin-api#UrlReaderService} for files in Gerrit.\n *\n * @remarks\n * To be able to link to Git contents for Gerrit providers in a user friendly\n * way we are depending on that there is a Gitiles installation somewhere\n * that we can link to. It is perfectly possible to integrate Gerrit with\n * Backstage without Gitiles since all API calls goes directly to Gerrit.\n * However if Gitiles is configured, readTree will use it to fetch\n * an archive instead of cloning the repository.\n *\n * The \"host\" variable in the config is the Gerrit host. The address where\n * Gitiles is installed may be on the same host but it could be on a\n * separate host. For example a Gerrit instance could be hosted on\n * \"gerrit-review.company.com\" but the repos could be browsable on a separate\n * host, e.g. \"gerrit.company.com\" and the human readable URL would then\n * not point to the API host.\n *\n * @public\n */\nexport class GerritUrlReader implements UrlReaderService {\n static factory: ReaderFactory = ({ config, treeResponseFactory }) => {\n const integrations = ScmIntegrations.fromConfig(config);\n if (!integrations.gerrit) {\n return [];\n }\n return integrations.gerrit.list().map(integration => {\n const reader = new GerritUrlReader(integration, { treeResponseFactory });\n const predicate = (url: URL) => {\n const gitilesUrl = new URL(integration.config.gitilesBaseUrl!);\n // If gitilesUrl is not specified it will default to\n // \"integration.config.host\".\n return url.host === gitilesUrl.host;\n };\n return { reader, predicate };\n });\n };\n\n constructor(\n private readonly integration: GerritIntegration,\n private readonly deps: { treeResponseFactory: ReadTreeResponseFactory },\n ) {}\n\n async read(url: string): Promise<Buffer> {\n const response = await this.readUrl(url);\n return response.buffer();\n }\n\n async readUrl(\n url: string,\n options?: UrlReaderServiceReadUrlOptions,\n ): Promise<UrlReaderServiceReadUrlResponse> {\n const apiUrl = getGerritFileContentsApiUrl(this.integration.config, url);\n let response: Response;\n try {\n response = await fetch(apiUrl, {\n method: 'GET',\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n } catch (e) {\n throw new Error(`Unable to read gerrit file ${url}, ${e}`);\n }\n\n if (response.ok) {\n let responseBody: string;\n return {\n buffer: async () => {\n if (responseBody === undefined) {\n responseBody = await response.text();\n }\n return Buffer.from(responseBody, 'base64');\n },\n stream: () => {\n const readable = Readable.from(response.body);\n return readable.pipe(new Base64Decode());\n },\n };\n }\n if (response.status === 404) {\n throw new NotFoundError(`File ${url} not found.`);\n }\n throw new Error(\n `${url} could not be read as ${apiUrl}, ${response.status} ${response.statusText}`,\n );\n }\n\n async readTree(\n url: string,\n options?: UrlReaderServiceReadTreeOptions,\n ): Promise<UrlReaderServiceReadTreeResponse> {\n const urlRevision = await this.getRevisionForUrl(url, options);\n\n return this.readTreeFromGitiles(url, urlRevision, options);\n }\n\n async search(\n url: string,\n options?: UrlReaderServiceSearchOptions,\n ): Promise<UrlReaderServiceSearchResponse> {\n const { path } = parseGitilesUrlRef(this.integration.config, url);\n\n if (!path.match(/[*?]/)) {\n try {\n const data = await this.readUrl(url, options);\n\n return {\n files: [\n {\n url: url,\n content: data.buffer,\n lastModifiedAt: data.lastModifiedAt,\n },\n ],\n etag: data.etag ?? '',\n };\n } catch (error) {\n assertError(error);\n if (error.name === 'NotFoundError') {\n return {\n files: [],\n etag: '',\n };\n }\n throw error;\n }\n }\n\n const urlRevision = await this.getRevisionForUrl(url, options);\n\n const files = await this.searchFilesFromGitiles(url, options);\n\n return { files, etag: urlRevision };\n }\n\n toString() {\n const { host, password } = this.integration.config;\n return `gerrit{host=${host},authed=${Boolean(password)}}`;\n }\n\n private async readTreeFromGitiles(\n url: string,\n revision: string,\n options?: UrlReaderServiceReadTreeOptions,\n ) {\n const archiveUrl = buildGerritGitilesArchiveUrlFromLocation(\n this.integration.config,\n url,\n );\n const archiveResponse = await fetch(archiveUrl, {\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n\n if (archiveResponse.status === 404) {\n throw new NotFoundError(`Not found: ${archiveUrl}`);\n }\n\n if (!archiveResponse.ok) {\n throw new Error(\n `${url} could not be read as ${archiveUrl}, ${archiveResponse.status} ${archiveResponse.statusText}`,\n );\n }\n\n return await this.deps.treeResponseFactory.fromTarArchive({\n stream: archiveResponse.body as unknown as Readable,\n etag: revision,\n filter: options?.filter,\n stripFirstDirectory: false,\n });\n }\n\n private async getRevisionForUrl(\n url: string,\n options?: UrlReaderServiceReadTreeOptions,\n ): Promise<string> {\n const { ref, refType } = parseGitilesUrlRef(this.integration.config, url);\n // The url points to a static revision.\n if (refType === 'sha') {\n if (options?.etag === ref) {\n throw new NotModifiedError();\n }\n return ref;\n }\n\n const apiUrl = getGerritBranchApiUrl(this.integration.config, url);\n let response: Response;\n try {\n response = await fetch(apiUrl, {\n method: 'GET',\n ...getGerritRequestOptions(this.integration.config),\n });\n } catch (e) {\n throw new Error(`Unable to read branch state ${url}, ${e}`);\n }\n\n if (!response.ok) {\n throw await ResponseError.fromResponse(response);\n }\n\n const branchInfo = (await parseGerritJsonResponse(response as any)) as {\n revision: string;\n };\n if (options?.etag === branchInfo.revision) {\n throw new NotModifiedError();\n }\n return branchInfo.revision;\n }\n\n private async searchFilesFromGitiles(\n url: string,\n options?: UrlReaderServiceReadTreeOptions,\n ): Promise<UrlReaderServiceSearchResponse['files']> {\n const { path, basePath } = parseGitilesUrlRef(this.integration.config, url);\n\n const treeUrl = `${basePath}/?format=JSON&recursive`.replace(\n this.integration.config.gitilesBaseUrl,\n getGitilesAuthenticationUrl(this.integration.config),\n );\n\n const treeResponse = await fetch(treeUrl, {\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n if (!treeResponse.ok) {\n throw await ResponseError.fromResponse(treeResponse);\n }\n\n const res = (await parseGerritJsonResponse(treeResponse as any)) as {\n id: string;\n entries: { mode: number; type: string; id: string; name: string }[];\n };\n\n const matcher = new Minimatch(decodeURIComponent(path).replace(/^\\/+/, ''));\n\n const matching = res.entries.filter(\n item => item.type === 'blob' && item.name && matcher.match(item.name),\n );\n\n return matching.map(item => ({\n url: `${basePath}/${item.name}`,\n content: async () => {\n const apiUrl = getGerritFileContentsApiUrl(\n this.integration.config,\n `${basePath}/${item.name}`,\n );\n const response = await fetch(apiUrl, {\n method: 'GET',\n ...getGerritRequestOptions(this.integration.config),\n // TODO(freben): The signal cast is there because pre-3.x versions of\n // node-fetch have a very slightly deviating AbortSignal type signature.\n // The difference does not affect us in practice however. The cast can\n // be removed after we support ESM for CLI dependencies and migrate to\n // version 3 of node-fetch.\n // https://github.com/backstage/backstage/issues/8242\n signal: options?.signal as any,\n });\n\n const responseBody = await response.text();\n return Buffer.from(responseBody, 'base64');\n },\n }));\n }\n}\n"],"names":["ScmIntegrations","getGerritFileContentsApiUrl","fetch","getGerritRequestOptions","Readable","Base64Decode","NotFoundError","parseGitilesUrlRef","assertError","buildGerritGitilesArchiveUrlFromLocation","NotModifiedError","getGerritBranchApiUrl","ResponseError","parseGerritJsonResponse","getGitilesAuthenticationUrl","Minimatch"],"mappings":"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"}
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var name = "@backstage/backend-defaults";
6
- var version = "0.8.2-next.2";
6
+ var version = "0.8.2";
7
7
  var description = "Backend defaults used by Backstage backend apps";
8
8
  var backstage = {
9
9
  role: "node-library"
@@ -130,12 +130,10 @@ var dependencies = {
130
130
  "@aws-sdk/client-s3": "^3.350.0",
131
131
  "@aws-sdk/credential-providers": "^3.350.0",
132
132
  "@aws-sdk/types": "^3.347.0",
133
- "@azure/identity": "^4.0.0",
134
133
  "@azure/storage-blob": "^12.5.0",
135
134
  "@backstage/backend-app-api": "workspace:^",
136
135
  "@backstage/backend-dev-utils": "workspace:^",
137
136
  "@backstage/backend-plugin-api": "workspace:^",
138
- "@backstage/cli-common": "workspace:^",
139
137
  "@backstage/cli-node": "workspace:^",
140
138
  "@backstage/config": "workspace:^",
141
139
  "@backstage/config-loader": "workspace:^",
@@ -167,7 +165,6 @@ var dependencies = {
167
165
  "fs-extra": "^11.2.0",
168
166
  "git-url-parse": "^15.0.0",
169
167
  helmet: "^6.0.0",
170
- "isomorphic-git": "^1.23.0",
171
168
  jose: "^5.0.0",
172
169
  keyv: "^5.2.1",
173
170
  knex: "^3.0.0",
@@ -175,7 +172,6 @@ var dependencies = {
175
172
  logform: "^2.3.2",
176
173
  luxon: "^3.0.0",
177
174
  minimatch: "^9.0.0",
178
- minimist: "^1.2.5",
179
175
  mysql2: "^3.0.0",
180
176
  "node-fetch": "^2.7.0",
181
177
  "node-forge": "^1.3.1",
@@ -204,11 +200,11 @@ var devDependencies = {
204
200
  "@google-cloud/cloud-sql-connector": "^1.4.0",
205
201
  "@types/archiver": "^6.0.0",
206
202
  "@types/base64-stream": "^1.0.2",
203
+ "@types/compression": "^1.7.5",
207
204
  "@types/concat-stream": "^2.0.0",
208
205
  "@types/http-errors": "^2.0.0",
209
206
  "@types/node-forge": "^1.3.0",
210
207
  "@types/pg-format": "^1.0.5",
211
- "@types/stoppable": "^1.1.0",
212
208
  "@types/yauzl": "^2.10.0",
213
209
  "aws-sdk-client-mock": "^4.0.0",
214
210
  "http-errors": "^2.0.0",
@@ -1 +1 @@
1
- {"version":3,"file":"package.json.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"package.json.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -212,6 +212,7 @@ declare class GerritUrlReader implements UrlReaderService {
212
212
  toString(): string;
213
213
  private readTreeFromGitiles;
214
214
  private getRevisionForUrl;
215
+ private searchFilesFromGitiles;
215
216
  }
216
217
 
217
218
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage/backend-defaults",
3
- "version": "0.8.2-next.2",
3
+ "version": "0.8.2",
4
4
  "description": "Backend defaults used by Backstage backend apps",
5
5
  "backstage": {
6
6
  "role": "node-library"
@@ -207,22 +207,20 @@
207
207
  "@aws-sdk/client-s3": "^3.350.0",
208
208
  "@aws-sdk/credential-providers": "^3.350.0",
209
209
  "@aws-sdk/types": "^3.347.0",
210
- "@azure/identity": "^4.0.0",
211
210
  "@azure/storage-blob": "^12.5.0",
212
- "@backstage/backend-app-api": "1.2.1-next.2",
213
- "@backstage/backend-dev-utils": "0.1.5",
214
- "@backstage/backend-plugin-api": "1.2.1-next.1",
215
- "@backstage/cli-common": "0.1.15",
216
- "@backstage/cli-node": "0.2.13",
217
- "@backstage/config": "1.3.2",
218
- "@backstage/config-loader": "1.10.0-next.0",
219
- "@backstage/errors": "1.2.7",
220
- "@backstage/integration": "1.16.2-next.0",
221
- "@backstage/integration-aws-node": "0.1.15",
222
- "@backstage/plugin-auth-node": "0.6.1-next.1",
223
- "@backstage/plugin-events-node": "0.4.9-next.2",
224
- "@backstage/plugin-permission-node": "0.8.9-next.1",
225
- "@backstage/types": "1.2.1",
211
+ "@backstage/backend-app-api": "^1.2.1",
212
+ "@backstage/backend-dev-utils": "^0.1.5",
213
+ "@backstage/backend-plugin-api": "^1.2.1",
214
+ "@backstage/cli-node": "^0.2.13",
215
+ "@backstage/config": "^1.3.2",
216
+ "@backstage/config-loader": "^1.10.0",
217
+ "@backstage/errors": "^1.2.7",
218
+ "@backstage/integration": "^1.16.2",
219
+ "@backstage/integration-aws-node": "^0.1.15",
220
+ "@backstage/plugin-auth-node": "^0.6.1",
221
+ "@backstage/plugin-events-node": "^0.4.9",
222
+ "@backstage/plugin-permission-node": "^0.9.0",
223
+ "@backstage/types": "^1.2.1",
226
224
  "@google-cloud/storage": "^7.0.0",
227
225
  "@keyv/memcache": "^2.0.1",
228
226
  "@keyv/redis": "^4.0.1",
@@ -244,7 +242,6 @@
244
242
  "fs-extra": "^11.2.0",
245
243
  "git-url-parse": "^15.0.0",
246
244
  "helmet": "^6.0.0",
247
- "isomorphic-git": "^1.23.0",
248
245
  "jose": "^5.0.0",
249
246
  "keyv": "^5.2.1",
250
247
  "knex": "^3.0.0",
@@ -252,7 +249,6 @@
252
249
  "logform": "^2.3.2",
253
250
  "luxon": "^3.0.0",
254
251
  "minimatch": "^9.0.0",
255
- "minimist": "^1.2.5",
256
252
  "mysql2": "^3.0.0",
257
253
  "node-fetch": "^2.7.0",
258
254
  "node-forge": "^1.3.1",
@@ -275,17 +271,17 @@
275
271
  },
276
272
  "devDependencies": {
277
273
  "@aws-sdk/util-stream-node": "^3.350.0",
278
- "@backstage/backend-plugin-api": "1.2.1-next.1",
279
- "@backstage/backend-test-utils": "1.3.1-next.2",
280
- "@backstage/cli": "0.31.0-next.1",
274
+ "@backstage/backend-plugin-api": "^1.2.1",
275
+ "@backstage/backend-test-utils": "^1.3.1",
276
+ "@backstage/cli": "^0.31.0",
281
277
  "@google-cloud/cloud-sql-connector": "^1.4.0",
282
278
  "@types/archiver": "^6.0.0",
283
279
  "@types/base64-stream": "^1.0.2",
280
+ "@types/compression": "^1.7.5",
284
281
  "@types/concat-stream": "^2.0.0",
285
282
  "@types/http-errors": "^2.0.0",
286
283
  "@types/node-forge": "^1.3.0",
287
284
  "@types/pg-format": "^1.0.5",
288
- "@types/stoppable": "^1.1.0",
289
285
  "@types/yauzl": "^2.10.0",
290
286
  "aws-sdk-client-mock": "^4.0.0",
291
287
  "http-errors": "^2.0.0",