@backstage/plugin-catalog-backend-module-bitbucket-server 0.4.0-next.1 → 0.4.1-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 CHANGED
@@ -1,5 +1,40 @@
1
1
  # @backstage/plugin-catalog-backend-module-bitbucket-server
2
2
 
3
+ ## 0.4.1-next.0
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies
8
+ - @backstage/integration@1.16.4-next.0
9
+ - @backstage/catalog-client@1.10.0-next.0
10
+ - @backstage/plugin-catalog-node@1.17.0-next.0
11
+ - @backstage/backend-plugin-api@1.3.1-next.0
12
+ - @backstage/plugin-events-node@0.4.11-next.0
13
+ - @backstage/catalog-model@1.7.3
14
+ - @backstage/config@1.3.2
15
+ - @backstage/errors@1.2.7
16
+ - @backstage/plugin-catalog-common@1.1.3
17
+
18
+ ## 0.4.0
19
+
20
+ ### Minor Changes
21
+
22
+ - 1daedce: Remove Throttle of Bitbucket Server API calls
23
+ - 7b3ed9b: Added the ability for the plugin to receive events coming from Bitbucket Server push webhooks. It then performs a delta mutation on the catalog.
24
+
25
+ ### Patch Changes
26
+
27
+ - Updated dependencies
28
+ - @backstage/plugin-catalog-node@1.16.3
29
+ - @backstage/backend-plugin-api@1.3.0
30
+ - @backstage/integration@1.16.3
31
+ - @backstage/catalog-client@1.9.1
32
+ - @backstage/catalog-model@1.7.3
33
+ - @backstage/config@1.3.2
34
+ - @backstage/errors@1.2.7
35
+ - @backstage/plugin-catalog-common@1.1.3
36
+ - @backstage/plugin-events-node@0.4.10
37
+
3
38
  ## 0.4.0-next.1
4
39
 
5
40
  ### Patch Changes
@@ -1,22 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  var integration = require('@backstage/integration');
4
- var pThrottle = require('p-throttle');
5
4
  var errors = require('@backstage/errors');
6
5
 
7
- function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
8
-
9
- var pThrottle__default = /*#__PURE__*/_interopDefaultCompat(pThrottle);
10
-
11
- const throttle = pThrottle__default.default({
12
- limit: 1,
13
- interval: 1e3
14
- });
15
- const throttledFetch = throttle(
16
- async (url, options) => {
17
- return await fetch(url, options);
18
- }
19
- );
20
6
  class BitbucketServerClient {
21
7
  config;
22
8
  static fromConfig(options) {
@@ -40,14 +26,14 @@ class BitbucketServerClient {
40
26
  );
41
27
  }
42
28
  async getFile(options) {
43
- return throttledFetch(
29
+ return fetch(
44
30
  `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}/raw/${options.path}`,
45
31
  integration.getBitbucketServerRequestOptions(this.config)
46
32
  );
47
33
  }
48
34
  async getRepository(options) {
49
35
  const request = `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}`;
50
- const response = await throttledFetch(
36
+ const response = await fetch(
51
37
  request,
52
38
  integration.getBitbucketServerRequestOptions(this.config)
53
39
  );
@@ -101,17 +87,16 @@ class BitbucketServerClient {
101
87
  return this.request(new Request(url.toString(), { method: "GET" }));
102
88
  }
103
89
  async request(req) {
104
- return throttledFetch(
105
- req,
106
- integration.getBitbucketServerRequestOptions(this.config)
107
- ).then((response) => {
108
- if (!response.ok) {
109
- throw new Error(
110
- `Unexpected response for ${req.method} ${req.url}. Expected 200 but got ${response.status} - ${response.statusText}`
111
- );
90
+ return fetch(req, integration.getBitbucketServerRequestOptions(this.config)).then(
91
+ (response) => {
92
+ if (!response.ok) {
93
+ throw new Error(
94
+ `Unexpected response for ${req.method} ${req.url}. Expected 200 but got ${response.status} - ${response.statusText}`
95
+ );
96
+ }
97
+ return response;
112
98
  }
113
- return response;
114
- });
99
+ );
115
100
  }
116
101
  }
117
102
  async function* paginated(request, options) {
@@ -1 +1 @@
1
- {"version":3,"file":"BitbucketServerClient.cjs.js","sources":["../../src/lib/BitbucketServerClient.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 BitbucketServerIntegrationConfig,\n getBitbucketServerRequestOptions,\n} from '@backstage/integration';\nimport pThrottle from 'p-throttle';\nimport {\n BitbucketServerDefaultBranch,\n BitbucketServerRepository,\n} from './index';\nimport { BitbucketServerProject } from './types';\nimport { NotFoundError } from '@backstage/errors';\nimport { ResponseError } from '@backstage/errors';\n\n// 1 per second\nconst throttle = pThrottle({\n limit: 1,\n interval: 1000,\n});\n\nconst throttledFetch = throttle(\n async (url: RequestInfo, options?: RequestInit) => {\n return await fetch(url, options);\n },\n);\n\n/**\n * A client for interacting with a Bitbucket Server instance\n *\n * @public\n */\nexport class BitbucketServerClient {\n private readonly config: BitbucketServerIntegrationConfig;\n\n static fromConfig(options: {\n config: BitbucketServerIntegrationConfig;\n }): BitbucketServerClient {\n return new BitbucketServerClient(options);\n }\n\n constructor(options: { config: BitbucketServerIntegrationConfig }) {\n this.config = options.config;\n }\n\n async listProjects(options: {\n listOptions?: BitbucketServerListOptions;\n }): Promise<BitbucketServerPagedResponse<BitbucketServerProject>> {\n return this.pagedRequest(\n `${this.config.apiBaseUrl}/projects`,\n options.listOptions,\n );\n }\n\n async listRepositories(options: {\n projectKey: string;\n listOptions?: BitbucketServerListOptions;\n }): Promise<BitbucketServerPagedResponse<BitbucketServerRepository>> {\n return this.pagedRequest(\n `${this.config.apiBaseUrl}/projects/${encodeURIComponent(\n options.projectKey,\n )}/repos`,\n options.listOptions,\n );\n }\n\n async getFile(options: {\n projectKey: string;\n repo: string;\n path: string;\n }): Promise<Response> {\n return throttledFetch(\n `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}/raw/${options.path}`,\n getBitbucketServerRequestOptions(this.config),\n );\n }\n\n async getRepository(options: {\n projectKey: string;\n repo: string;\n }): Promise<BitbucketServerRepository> {\n const request = `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}`;\n const response = await throttledFetch(\n request,\n getBitbucketServerRequestOptions(this.config),\n );\n if (response.ok) {\n return response.json();\n }\n if (response.status === 404) {\n throw new NotFoundError(\n `Repository '${options.repo}' in project '${options.projectKey}' does not exist.`,\n );\n }\n throw await ResponseError.fromResponse(response);\n }\n\n async getDefaultBranch(options: {\n projectKey: string;\n repo: string;\n }): Promise<BitbucketServerDefaultBranch> {\n const request = `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}/default-branch`;\n const response = await fetch(\n request,\n getBitbucketServerRequestOptions(this.config),\n );\n if (response.ok) {\n return response.json();\n }\n if (response.status === 404) {\n throw new NotFoundError(\n `Your Bitbucket Server version no longer supports the default branch endpoint or '${options.repo}' in '${options.projectKey}' does not exist.`,\n );\n }\n throw await ResponseError.fromResponse(response);\n }\n\n resolvePath(options: { projectKey: string; repo: string; path: string }): {\n path: string;\n } {\n const base = new URL(this.config.apiBaseUrl || '');\n\n return {\n path: `${base.protocol}//${base.host}/projects/${options.projectKey}/repos/${options.repo}${options.path}`,\n };\n }\n\n private async pagedRequest(\n endpoint: string,\n options?: BitbucketServerListOptions,\n ): Promise<BitbucketServerPagedResponse<any>> {\n const request = new URL(endpoint);\n for (const key in options) {\n if (options[key]) {\n request.searchParams.append(key, options[key]!.toString());\n }\n }\n return this.getTypeMapped(request);\n }\n\n private async getTypeMapped<T = any>(url: URL): Promise<T> {\n return this.get(url).then((response: Response) => {\n return response.json() as Promise<T>;\n });\n }\n\n private async get(url: URL): Promise<Response> {\n return this.request(new Request(url.toString(), { method: 'GET' }));\n }\n\n private async request(req: Request): Promise<Response> {\n return throttledFetch(\n req,\n getBitbucketServerRequestOptions(this.config),\n ).then((response: Response) => {\n if (!response.ok) {\n throw new Error(\n `Unexpected response for ${req.method} ${req.url}. Expected 200 but got ${response.status} - ${response.statusText}`,\n );\n }\n return response;\n });\n }\n}\n\n/**\n * @public\n */\nexport type BitbucketServerListOptions = {\n [key: string]: number | undefined;\n limit?: number | undefined;\n start?: number | undefined;\n};\n\n/**\n * @public\n */\nexport type BitbucketServerPagedResponse<T> = {\n size: number;\n limit: number;\n start: number;\n isLastPage: boolean;\n values: T[];\n nextPageStart: number;\n};\n\nexport async function* paginated(\n request: (\n options: BitbucketServerListOptions,\n ) => Promise<BitbucketServerPagedResponse<any>>,\n options?: BitbucketServerListOptions,\n) {\n const opts = options || { start: 0 };\n let res;\n do {\n res = await request(opts);\n opts.start = res.nextPageStart;\n for (const item of res.values) {\n yield item;\n }\n } while (!res.isLastPage);\n}\n"],"names":["pThrottle","getBitbucketServerRequestOptions","NotFoundError","ResponseError"],"mappings":"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"}
1
+ {"version":3,"file":"BitbucketServerClient.cjs.js","sources":["../../src/lib/BitbucketServerClient.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 BitbucketServerIntegrationConfig,\n getBitbucketServerRequestOptions,\n} from '@backstage/integration';\nimport {\n BitbucketServerDefaultBranch,\n BitbucketServerRepository,\n} from './index';\nimport { BitbucketServerProject } from './types';\nimport { NotFoundError } from '@backstage/errors';\nimport { ResponseError } from '@backstage/errors';\n\n/**\n * A client for interacting with a Bitbucket Server instance\n *\n * @public\n */\nexport class BitbucketServerClient {\n private readonly config: BitbucketServerIntegrationConfig;\n\n static fromConfig(options: {\n config: BitbucketServerIntegrationConfig;\n }): BitbucketServerClient {\n return new BitbucketServerClient(options);\n }\n\n constructor(options: { config: BitbucketServerIntegrationConfig }) {\n this.config = options.config;\n }\n\n async listProjects(options: {\n listOptions?: BitbucketServerListOptions;\n }): Promise<BitbucketServerPagedResponse<BitbucketServerProject>> {\n return this.pagedRequest(\n `${this.config.apiBaseUrl}/projects`,\n options.listOptions,\n );\n }\n\n async listRepositories(options: {\n projectKey: string;\n listOptions?: BitbucketServerListOptions;\n }): Promise<BitbucketServerPagedResponse<BitbucketServerRepository>> {\n return this.pagedRequest(\n `${this.config.apiBaseUrl}/projects/${encodeURIComponent(\n options.projectKey,\n )}/repos`,\n options.listOptions,\n );\n }\n\n async getFile(options: {\n projectKey: string;\n repo: string;\n path: string;\n }): Promise<Response> {\n return fetch(\n `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}/raw/${options.path}`,\n getBitbucketServerRequestOptions(this.config),\n );\n }\n\n async getRepository(options: {\n projectKey: string;\n repo: string;\n }): Promise<BitbucketServerRepository> {\n const request = `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}`;\n const response = await fetch(\n request,\n getBitbucketServerRequestOptions(this.config),\n );\n if (response.ok) {\n return response.json();\n }\n if (response.status === 404) {\n throw new NotFoundError(\n `Repository '${options.repo}' in project '${options.projectKey}' does not exist.`,\n );\n }\n throw await ResponseError.fromResponse(response);\n }\n\n async getDefaultBranch(options: {\n projectKey: string;\n repo: string;\n }): Promise<BitbucketServerDefaultBranch> {\n const request = `${this.config.apiBaseUrl}/projects/${options.projectKey}/repos/${options.repo}/default-branch`;\n const response = await fetch(\n request,\n getBitbucketServerRequestOptions(this.config),\n );\n if (response.ok) {\n return response.json();\n }\n if (response.status === 404) {\n throw new NotFoundError(\n `Your Bitbucket Server version no longer supports the default branch endpoint or '${options.repo}' in '${options.projectKey}' does not exist.`,\n );\n }\n throw await ResponseError.fromResponse(response);\n }\n\n resolvePath(options: { projectKey: string; repo: string; path: string }): {\n path: string;\n } {\n const base = new URL(this.config.apiBaseUrl || '');\n\n return {\n path: `${base.protocol}//${base.host}/projects/${options.projectKey}/repos/${options.repo}${options.path}`,\n };\n }\n\n private async pagedRequest(\n endpoint: string,\n options?: BitbucketServerListOptions,\n ): Promise<BitbucketServerPagedResponse<any>> {\n const request = new URL(endpoint);\n for (const key in options) {\n if (options[key]) {\n request.searchParams.append(key, options[key]!.toString());\n }\n }\n return this.getTypeMapped(request);\n }\n\n private async getTypeMapped<T = any>(url: URL): Promise<T> {\n return this.get(url).then((response: Response) => {\n return response.json() as Promise<T>;\n });\n }\n\n private async get(url: URL): Promise<Response> {\n return this.request(new Request(url.toString(), { method: 'GET' }));\n }\n\n private async request(req: Request): Promise<Response> {\n return fetch(req, getBitbucketServerRequestOptions(this.config)).then(\n (response: Response) => {\n if (!response.ok) {\n throw new Error(\n `Unexpected response for ${req.method} ${req.url}. Expected 200 but got ${response.status} - ${response.statusText}`,\n );\n }\n return response;\n },\n );\n }\n}\n\n/**\n * @public\n */\nexport type BitbucketServerListOptions = {\n [key: string]: number | undefined;\n limit?: number | undefined;\n start?: number | undefined;\n};\n\n/**\n * @public\n */\nexport type BitbucketServerPagedResponse<T> = {\n size: number;\n limit: number;\n start: number;\n isLastPage: boolean;\n values: T[];\n nextPageStart: number;\n};\n\nexport async function* paginated(\n request: (\n options: BitbucketServerListOptions,\n ) => Promise<BitbucketServerPagedResponse<any>>,\n options?: BitbucketServerListOptions,\n) {\n const opts = options || { start: 0 };\n let res;\n do {\n res = await request(opts);\n opts.start = res.nextPageStart;\n for (const item of res.values) {\n yield item;\n }\n } while (!res.isLastPage);\n}\n"],"names":["getBitbucketServerRequestOptions","NotFoundError","ResponseError"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage/plugin-catalog-backend-module-bitbucket-server",
3
- "version": "0.4.0-next.1",
3
+ "version": "0.4.1-next.0",
4
4
  "backstage": {
5
5
  "role": "backend-plugin-module",
6
6
  "pluginId": "catalog",
@@ -54,22 +54,21 @@
54
54
  "test": "backstage-cli package test"
55
55
  },
56
56
  "dependencies": {
57
- "@backstage/backend-plugin-api": "1.2.1",
58
- "@backstage/catalog-client": "1.9.1",
57
+ "@backstage/backend-plugin-api": "1.3.1-next.0",
58
+ "@backstage/catalog-client": "1.10.0-next.0",
59
59
  "@backstage/catalog-model": "1.7.3",
60
60
  "@backstage/config": "1.3.2",
61
61
  "@backstage/errors": "1.2.7",
62
- "@backstage/integration": "1.16.3-next.0",
62
+ "@backstage/integration": "1.16.4-next.0",
63
63
  "@backstage/plugin-catalog-common": "1.1.3",
64
- "@backstage/plugin-catalog-node": "1.16.3-next.0",
65
- "@backstage/plugin-events-node": "0.4.9",
66
- "p-throttle": "^4.1.1",
64
+ "@backstage/plugin-catalog-node": "1.17.0-next.0",
65
+ "@backstage/plugin-events-node": "0.4.11-next.0",
67
66
  "uuid": "^11.0.0"
68
67
  },
69
68
  "devDependencies": {
70
- "@backstage/backend-test-utils": "1.3.2-next.2",
71
- "@backstage/cli": "0.32.0-next.2",
72
- "@backstage/plugin-events-backend-test-utils": "0.1.42",
69
+ "@backstage/backend-test-utils": "1.5.0-next.0",
70
+ "@backstage/cli": "0.32.1-next.0",
71
+ "@backstage/plugin-events-backend-test-utils": "0.1.44-next.0",
73
72
  "luxon": "^3.0.0",
74
73
  "msw": "^1.0.0"
75
74
  },