@solo.io/platform-portal-backstage-plugin-backend 0.0.50 → 0.0.53

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/dist/index.cjs.js CHANGED
@@ -6,17 +6,11 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
6
6
 
7
7
  var fetch__default = /*#__PURE__*/_interopDefaultCompat(fetch);
8
8
 
9
- var __defProp$2 = Object.defineProperty;
10
- var __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
11
- var __publicField$2 = (obj, key, value) => {
12
- __defNormalProp$2(obj, typeof key !== "symbol" ? key + "" : key, value);
13
- return value;
14
- };
15
9
  class ConfigUtil {
10
+ logErr;
11
+ logWarning;
12
+ config;
16
13
  constructor(logErr, logWarning, config) {
17
- __publicField$2(this, "logErr");
18
- __publicField$2(this, "logWarning");
19
- __publicField$2(this, "config");
20
14
  this.logErr = logErr;
21
15
  this.logWarning = logWarning;
22
16
  this.config = config;
@@ -31,7 +25,7 @@ class ConfigUtil {
31
25
  );
32
26
  if (!!value && value.at(-1) === "/")
33
27
  value = value.substring(0, value.length - 1);
34
- return value != null ? value : "http://localhost:31080/v1";
28
+ return value ?? "http://localhost:31080/v1";
35
29
  }
36
30
  getClientSecret() {
37
31
  if (!this.config) {
@@ -46,7 +40,7 @@ class ConfigUtil {
46
40
  "No glooPlatformPortal.backend.clientSecret found in app-config.local.yaml"
47
41
  );
48
42
  }
49
- return value != null ? value : "";
43
+ return value ?? "";
50
44
  }
51
45
  getClientId() {
52
46
  if (!this.config) {
@@ -61,7 +55,7 @@ class ConfigUtil {
61
55
  "No glooPlatformPortal.backend.clientId found in app-config.local.yaml"
62
56
  );
63
57
  }
64
- return value != null ? value : "";
58
+ return value ?? "";
65
59
  }
66
60
  getTokenEndpoint() {
67
61
  if (!this.config) {
@@ -76,7 +70,7 @@ class ConfigUtil {
76
70
  "No glooPlatformPortal.backend.tokenEndpoint found in app-config.local.yaml"
77
71
  );
78
72
  }
79
- return value != null ? value : "";
73
+ return value ?? "";
80
74
  }
81
75
  }
82
76
 
@@ -91,8 +85,7 @@ function parseJwt(token) {
91
85
  function objectToUrlFormEncodedPayload(requestJSON) {
92
86
  const formBodyPieces = [];
93
87
  for (const property in requestJSON) {
94
- if (!requestJSON.hasOwnProperty(property))
95
- continue;
88
+ if (!requestJSON.hasOwnProperty(property)) continue;
96
89
  const encodedKey = encodeURIComponent(property);
97
90
  const encodedValue = encodeURIComponent(
98
91
  requestJSON[property]
@@ -155,23 +148,15 @@ const sanitizeStringForEntity = (propertyType, propertyValue) => {
155
148
  );
156
149
  };
157
150
 
158
- var __defProp$1 = Object.defineProperty;
159
- var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
160
- var __publicField$1 = (obj, key, value) => {
161
- __defNormalProp$1(obj, typeof key !== "symbol" ? key + "" : key, value);
162
- return value;
163
- };
164
151
  class EntityBuilder {
165
- constructor() {
166
- // Backstage catalog metadata.
167
- __publicField$1(this, "bsGroupName", "solo-io-service-accounts");
168
- __publicField$1(this, "bsServiceAccountName", "gloo-platform-portal-service-account");
169
- __publicField$1(this, "bsSystemName", "gloo-platform-portal-apis");
170
- __publicField$1(this, "apisEndpoint", "");
171
- __publicField$1(this, "portalServerUrl", "");
172
- __publicField$1(this, "onApisEndpointChange", (apisEndpoint) => this.apisEndpoint = apisEndpoint);
173
- __publicField$1(this, "onPortalServerUrlChange", (portalServerUrl) => this.portalServerUrl = portalServerUrl);
174
- }
152
+ // Backstage catalog metadata.
153
+ bsGroupName = "solo-io-service-accounts";
154
+ bsServiceAccountName = "gloo-platform-portal-service-account";
155
+ bsSystemName = "gloo-platform-portal-apis";
156
+ apisEndpoint = "";
157
+ portalServerUrl = "";
158
+ onApisEndpointChange = (apisEndpoint) => this.apisEndpoint = apisEndpoint;
159
+ onPortalServerUrlChange = (portalServerUrl) => this.portalServerUrl = portalServerUrl;
175
160
  /**
176
161
  * A helper function to return a Backstage catalog entity for an API.
177
162
  */
@@ -297,64 +282,29 @@ class EntityBuilder {
297
282
  }
298
283
  }
299
284
 
300
- var __defProp = Object.defineProperty;
301
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
302
- var __publicField = (obj, key, value) => {
303
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
304
- return value;
305
- };
306
285
  class GlooPlatformPortalProvider {
307
- //
308
- // 1. Init class
309
- //
310
- constructor(logger, config, scheduler, entityTransformation) {
311
- __publicField(this, "connection");
312
- __publicField(this, "logger");
313
- __publicField(this, "config");
314
- __publicField(this, "latestTokensResponse");
315
- __publicField(this, "debugLogging", false);
316
- __publicField(this, "entityTransformation");
317
- // Helper classes
318
- __publicField(this, "configUtil");
319
- __publicField(this, "entityBuilder");
320
- /**
321
- * Defaults to 'unknown'.
322
- * This is updated to 'gloo-gateway' or 'gloo-mesh-gateway' depending on the api response.
323
- */
324
- __publicField(this, "_portalServerType", "unknown");
325
- __publicField(this, "_portalServerUrl", "");
326
- __publicField(this, "_apisEndpoint", "");
327
- __publicField(this, "log", (s) => {
328
- var _a;
329
- return (_a = this.logger) == null ? void 0 : _a.info(`gloo-platform-portal: ${s}`);
330
- });
331
- __publicField(this, "warn", (s) => {
332
- var _a;
333
- return (_a = this.logger) == null ? void 0 : _a.warn(`gloo-platform-portal: ${s}`);
334
- });
335
- __publicField(this, "error", (s) => {
336
- var _a;
337
- return (_a = this.logger) == null ? void 0 : _a.error(`gloo-platform-portal: ${s}`);
338
- });
339
- __publicField(this, "getProviderName", () => `gloo-platform-portal-backend-provider`);
340
- var _a;
341
- this.logger = logger;
342
- this.config = config;
343
- this.entityTransformation = entityTransformation;
344
- this.configUtil = new ConfigUtil(this.error, this.warn, this.config);
345
- this.entityBuilder = new EntityBuilder();
346
- this.debugLogging = !!((_a = this.config) == null ? void 0 : _a.getOptionalBoolean(
347
- "glooPlatformPortal.backend.debugLogging"
348
- ));
349
- this.log("Initializing GlooPlatformPortalProvider.");
350
- this.startTokensRequests().then(() => this.startScheduler(scheduler));
351
- }
286
+ connection;
287
+ logger;
288
+ config;
289
+ latestTokensResponse;
290
+ debugLogging = false;
291
+ entityTransformation;
292
+ // Helper classes
293
+ configUtil;
294
+ entityBuilder;
295
+ /**
296
+ * Defaults to 'unknown'.
297
+ * This is updated to 'gloo-gateway' or 'gloo-mesh-gateway' depending on the api response.
298
+ */
299
+ _portalServerType = "unknown";
352
300
  get portalServerType() {
353
301
  return this._portalServerType;
354
302
  }
303
+ _portalServerUrl = "";
355
304
  get portalServerUrl() {
356
305
  return this._portalServerUrl;
357
306
  }
307
+ _apisEndpoint = "";
358
308
  get apisEndpoint() {
359
309
  return this._apisEndpoint;
360
310
  }
@@ -364,6 +314,10 @@ class GlooPlatformPortalProvider {
364
314
  get gg_apisEndpoint() {
365
315
  return this.portalServerUrl + "/api-products";
366
316
  }
317
+ log = (s) => this.logger?.info(`gloo-platform-portal: ${s}`);
318
+ warn = (s) => this.logger?.warn(`gloo-platform-portal: ${s}`);
319
+ error = (s) => this.logger?.error(`gloo-platform-portal: ${s}`);
320
+ getProviderName = () => `gloo-platform-portal-backend-provider`;
367
321
  async connect(connection) {
368
322
  this.connection = connection;
369
323
  }
@@ -380,6 +334,21 @@ class GlooPlatformPortalProvider {
380
334
  this.updateApisEndpoint();
381
335
  }
382
336
  //
337
+ // 1. Init class
338
+ //
339
+ constructor(logger, config, scheduler, entityTransformation) {
340
+ this.logger = logger;
341
+ this.config = config;
342
+ this.entityTransformation = entityTransformation;
343
+ this.configUtil = new ConfigUtil(this.error, this.warn, this.config);
344
+ this.entityBuilder = new EntityBuilder();
345
+ this.debugLogging = !!this.config?.getOptionalBoolean(
346
+ "glooPlatformPortal.backend.debugLogging"
347
+ );
348
+ this.log("Initializing GlooPlatformPortalProvider.");
349
+ this.startTokensRequests().then(() => this.startScheduler(scheduler));
350
+ }
351
+ //
383
352
  // 2. Get access_token
384
353
  //
385
354
  async startTokensRequests() {
@@ -437,18 +406,17 @@ class GlooPlatformPortalProvider {
437
406
  * Backstage plugin task scheduler.
438
407
  * */
439
408
  async startScheduler(scheduler) {
440
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
441
409
  if (this.debugLogging) {
442
410
  this.log("Scheduling backstage catalog sync.");
443
411
  }
444
- const frequencyConfig = (_a = this.config) == null ? void 0 : _a.getOptionalConfig(
412
+ const frequencyConfig = this.config?.getOptionalConfig(
445
413
  "glooPlatformPortal.backend.syncFrequency"
446
414
  );
447
415
  const frequency = {
448
- hours: (_b = frequencyConfig == null ? void 0 : frequencyConfig.getOptionalNumber("hours")) != null ? _b : 0,
449
- minutes: (_c = frequencyConfig == null ? void 0 : frequencyConfig.getOptionalNumber("minutes")) != null ? _c : 0,
450
- seconds: (_d = frequencyConfig == null ? void 0 : frequencyConfig.getOptionalNumber("seconds")) != null ? _d : 0,
451
- milliseconds: (_e = frequencyConfig == null ? void 0 : frequencyConfig.getOptionalNumber("milliseconds")) != null ? _e : 0
416
+ hours: frequencyConfig?.getOptionalNumber("hours") ?? 0,
417
+ minutes: frequencyConfig?.getOptionalNumber("minutes") ?? 0,
418
+ seconds: frequencyConfig?.getOptionalNumber("seconds") ?? 0,
419
+ milliseconds: frequencyConfig?.getOptionalNumber("milliseconds") ?? 0
452
420
  };
453
421
  if (Object.values(frequency).every((v) => v === 0)) {
454
422
  frequency.minutes = 5;
@@ -461,14 +429,14 @@ class GlooPlatformPortalProvider {
461
429
  if (this.debugLogging) {
462
430
  this.log(`Frequency set to ${JSON.stringify(frequency)}.`);
463
431
  }
464
- const timeoutConfig = (_f = this.config) == null ? void 0 : _f.getOptionalConfig(
432
+ const timeoutConfig = this.config?.getOptionalConfig(
465
433
  "glooPlatformPortal.backend.syncTimeout"
466
434
  );
467
435
  const timeout = {
468
- hours: (_g = timeoutConfig == null ? void 0 : timeoutConfig.getOptionalNumber("hours")) != null ? _g : 0,
469
- minutes: (_h = timeoutConfig == null ? void 0 : timeoutConfig.getOptionalNumber("minutes")) != null ? _h : 0,
470
- seconds: (_i = timeoutConfig == null ? void 0 : timeoutConfig.getOptionalNumber("seconds")) != null ? _i : 0,
471
- milliseconds: (_j = timeoutConfig == null ? void 0 : timeoutConfig.getOptionalNumber("milliseconds")) != null ? _j : 0
436
+ hours: timeoutConfig?.getOptionalNumber("hours") ?? 0,
437
+ minutes: timeoutConfig?.getOptionalNumber("minutes") ?? 0,
438
+ seconds: timeoutConfig?.getOptionalNumber("seconds") ?? 0,
439
+ milliseconds: timeoutConfig?.getOptionalNumber("milliseconds") ?? 0
472
440
  };
473
441
  if (Object.values(timeout).every((v) => v === 0)) {
474
442
  timeout.seconds = 30;
@@ -506,7 +474,7 @@ class GlooPlatformPortalProvider {
506
474
  this.updateApisEndpoint();
507
475
  try {
508
476
  let processedAPIs = await this.fetchAPIs();
509
- if (this.portalServerType === "gloo-mesh-gateway" && !!(processedAPIs == null ? void 0 : processedAPIs.length) && "apiVersions" in processedAPIs[0]) {
477
+ if (this.portalServerType === "gloo-mesh-gateway" && !!processedAPIs?.length && "apiVersions" in processedAPIs[0]) {
510
478
  const apiProducts = processedAPIs;
511
479
  processedAPIs = apiProducts.reduce((accum, curProd) => {
512
480
  accum.push(
@@ -648,7 +616,7 @@ class GlooPlatformPortalProvider {
648
616
  );
649
617
  }
650
618
  let processedAPIs = [];
651
- if (!!(res == null ? void 0 : res.length)) {
619
+ if (!!res?.length) {
652
620
  var identifiedPortalServerType = "unknown";
653
621
  if ("id" in res[0]) {
654
622
  identifiedPortalServerType = "gloo-gateway";
@@ -709,7 +677,7 @@ class GlooPlatformPortalProvider {
709
677
  `Fetched ${getVersionsUrl} (identified as ${this.portalServerType}) and recieved the response: ${JSON.stringify(versions)}`
710
678
  );
711
679
  }
712
- if (!!(versions == null ? void 0 : versions.length)) {
680
+ if (!!versions?.length) {
713
681
  processedAPIs.push(
714
682
  ...versions.map((v) => ({
715
683
  ...v,
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/provider/ConfigUtil.ts","../src/provider/utility.ts","../src/provider/EntityBuilder.ts","../src/provider/GlooPlatformPortalProvider.ts"],"sourcesContent":["import { Config } from '@backstage/config';\n\ntype logFn = (s: string) => any;\n\nexport class ConfigUtil {\n logErr: logFn;\n logWarning: logFn;\n config: Config;\n\n constructor(logErr: logFn, logWarning: logFn, config: Config) {\n this.logErr = logErr;\n this.logWarning = logWarning;\n this.config = config;\n }\n\n getPortalServerUrl() {\n if (!this.config) {\n this.logErr('No backstage config found when getting portal server url.');\n return '';\n }\n let value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.portalServerUrl',\n );\n // Remove trailing slash if supplied.\n if (!!value && value.at(-1) === '/')\n value = value.substring(0, value.length - 1);\n return value ?? 'http://localhost:31080/v1';\n }\n\n getClientSecret() {\n if (!this.config) {\n this.logErr('No backstage config found when getting client secret.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.clientSecret',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.clientSecret found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n\n getClientId() {\n if (!this.config) {\n this.logErr('No backstage config found when getting client id.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.clientId',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.clientId found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n\n getTokenEndpoint() {\n if (!this.config) {\n this.logErr('No backstage config found when getting token endpoint.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.tokenEndpoint',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.tokenEndpoint found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n}\n","import fetch from 'node-fetch';\nimport { AccessTokensResponse } from './api-types';\n\nexport function parseJwt(token: string) {\n const base64Url = token.split('.')[1];\n const base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');\n const jsonPayload = decodeURIComponent(\n atob(base64)\n .split('')\n .map(c => `%${`00${c.charCodeAt(0).toString(16)}`.slice(-2)}`)\n .join(''),\n );\n return JSON.parse(jsonPayload);\n}\n\nexport function objectToUrlFormEncodedPayload(\n requestJSON: Record<string, string>,\n) {\n const formBodyPieces = [] as string[];\n for (const property in requestJSON) {\n if (!requestJSON.hasOwnProperty(property)) continue;\n const encodedKey = encodeURIComponent(property);\n const encodedValue = encodeURIComponent(\n requestJSON[property as keyof typeof requestJSON],\n );\n formBodyPieces.push(`${encodedKey}=${encodedValue}`);\n }\n const formBodyString = formBodyPieces.join('&');\n return formBodyString;\n}\n\nexport async function doAccessTokenRequest(\n grantType: 'refresh_token' | 'client_credentials',\n tokenEndpoint: string,\n clientId: string,\n clientSecret: string,\n refreshToken?: string,\n) {\n const formData = {} as Record<string, string>;\n //\n // Build the request payload for a new oauth access token.\n //\n formData.grant_type = grantType;\n formData.client_id = clientId;\n formData.client_secret = clientSecret;\n if (grantType === 'refresh_token') {\n if (!refreshToken) {\n return undefined;\n }\n formData.refresh_token = refreshToken;\n }\n //\n // Make the request\n //\n const rawRes = await fetch(tokenEndpoint, {\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',\n },\n method: 'POST',\n body: objectToUrlFormEncodedPayload(formData),\n });\n let resJSON: any;\n try {\n resJSON = await rawRes.json();\n } catch {\n throw new Error('Error parsing oauth response.');\n }\n if (!!resJSON.error_description) {\n throw new Error(resJSON.error_description);\n }\n if (!!resJSON.error) {\n throw new Error(resJSON.error);\n }\n //\n // Check for the access token in the response.\n //\n if (!resJSON.access_token) {\n throw new Error(\n \"No 'access_token' property was found in the oauth response body.\",\n );\n }\n return resJSON as AccessTokensResponse;\n}\n\n//\n// From: https://backstage.io/docs/features/software-catalog/descriptor-format\n//\nconst sanitizeRegex = {\n // Each tag must be sequences of [a-z0-9:+#] separated by -, at most 63 characters in total\n tag: /[a-z]|[0-9]|\\:|\\+|\\#|\\-/,\n // Strings of length at least 1, and at most 63\n // Must consist of sequences of [a-z0-9A-Z] possibly separated by one of [-_.].\n name: /[a-z]|[0-9]|[A-Z]|\\-|\\_|\\./,\n // Namespaces must be sequences of [a-zA-Z0-9], possibly separated by -, at most 63 characters in total.\n namespace: /[a-z]|[0-9]|[A-Z]|\\-/,\n};\n\n/**\n * Sanitizes a string before adding it to a backstage entity.\n */\nexport const sanitizeStringForEntity = (\n propertyType: keyof typeof sanitizeRegex,\n propertyValue: string,\n) => {\n return propertyValue\n .toLowerCase()\n .split('')\n .map(ch => (!sanitizeRegex[propertyType].test(ch) ? '-' : ch))\n .reduce(\n (prev, cur) =>\n // Don't go over 63 characters.\n prev.length >= 62\n ? prev\n : // Don't repeat \"-\"\n prev.at(-1) === '-' && cur === '-'\n ? prev\n : prev + cur,\n '',\n );\n};\n","import { Entity, EntityMeta } from '@backstage/catalog-model';\nimport { EntityProviderMutation } from '@backstage/plugin-catalog-node';\nimport { APISchema } from './api-types';\nimport { sanitizeStringForEntity } from './utility';\n\nexport class EntityBuilder {\n // Backstage catalog metadata.\n private bsGroupName = 'solo-io-service-accounts';\n private bsServiceAccountName = 'gloo-platform-portal-service-account';\n private bsSystemName = 'gloo-platform-portal-apis';\n\n private apisEndpoint = '';\n private portalServerUrl = '';\n\n onApisEndpointChange = (apisEndpoint: string) =>\n (this.apisEndpoint = apisEndpoint);\n onPortalServerUrlChange = (portalServerUrl: string) =>\n (this.portalServerUrl = portalServerUrl);\n\n /**\n * A helper function to return a Backstage catalog entity for an API.\n */\n buildApiVersionEntity(\n apiId: string,\n apiVersion: string | undefined,\n apiDescription: string,\n schema: APISchema | string | undefined,\n ): Entity {\n const newEntity: Entity = {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'API',\n metadata: {\n tags: [\n 'gloo-platform',\n ...(!!apiVersion\n ? ['api-version:' + sanitizeStringForEntity('tag', apiVersion)]\n : []),\n ],\n name: sanitizeStringForEntity('name', apiId),\n title: apiId,\n description: apiDescription,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.apisEndpoint}`,\n 'backstage.io/managed-by-origin-location': `url:${this.apisEndpoint}`,\n },\n } as EntityMeta,\n spec: {\n type: 'openapi',\n lifecycle: 'production',\n system: this.bsSystemName,\n owner: `user:${this.bsServiceAccountName}`,\n definition: JSON.stringify(schema),\n },\n };\n return newEntity;\n }\n\n /**\n * A helper function to return a Backstage catalog EntityProviderMutation object for the GlooPlatformPortalProvider plugin.\n * The returned object includes entities that will be added to the catalog.\n */\n buildEntityProviderMutation(entities: Entity[]) {\n const locationKey = `gloo-platform-portal-provider`;\n const mutationObj: EntityProviderMutation = {\n type: 'full',\n entities: [\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'Group',\n metadata: {\n name: this.bsGroupName,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n },\n spec: {\n type: 'service-account-group',\n children: [],\n members: [this.bsServiceAccountName],\n },\n },\n },\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'User',\n metadata: {\n name: this.bsServiceAccountName,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n },\n spec: {\n displayName: 'Solo.io Service Account',\n email: '',\n picture: '',\n memberOf: [this.bsGroupName],\n },\n },\n },\n // {\n // locationKey,\n // entity: {\n // apiVersion: 'backstage.io/v1alpha1',\n // kind: 'Domain',\n // metadata: {\n // tags: ['gloo-platform'],\n // name: 'api-product',\n // description: 'Gloo Platform Portal ApiProduct resources.',\n // annotations: {\n // 'backstage.io/managed-by-location': 'url:' + this.apisEndpoint,\n // 'backstage.io/managed-by-origin-location':\n // 'url:' + this.apisEndpoint,\n // },\n // } as EntityMeta,\n // spec: {\n // owner: 'user:' + bsServiceAccountName,\n // },\n // },\n // },\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'System',\n metadata: {\n tags: ['gloo-platform'],\n name: this.bsSystemName,\n title: 'Gloo Platform Portal APIs',\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n } as EntityMeta,\n spec: {\n owner: `user:${this.bsServiceAccountName}`,\n // domain: 'api-product',\n },\n },\n },\n ...entities.map(entity => ({ locationKey, entity })),\n ],\n };\n return mutationObj;\n }\n}\n","import { LoggerService, SchedulerService } from '@backstage/backend-plugin-api';\nimport { Entity } from '@backstage/catalog-model';\nimport { Config } from '@backstage/config';\nimport {\n EntityProvider,\n EntityProviderConnection,\n} from '@backstage/plugin-catalog-node';\nimport fetch from 'node-fetch';\nimport { ConfigUtil } from './ConfigUtil';\nimport { EntityBuilder } from './EntityBuilder';\nimport {\n API,\n APIProduct,\n APISchema,\n AccessTokensResponse,\n ApiProductSummary,\n ApiVersion,\n ApiVersionExtended,\n} from './api-types';\nimport { doAccessTokenRequest, parseJwt } from './utility';\n\ntype PortalServerType = 'gloo-mesh-gateway' | 'gloo-gateway' | 'unknown';\n\ntype ApisEndpointResponseType =\n | API[]\n | APIProduct[]\n | ApiProductSummary[]\n | null;\n\n\ntype EntityTransformation = (entity: Entity, api: ApiVersionExtended | API) => Promise<Entity>\n\n/**\n * Provides API entities from the Gloo Platform Portal REST server.\n */\nexport class GlooPlatformPortalProvider implements EntityProvider {\n private connection?: EntityProviderConnection;\n private logger: LoggerService;\n private config: Config;\n private latestTokensResponse?: AccessTokensResponse;\n private debugLogging = false;\n private entityTransformation?: EntityTransformation;\n\n // Helper classes\n private configUtil: ConfigUtil;\n private entityBuilder: EntityBuilder;\n\n /**\n * Defaults to 'unknown'.\n * This is updated to 'gloo-gateway' or 'gloo-mesh-gateway' depending on the api response.\n */\n private _portalServerType: PortalServerType = 'unknown';\n private get portalServerType() {\n return this._portalServerType;\n }\n private _portalServerUrl = '';\n private get portalServerUrl() {\n return this._portalServerUrl;\n }\n private _apisEndpoint = '';\n private get apisEndpoint() {\n return this._apisEndpoint;\n }\n private get gmg_apisEndpoint() {\n return this.portalServerUrl + '/apis';\n }\n private get gg_apisEndpoint() {\n return this.portalServerUrl + '/api-products';\n }\n\n log = (s: string) => this.logger?.info(`gloo-platform-portal: ${s}`);\n warn = (s: string) => this.logger?.warn(`gloo-platform-portal: ${s}`);\n error = (s: string) => this.logger?.error(`gloo-platform-portal: ${s}`);\n getProviderName = () => `gloo-platform-portal-backend-provider`;\n async connect(connection: EntityProviderConnection): Promise<void> {\n this.connection = connection;\n }\n\n updatePortalServerUrl() {\n this._portalServerUrl = this.configUtil.getPortalServerUrl();\n this.entityBuilder.onPortalServerUrlChange(this.portalServerUrl);\n }\n\n updateApisEndpoint() {\n // For portalServerType:\n // - \"unknown, and \"gloo-mesh-gateway\": use GMG endpoint\n // - \"gloo-gateway\": use GG endpoint\n this._apisEndpoint =\n this.portalServerType === 'gloo-gateway'\n ? this.gg_apisEndpoint\n : this.gmg_apisEndpoint;\n this.entityBuilder.onApisEndpointChange(this.apisEndpoint);\n }\n\n updatePortalServerType(newType: typeof this.portalServerType) {\n this._portalServerType = newType;\n // When the portal server type changes, the apis endpoint may be updated.\n this.updateApisEndpoint();\n }\n\n\n //\n // 1. Init class\n //\n constructor(\n logger: LoggerService,\n config: Config,\n scheduler: SchedulerService,\n entityTransformation?: EntityTransformation\n ) {\n this.logger = logger;\n this.config = config;\n this.entityTransformation = entityTransformation;\n this.configUtil = new ConfigUtil(this.error, this.warn, this.config);\n this.entityBuilder = new EntityBuilder();\n // Default extra debug-logging to false\n this.debugLogging = !!this.config?.getOptionalBoolean(\n 'glooPlatformPortal.backend.debugLogging',\n );\n this.log('Initializing GlooPlatformPortalProvider.');\n // Get the tokens, then schedule the task to update the catalog.\n this.startTokensRequests().then(() => this.startScheduler(scheduler));\n }\n\n //\n // 2. Get access_token\n //\n async startTokensRequests() {\n //\n // Make the initial request for the access_token.\n if (this.debugLogging) {\n this.log('Making the initial access_token request.');\n }\n if (!this.config) {\n this.error(\n 'Backstage config object not found when doing access token request.',\n );\n return;\n }\n const res = await doAccessTokenRequest(\n 'client_credentials',\n this.configUtil.getTokenEndpoint(),\n this.configUtil.getClientId(),\n this.configUtil.getClientSecret(),\n );\n this.latestTokensResponse = res;\n if (!this.latestTokensResponse) {\n // If there's a problem, wait to restart the access token\n // requests so as to not overload the auth server.\n this.warn('No latest access token. Re-requesting the access_token.');\n setTimeout(this.startTokensRequests.bind(this), 5000);\n return;\n }\n if (this.debugLogging) {\n this.log('Got the access_token.');\n }\n //\n // Parse the access_token JWT to find when it expires.\n const parsedToken = parseJwt(this.latestTokensResponse.access_token);\n if (!parsedToken.exp) {\n this.warn('No `exp` property found in the access_token JWT.');\n }\n const nowDate = new Date();\n const expiresDate = new Date(parsedToken.exp * 1000);\n const millisUntilExpires = expiresDate.getTime() - nowDate.getTime();\n if (millisUntilExpires <= 0) {\n this.warn('access token is expired!');\n this.latestTokensResponse = undefined;\n return;\n }\n if (this.debugLogging) {\n this.log('Setting a timeout to get the next access token.');\n }\n // Set the timeout to request new tokens.\n setTimeout(\n this.startTokensRequests.bind(this),\n // Don't make this request more than once a second,\n // and do the refresh 5 seconds early.\n Math.max(1000, millisUntilExpires - 5000),\n );\n }\n\n /**\n *\n * 3. Schedule sync.\n *\n * This passes the user config into the\n * Backstage plugin task scheduler.\n * */\n async startScheduler(scheduler: SchedulerService) {\n if (this.debugLogging) {\n this.log('Scheduling backstage catalog sync.');\n }\n const frequencyConfig = this.config?.getOptionalConfig(\n 'glooPlatformPortal.backend.syncFrequency',\n );\n // Get frequency from the config.\n const frequency = {\n hours: frequencyConfig?.getOptionalNumber('hours') ?? 0,\n minutes: frequencyConfig?.getOptionalNumber('minutes') ?? 0,\n seconds: frequencyConfig?.getOptionalNumber('seconds') ?? 0,\n milliseconds: frequencyConfig?.getOptionalNumber('milliseconds') ?? 0,\n };\n if (Object.values(frequency).every(v => v === 0)) {\n // If there are no values for frequency, set a resonable default instead of 0.\n frequency.minutes = 5;\n if (this.debugLogging) {\n this.log(\n `No frequency value was set, so the default value of ${frequency.minutes} minutes will be used.`,\n );\n }\n }\n if (this.debugLogging) {\n this.log(`Frequency set to ${JSON.stringify(frequency)}.`);\n }\n // Get timeout from the config.\n const timeoutConfig = this.config?.getOptionalConfig(\n 'glooPlatformPortal.backend.syncTimeout',\n );\n const timeout = {\n hours: timeoutConfig?.getOptionalNumber('hours') ?? 0,\n minutes: timeoutConfig?.getOptionalNumber('minutes') ?? 0,\n seconds: timeoutConfig?.getOptionalNumber('seconds') ?? 0,\n milliseconds: timeoutConfig?.getOptionalNumber('milliseconds') ?? 0,\n };\n if (Object.values(timeout).every(v => v === 0)) {\n // If there are no values for timeout, set a resonable default instead of 0.\n timeout.seconds = 30;\n if (this.debugLogging) {\n this.log(\n `No timeout value was set. The default value of ${timeout.seconds} seconds will be used.`,\n );\n }\n }\n if (this.debugLogging) {\n this.log(`Timeout set to ${JSON.stringify(timeout)}.`);\n }\n // Start the sync task on the Backstage scheduler.\n await scheduler.scheduleTask({\n id: 'run_gloo_platform_portal_refresh',\n fn: async () => {\n await this.run();\n },\n frequency,\n timeout,\n });\n }\n\n /**\n *\n * 4. Return new Backstage entities.\n *\n * Requests API information from the Gloo Platform Portal REST server,\n * and transforms the response into Backstage API entities.\n */\n async run(): Promise<void> {\n if (!this.connection || !this.latestTokensResponse) {\n throw new Error('Not initialized');\n }\n const entities: Entity[] = [];\n this.updatePortalServerUrl();\n this.updateApisEndpoint();\n\n // Make API request\n try {\n let processedAPIs = await this.fetchAPIs();\n\n //\n // Some Gloo Mesh Gateway portal servers returned the APIs grouped by APIProduct,\n // so we can convert it back to a list here.\n //\n if (\n this.portalServerType === 'gloo-mesh-gateway' &&\n !!processedAPIs?.length &&\n 'apiVersions' in processedAPIs[0]\n ) {\n const apiProducts = processedAPIs as unknown as APIProduct[];\n processedAPIs = apiProducts.reduce((accum, curProd) => {\n accum.push(\n ...curProd.apiVersions.reduce((accumVer, api) => {\n if (!!api.openapiSpecFetchErr) {\n this.warn(\n `Schema fetch error for ${api.apiId} : ${JSON.stringify(\n api.openapiSpecFetchErr,\n )}`,\n );\n }\n accumVer.push({\n apiId: api.apiId,\n apiProductDisplayName: curProd.apiProductDisplayName,\n apiProductId: curProd.apiProductId,\n apiVersion: api.apiVersion,\n contact: api.contact,\n customMetadata: api.customMetadata,\n description: api.description,\n license: api.license,\n termsOfService: api.termsOfService,\n title: api.title,\n usagePlans: api.usagePlans,\n openapiSpec: api.openapiSpec,\n openapiSpecFetchErr: api.openapiSpecFetchErr,\n });\n return accumVer;\n }, [] as API[]),\n );\n return accum;\n }, [] as API[]);\n }\n\n // Convert the APIs to entities\n for (let i = 0; i < processedAPIs.length; i++) {\n const api = processedAPIs[i];\n if ('id' in api) {\n //\n // For \"gloo-gateway\"\n //\n this.updatePortalServerType('gloo-gateway');\n let entity = await this.getGlooGatewayApiEntity(api);\n entities.push(await this.applyEntityTransformation(entity, api));\n } else if ('apiProductId' in api) {\n //\n // For \"gloo-mesh-gateway\"\n //\n this.updatePortalServerType('gloo-mesh-gateway');\n let entity = await this.getGlooMeshGatewayApiEntity(api);\n entities.push(await this.applyEntityTransformation(entity, api));\n }\n }\n if (this.debugLogging) {\n this.log(\n 'Transformed APIs into new entities: ' + JSON.stringify(entities),\n );\n }\n } catch (e) {\n this.error(\n `Could not get APIs from the portal server endpoint or their schemas or transform them into entities (${\n this.apisEndpoint\n }). Error: ${JSON.stringify(e)}`,\n );\n }\n\n await this.connection.applyMutation(\n this.entityBuilder.buildEntityProviderMutation(entities),\n );\n }\n\n /**\n * Returns the Backstage catalog entity for the \"gloo-gateway\" Portal Server API response.\n */\n async getGlooGatewayApiEntity(api: ApiVersionExtended): Promise<Entity> {\n return this.entityBuilder.buildApiVersionEntity(\n api.id,\n api.name,\n api.apiProductDescription,\n api.apiSpec,\n );\n }\n\n /**\n * Returns the Backstage catalog entity for the \"gloo-mesh-gateway\" Portal Server API response.\n */\n async getGlooMeshGatewayApiEntity(api: API): Promise<Entity> {\n if (!this.connection || !this.latestTokensResponse || !this.apisEndpoint) {\n throw new Error('Unable to getGlooMeshGatewayApiEntity');\n }\n let schema = api.openapiSpec;\n if (!schema && !api.openapiSpecFetchErr) {\n // If the schema was not attempted to be fetched with\n // the /apis call, we individually fetch it here.\n // This is for backwards compatibility only, for\n // when the schema was not in the /apis response.\n const schemaRes = await fetch(\n `${this.apisEndpoint}/${api.apiId}/schema`,\n {\n headers: {\n Authorization: `Bearer ${this.latestTokensResponse.access_token}`,\n },\n },\n );\n schema = (await schemaRes.json()) as APISchema;\n }\n return this.entityBuilder.buildApiVersionEntity(\n api.apiId,\n api.apiVersion,\n api.description,\n schema,\n );\n }\n\n /**\n * A helper function for getting the API's from the Portal Server.\n * This abstracts away the \"gloo-gateway\"/\"gloo-mesh-gateway\" portal server details.\n */\n async fetchAPIs() {\n if (!this.connection || !this.latestTokensResponse || !this.apisEndpoint) {\n throw new Error('Unable to fetch APIs');\n }\n const fetchInit: fetch.RequestInit = {\n headers: {\n Authorization: `Bearer ${this.latestTokensResponse.access_token}`,\n },\n };\n\n //\n // Make the initial apis request.\n //\n if (this.debugLogging) {\n this.log(\n `Fetching APIs from ${this.apisEndpoint} (identified as ${this.portalServerType}) with header: \"Authorization: Bearer ${this.latestTokensResponse.access_token}\"`,\n );\n }\n let res: ApisEndpointResponseType = null;\n try {\n res = await (await fetch(this.apisEndpoint, fetchInit)).json();\n } catch {}\n if (\n // If we didn't just try the GG endpoint, and\n this.apisEndpoint !== this.gg_apisEndpoint &&\n // the GG+GMG endpoints aren't the same, and\n this.gg_apisEndpoint !== this.gmg_apisEndpoint &&\n // the GMG request failed, or\n (!res ||\n // the GMG request didn't fail, it returned data, but it's not an array, or\n !Array.isArray(res) ||\n // the GMG request didn't fail, it returned data, but\n (!!res.length &&\n // it didn't return either GG or GMG data,\n !('id' in res[0]) &&\n !('apiVersions' in res[0])))\n ) {\n // try with the GG endpoint.\n if (this.debugLogging) {\n this.log(`Retrying fetching APIs using ${this.gg_apisEndpoint}`);\n }\n try {\n res = await (await fetch(this.gg_apisEndpoint, fetchInit)).json();\n } catch {}\n }\n if (this.debugLogging) {\n this.log(\n 'Performed fetch and recieved the response: ' + JSON.stringify(res),\n );\n }\n\n let processedAPIs: (API | ApiVersionExtended)[] = [];\n if (!!res?.length) {\n //\n // Check the portal server API type\n //\n var identifiedPortalServerType: PortalServerType = 'unknown';\n if ('id' in res[0]) {\n identifiedPortalServerType = 'gloo-gateway';\n } else {\n identifiedPortalServerType = 'gloo-mesh-gateway';\n }\n if (\n this.debugLogging &&\n this.portalServerType !== identifiedPortalServerType\n ) {\n this.log(\n 'Portal server type identified as: ' + identifiedPortalServerType,\n );\n }\n this.updatePortalServerType(identifiedPortalServerType);\n\n //\n // Transform the data\n //\n // For \"gloo-mesh-gateway\"\n if (identifiedPortalServerType === 'gloo-mesh-gateway') {\n if ('apiVersions' in res[0]) {\n // Some versions return the data grouped by APIProduct,\n // so we convert it back to a list here.\n const apiProducts = res as APIProduct[];\n processedAPIs = apiProducts.reduce((accum, curProd) => {\n accum.push(\n ...curProd.apiVersions.reduce((accumVer, api) => {\n accumVer.push({\n apiId: api.apiId,\n apiProductDisplayName: curProd.apiProductDisplayName,\n apiProductId: curProd.apiProductId,\n apiVersion: api.apiVersion,\n contact: api.contact,\n customMetadata: api.customMetadata,\n description: api.description,\n license: api.license,\n termsOfService: api.termsOfService,\n title: api.title,\n usagePlans: api.usagePlans,\n });\n return accumVer;\n }, [] as API[]),\n );\n return accum;\n }, [] as API[]);\n } else {\n processedAPIs = res as API[];\n }\n }\n // For \"gloo-gateway\"\n else if (identifiedPortalServerType === 'gloo-gateway') {\n // Fetch the information for each version.\n const summaries = res as ApiProductSummary[];\n // Reset the processedAPIs so we can add each version to it.\n processedAPIs = [];\n // We have to do a separate request for each ApiProduct in order to get their versions.\n for (let i = 0; i < summaries.length; i++) {\n const apiProductSummary = summaries[i];\n const getVersionsUrl = `${this.apisEndpoint}/${apiProductSummary.id}/versions`;\n if (this.debugLogging) {\n this.log(\n `Fetching API versions from ${getVersionsUrl} (identified as ${this.portalServerType}).`,\n );\n }\n let versions: ApiVersion[] = [];\n try {\n versions = await (await fetch(getVersionsUrl, fetchInit)).json();\n } catch {}\n if (this.debugLogging) {\n this.log(\n `Fetched ${getVersionsUrl} (identified as ${\n this.portalServerType\n }) and recieved the response: ${JSON.stringify(versions)}`,\n );\n }\n if (!!versions?.length) {\n // Add each API product's version to the processedAPIs.\n processedAPIs.push(\n ...versions.map(v => ({\n ...v,\n apiProductDescription: apiProductSummary.description,\n })),\n );\n }\n }\n }\n }\n\n return processedAPIs;\n }\n\n private async applyEntityTransformation(entity: Entity, api: ApiVersionExtended | API) {\n if (!!this.entityTransformation) {\n return await this.entityTransformation(entity, api);\n }\n\n return entity;\n }\n}\n"],"names":["__publicField","fetch"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/provider/ConfigUtil.ts","../src/provider/utility.ts","../src/provider/EntityBuilder.ts","../src/provider/GlooPlatformPortalProvider.ts"],"sourcesContent":["import { Config } from '@backstage/config';\n\ntype logFn = (s: string) => any;\n\nexport class ConfigUtil {\n logErr: logFn;\n logWarning: logFn;\n config: Config;\n\n constructor(logErr: logFn, logWarning: logFn, config: Config) {\n this.logErr = logErr;\n this.logWarning = logWarning;\n this.config = config;\n }\n\n getPortalServerUrl() {\n if (!this.config) {\n this.logErr('No backstage config found when getting portal server url.');\n return '';\n }\n let value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.portalServerUrl',\n );\n // Remove trailing slash if supplied.\n if (!!value && value.at(-1) === '/')\n value = value.substring(0, value.length - 1);\n return value ?? 'http://localhost:31080/v1';\n }\n\n getClientSecret() {\n if (!this.config) {\n this.logErr('No backstage config found when getting client secret.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.clientSecret',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.clientSecret found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n\n getClientId() {\n if (!this.config) {\n this.logErr('No backstage config found when getting client id.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.clientId',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.clientId found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n\n getTokenEndpoint() {\n if (!this.config) {\n this.logErr('No backstage config found when getting token endpoint.');\n return '';\n }\n const value = this.config.getOptionalString(\n 'glooPlatformPortal.backend.tokenEndpoint',\n );\n if (!value) {\n this.logWarning(\n 'No glooPlatformPortal.backend.tokenEndpoint found in app-config.local.yaml',\n );\n }\n return value ?? '';\n }\n}\n","import fetch from 'node-fetch';\nimport { AccessTokensResponse } from './api-types';\n\nexport function parseJwt(token: string) {\n const base64Url = token.split('.')[1];\n const base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');\n const jsonPayload = decodeURIComponent(\n atob(base64)\n .split('')\n .map(c => `%${`00${c.charCodeAt(0).toString(16)}`.slice(-2)}`)\n .join(''),\n );\n return JSON.parse(jsonPayload);\n}\n\nexport function objectToUrlFormEncodedPayload(\n requestJSON: Record<string, string>,\n) {\n const formBodyPieces = [] as string[];\n for (const property in requestJSON) {\n if (!requestJSON.hasOwnProperty(property)) continue;\n const encodedKey = encodeURIComponent(property);\n const encodedValue = encodeURIComponent(\n requestJSON[property as keyof typeof requestJSON],\n );\n formBodyPieces.push(`${encodedKey}=${encodedValue}`);\n }\n const formBodyString = formBodyPieces.join('&');\n return formBodyString;\n}\n\nexport async function doAccessTokenRequest(\n grantType: 'refresh_token' | 'client_credentials',\n tokenEndpoint: string,\n clientId: string,\n clientSecret: string,\n refreshToken?: string,\n) {\n const formData = {} as Record<string, string>;\n //\n // Build the request payload for a new oauth access token.\n //\n formData.grant_type = grantType;\n formData.client_id = clientId;\n formData.client_secret = clientSecret;\n if (grantType === 'refresh_token') {\n if (!refreshToken) {\n return undefined;\n }\n formData.refresh_token = refreshToken;\n }\n //\n // Make the request\n //\n const rawRes = await fetch(tokenEndpoint, {\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',\n },\n method: 'POST',\n body: objectToUrlFormEncodedPayload(formData),\n });\n let resJSON: any;\n try {\n resJSON = await rawRes.json();\n } catch {\n throw new Error('Error parsing oauth response.');\n }\n if (!!resJSON.error_description) {\n throw new Error(resJSON.error_description);\n }\n if (!!resJSON.error) {\n throw new Error(resJSON.error);\n }\n //\n // Check for the access token in the response.\n //\n if (!resJSON.access_token) {\n throw new Error(\n \"No 'access_token' property was found in the oauth response body.\",\n );\n }\n return resJSON as AccessTokensResponse;\n}\n\n//\n// From: https://backstage.io/docs/features/software-catalog/descriptor-format\n//\nconst sanitizeRegex = {\n // Each tag must be sequences of [a-z0-9:+#] separated by -, at most 63 characters in total\n tag: /[a-z]|[0-9]|\\:|\\+|\\#|\\-/,\n // Strings of length at least 1, and at most 63\n // Must consist of sequences of [a-z0-9A-Z] possibly separated by one of [-_.].\n name: /[a-z]|[0-9]|[A-Z]|\\-|\\_|\\./,\n // Namespaces must be sequences of [a-zA-Z0-9], possibly separated by -, at most 63 characters in total.\n namespace: /[a-z]|[0-9]|[A-Z]|\\-/,\n};\n\n/**\n * Sanitizes a string before adding it to a backstage entity.\n */\nexport const sanitizeStringForEntity = (\n propertyType: keyof typeof sanitizeRegex,\n propertyValue: string,\n) => {\n return propertyValue\n .toLowerCase()\n .split('')\n .map(ch => (!sanitizeRegex[propertyType].test(ch) ? '-' : ch))\n .reduce(\n (prev, cur) =>\n // Don't go over 63 characters.\n prev.length >= 62\n ? prev\n : // Don't repeat \"-\"\n prev.at(-1) === '-' && cur === '-'\n ? prev\n : prev + cur,\n '',\n );\n};\n","import { Entity, EntityMeta } from '@backstage/catalog-model';\nimport { EntityProviderMutation } from '@backstage/plugin-catalog-node';\nimport { APISchema } from './api-types';\nimport { sanitizeStringForEntity } from './utility';\n\nexport class EntityBuilder {\n // Backstage catalog metadata.\n private bsGroupName = 'solo-io-service-accounts';\n private bsServiceAccountName = 'gloo-platform-portal-service-account';\n private bsSystemName = 'gloo-platform-portal-apis';\n\n private apisEndpoint = '';\n private portalServerUrl = '';\n\n onApisEndpointChange = (apisEndpoint: string) =>\n (this.apisEndpoint = apisEndpoint);\n onPortalServerUrlChange = (portalServerUrl: string) =>\n (this.portalServerUrl = portalServerUrl);\n\n /**\n * A helper function to return a Backstage catalog entity for an API.\n */\n buildApiVersionEntity(\n apiId: string,\n apiVersion: string | undefined,\n apiDescription: string,\n schema: APISchema | string | undefined,\n ): Entity {\n const newEntity: Entity = {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'API',\n metadata: {\n tags: [\n 'gloo-platform',\n ...(!!apiVersion\n ? ['api-version:' + sanitizeStringForEntity('tag', apiVersion)]\n : []),\n ],\n name: sanitizeStringForEntity('name', apiId),\n title: apiId,\n description: apiDescription,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.apisEndpoint}`,\n 'backstage.io/managed-by-origin-location': `url:${this.apisEndpoint}`,\n },\n } as EntityMeta,\n spec: {\n type: 'openapi',\n lifecycle: 'production',\n system: this.bsSystemName,\n owner: `user:${this.bsServiceAccountName}`,\n definition: JSON.stringify(schema),\n },\n };\n return newEntity;\n }\n\n /**\n * A helper function to return a Backstage catalog EntityProviderMutation object for the GlooPlatformPortalProvider plugin.\n * The returned object includes entities that will be added to the catalog.\n */\n buildEntityProviderMutation(entities: Entity[]) {\n const locationKey = `gloo-platform-portal-provider`;\n const mutationObj: EntityProviderMutation = {\n type: 'full',\n entities: [\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'Group',\n metadata: {\n name: this.bsGroupName,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n },\n spec: {\n type: 'service-account-group',\n children: [],\n members: [this.bsServiceAccountName],\n },\n },\n },\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'User',\n metadata: {\n name: this.bsServiceAccountName,\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n },\n spec: {\n displayName: 'Solo.io Service Account',\n email: '',\n picture: '',\n memberOf: [this.bsGroupName],\n },\n },\n },\n // {\n // locationKey,\n // entity: {\n // apiVersion: 'backstage.io/v1alpha1',\n // kind: 'Domain',\n // metadata: {\n // tags: ['gloo-platform'],\n // name: 'api-product',\n // description: 'Gloo Platform Portal ApiProduct resources.',\n // annotations: {\n // 'backstage.io/managed-by-location': 'url:' + this.apisEndpoint,\n // 'backstage.io/managed-by-origin-location':\n // 'url:' + this.apisEndpoint,\n // },\n // } as EntityMeta,\n // spec: {\n // owner: 'user:' + bsServiceAccountName,\n // },\n // },\n // },\n {\n locationKey,\n entity: {\n apiVersion: 'backstage.io/v1alpha1',\n kind: 'System',\n metadata: {\n tags: ['gloo-platform'],\n name: this.bsSystemName,\n title: 'Gloo Platform Portal APIs',\n annotations: {\n 'backstage.io/managed-by-location': `url:${this.portalServerUrl}`,\n 'backstage.io/managed-by-origin-location': `url:${this.portalServerUrl}`,\n },\n } as EntityMeta,\n spec: {\n owner: `user:${this.bsServiceAccountName}`,\n // domain: 'api-product',\n },\n },\n },\n ...entities.map(entity => ({ locationKey, entity })),\n ],\n };\n return mutationObj;\n }\n}\n","import { LoggerService, SchedulerService } from '@backstage/backend-plugin-api';\nimport { Entity } from '@backstage/catalog-model';\nimport { Config } from '@backstage/config';\nimport {\n EntityProvider,\n EntityProviderConnection,\n} from '@backstage/plugin-catalog-node';\nimport fetch from 'node-fetch';\nimport { ConfigUtil } from './ConfigUtil';\nimport { EntityBuilder } from './EntityBuilder';\nimport {\n API,\n APIProduct,\n APISchema,\n AccessTokensResponse,\n ApiProductSummary,\n ApiVersion,\n ApiVersionExtended,\n} from './api-types';\nimport { doAccessTokenRequest, parseJwt } from './utility';\n\ntype PortalServerType = 'gloo-mesh-gateway' | 'gloo-gateway' | 'unknown';\n\ntype ApisEndpointResponseType =\n | API[]\n | APIProduct[]\n | ApiProductSummary[]\n | null;\n\n\ntype EntityTransformation = (entity: Entity, api: ApiVersionExtended | API) => Promise<Entity>\n\n/**\n * Provides API entities from the Gloo Platform Portal REST server.\n */\nexport class GlooPlatformPortalProvider implements EntityProvider {\n private connection?: EntityProviderConnection;\n private logger: LoggerService;\n private config: Config;\n private latestTokensResponse?: AccessTokensResponse;\n private debugLogging = false;\n private entityTransformation?: EntityTransformation;\n\n // Helper classes\n private configUtil: ConfigUtil;\n private entityBuilder: EntityBuilder;\n\n /**\n * Defaults to 'unknown'.\n * This is updated to 'gloo-gateway' or 'gloo-mesh-gateway' depending on the api response.\n */\n private _portalServerType: PortalServerType = 'unknown';\n private get portalServerType() {\n return this._portalServerType;\n }\n private _portalServerUrl = '';\n private get portalServerUrl() {\n return this._portalServerUrl;\n }\n private _apisEndpoint = '';\n private get apisEndpoint() {\n return this._apisEndpoint;\n }\n private get gmg_apisEndpoint() {\n return this.portalServerUrl + '/apis';\n }\n private get gg_apisEndpoint() {\n return this.portalServerUrl + '/api-products';\n }\n\n log = (s: string) => this.logger?.info(`gloo-platform-portal: ${s}`);\n warn = (s: string) => this.logger?.warn(`gloo-platform-portal: ${s}`);\n error = (s: string) => this.logger?.error(`gloo-platform-portal: ${s}`);\n getProviderName = () => `gloo-platform-portal-backend-provider`;\n async connect(connection: EntityProviderConnection): Promise<void> {\n this.connection = connection;\n }\n\n updatePortalServerUrl() {\n this._portalServerUrl = this.configUtil.getPortalServerUrl();\n this.entityBuilder.onPortalServerUrlChange(this.portalServerUrl);\n }\n\n updateApisEndpoint() {\n // For portalServerType:\n // - \"unknown, and \"gloo-mesh-gateway\": use GMG endpoint\n // - \"gloo-gateway\": use GG endpoint\n this._apisEndpoint =\n this.portalServerType === 'gloo-gateway'\n ? this.gg_apisEndpoint\n : this.gmg_apisEndpoint;\n this.entityBuilder.onApisEndpointChange(this.apisEndpoint);\n }\n\n updatePortalServerType(newType: typeof this.portalServerType) {\n this._portalServerType = newType;\n // When the portal server type changes, the apis endpoint may be updated.\n this.updateApisEndpoint();\n }\n\n\n //\n // 1. Init class\n //\n constructor(\n logger: LoggerService,\n config: Config,\n scheduler: SchedulerService,\n entityTransformation?: EntityTransformation\n ) {\n this.logger = logger;\n this.config = config;\n this.entityTransformation = entityTransformation;\n this.configUtil = new ConfigUtil(this.error, this.warn, this.config);\n this.entityBuilder = new EntityBuilder();\n // Default extra debug-logging to false\n this.debugLogging = !!this.config?.getOptionalBoolean(\n 'glooPlatformPortal.backend.debugLogging',\n );\n this.log('Initializing GlooPlatformPortalProvider.');\n // Get the tokens, then schedule the task to update the catalog.\n this.startTokensRequests().then(() => this.startScheduler(scheduler));\n }\n\n //\n // 2. Get access_token\n //\n async startTokensRequests() {\n //\n // Make the initial request for the access_token.\n if (this.debugLogging) {\n this.log('Making the initial access_token request.');\n }\n if (!this.config) {\n this.error(\n 'Backstage config object not found when doing access token request.',\n );\n return;\n }\n const res = await doAccessTokenRequest(\n 'client_credentials',\n this.configUtil.getTokenEndpoint(),\n this.configUtil.getClientId(),\n this.configUtil.getClientSecret(),\n );\n this.latestTokensResponse = res;\n if (!this.latestTokensResponse) {\n // If there's a problem, wait to restart the access token\n // requests so as to not overload the auth server.\n this.warn('No latest access token. Re-requesting the access_token.');\n setTimeout(this.startTokensRequests.bind(this), 5000);\n return;\n }\n if (this.debugLogging) {\n this.log('Got the access_token.');\n }\n //\n // Parse the access_token JWT to find when it expires.\n const parsedToken = parseJwt(this.latestTokensResponse.access_token);\n if (!parsedToken.exp) {\n this.warn('No `exp` property found in the access_token JWT.');\n }\n const nowDate = new Date();\n const expiresDate = new Date(parsedToken.exp * 1000);\n const millisUntilExpires = expiresDate.getTime() - nowDate.getTime();\n if (millisUntilExpires <= 0) {\n this.warn('access token is expired!');\n this.latestTokensResponse = undefined;\n return;\n }\n if (this.debugLogging) {\n this.log('Setting a timeout to get the next access token.');\n }\n // Set the timeout to request new tokens.\n setTimeout(\n this.startTokensRequests.bind(this),\n // Don't make this request more than once a second,\n // and do the refresh 5 seconds early.\n Math.max(1000, millisUntilExpires - 5000),\n );\n }\n\n /**\n *\n * 3. Schedule sync.\n *\n * This passes the user config into the\n * Backstage plugin task scheduler.\n * */\n async startScheduler(scheduler: SchedulerService) {\n if (this.debugLogging) {\n this.log('Scheduling backstage catalog sync.');\n }\n const frequencyConfig = this.config?.getOptionalConfig(\n 'glooPlatformPortal.backend.syncFrequency',\n );\n // Get frequency from the config.\n const frequency = {\n hours: frequencyConfig?.getOptionalNumber('hours') ?? 0,\n minutes: frequencyConfig?.getOptionalNumber('minutes') ?? 0,\n seconds: frequencyConfig?.getOptionalNumber('seconds') ?? 0,\n milliseconds: frequencyConfig?.getOptionalNumber('milliseconds') ?? 0,\n };\n if (Object.values(frequency).every(v => v === 0)) {\n // If there are no values for frequency, set a resonable default instead of 0.\n frequency.minutes = 5;\n if (this.debugLogging) {\n this.log(\n `No frequency value was set, so the default value of ${frequency.minutes} minutes will be used.`,\n );\n }\n }\n if (this.debugLogging) {\n this.log(`Frequency set to ${JSON.stringify(frequency)}.`);\n }\n // Get timeout from the config.\n const timeoutConfig = this.config?.getOptionalConfig(\n 'glooPlatformPortal.backend.syncTimeout',\n );\n const timeout = {\n hours: timeoutConfig?.getOptionalNumber('hours') ?? 0,\n minutes: timeoutConfig?.getOptionalNumber('minutes') ?? 0,\n seconds: timeoutConfig?.getOptionalNumber('seconds') ?? 0,\n milliseconds: timeoutConfig?.getOptionalNumber('milliseconds') ?? 0,\n };\n if (Object.values(timeout).every(v => v === 0)) {\n // If there are no values for timeout, set a resonable default instead of 0.\n timeout.seconds = 30;\n if (this.debugLogging) {\n this.log(\n `No timeout value was set. The default value of ${timeout.seconds} seconds will be used.`,\n );\n }\n }\n if (this.debugLogging) {\n this.log(`Timeout set to ${JSON.stringify(timeout)}.`);\n }\n // Start the sync task on the Backstage scheduler.\n await scheduler.scheduleTask({\n id: 'run_gloo_platform_portal_refresh',\n fn: async () => {\n await this.run();\n },\n frequency,\n timeout,\n });\n }\n\n /**\n *\n * 4. Return new Backstage entities.\n *\n * Requests API information from the Gloo Platform Portal REST server,\n * and transforms the response into Backstage API entities.\n */\n async run(): Promise<void> {\n if (!this.connection || !this.latestTokensResponse) {\n throw new Error('Not initialized');\n }\n const entities: Entity[] = [];\n this.updatePortalServerUrl();\n this.updateApisEndpoint();\n\n // Make API request\n try {\n let processedAPIs = await this.fetchAPIs();\n\n //\n // Some Gloo Mesh Gateway portal servers returned the APIs grouped by APIProduct,\n // so we can convert it back to a list here.\n //\n if (\n this.portalServerType === 'gloo-mesh-gateway' &&\n !!processedAPIs?.length &&\n 'apiVersions' in processedAPIs[0]\n ) {\n const apiProducts = processedAPIs as unknown as APIProduct[];\n processedAPIs = apiProducts.reduce((accum, curProd) => {\n accum.push(\n ...curProd.apiVersions.reduce((accumVer, api) => {\n if (!!api.openapiSpecFetchErr) {\n this.warn(\n `Schema fetch error for ${api.apiId} : ${JSON.stringify(\n api.openapiSpecFetchErr,\n )}`,\n );\n }\n accumVer.push({\n apiId: api.apiId,\n apiProductDisplayName: curProd.apiProductDisplayName,\n apiProductId: curProd.apiProductId,\n apiVersion: api.apiVersion,\n contact: api.contact,\n customMetadata: api.customMetadata,\n description: api.description,\n license: api.license,\n termsOfService: api.termsOfService,\n title: api.title,\n usagePlans: api.usagePlans,\n openapiSpec: api.openapiSpec,\n openapiSpecFetchErr: api.openapiSpecFetchErr,\n });\n return accumVer;\n }, [] as API[]),\n );\n return accum;\n }, [] as API[]);\n }\n\n // Convert the APIs to entities\n for (let i = 0; i < processedAPIs.length; i++) {\n const api = processedAPIs[i];\n if ('id' in api) {\n //\n // For \"gloo-gateway\"\n //\n this.updatePortalServerType('gloo-gateway');\n let entity = await this.getGlooGatewayApiEntity(api);\n entities.push(await this.applyEntityTransformation(entity, api));\n } else if ('apiProductId' in api) {\n //\n // For \"gloo-mesh-gateway\"\n //\n this.updatePortalServerType('gloo-mesh-gateway');\n let entity = await this.getGlooMeshGatewayApiEntity(api);\n entities.push(await this.applyEntityTransformation(entity, api));\n }\n }\n if (this.debugLogging) {\n this.log(\n 'Transformed APIs into new entities: ' + JSON.stringify(entities),\n );\n }\n } catch (e) {\n this.error(\n `Could not get APIs from the portal server endpoint or their schemas or transform them into entities (${\n this.apisEndpoint\n }). Error: ${JSON.stringify(e)}`,\n );\n }\n\n await this.connection.applyMutation(\n this.entityBuilder.buildEntityProviderMutation(entities),\n );\n }\n\n /**\n * Returns the Backstage catalog entity for the \"gloo-gateway\" Portal Server API response.\n */\n async getGlooGatewayApiEntity(api: ApiVersionExtended): Promise<Entity> {\n return this.entityBuilder.buildApiVersionEntity(\n api.id,\n api.name,\n api.apiProductDescription,\n api.apiSpec,\n );\n }\n\n /**\n * Returns the Backstage catalog entity for the \"gloo-mesh-gateway\" Portal Server API response.\n */\n async getGlooMeshGatewayApiEntity(api: API): Promise<Entity> {\n if (!this.connection || !this.latestTokensResponse || !this.apisEndpoint) {\n throw new Error('Unable to getGlooMeshGatewayApiEntity');\n }\n let schema = api.openapiSpec;\n if (!schema && !api.openapiSpecFetchErr) {\n // If the schema was not attempted to be fetched with\n // the /apis call, we individually fetch it here.\n // This is for backwards compatibility only, for\n // when the schema was not in the /apis response.\n const schemaRes = await fetch(\n `${this.apisEndpoint}/${api.apiId}/schema`,\n {\n headers: {\n Authorization: `Bearer ${this.latestTokensResponse.access_token}`,\n },\n },\n );\n schema = (await schemaRes.json()) as APISchema;\n }\n return this.entityBuilder.buildApiVersionEntity(\n api.apiId,\n api.apiVersion,\n api.description,\n schema,\n );\n }\n\n /**\n * A helper function for getting the API's from the Portal Server.\n * This abstracts away the \"gloo-gateway\"/\"gloo-mesh-gateway\" portal server details.\n */\n async fetchAPIs() {\n if (!this.connection || !this.latestTokensResponse || !this.apisEndpoint) {\n throw new Error('Unable to fetch APIs');\n }\n const fetchInit: fetch.RequestInit = {\n headers: {\n Authorization: `Bearer ${this.latestTokensResponse.access_token}`,\n },\n };\n\n //\n // Make the initial apis request.\n //\n if (this.debugLogging) {\n this.log(\n `Fetching APIs from ${this.apisEndpoint} (identified as ${this.portalServerType}) with header: \"Authorization: Bearer ${this.latestTokensResponse.access_token}\"`,\n );\n }\n let res: ApisEndpointResponseType = null;\n try {\n res = await (await fetch(this.apisEndpoint, fetchInit)).json();\n } catch {}\n if (\n // If we didn't just try the GG endpoint, and\n this.apisEndpoint !== this.gg_apisEndpoint &&\n // the GG+GMG endpoints aren't the same, and\n this.gg_apisEndpoint !== this.gmg_apisEndpoint &&\n // the GMG request failed, or\n (!res ||\n // the GMG request didn't fail, it returned data, but it's not an array, or\n !Array.isArray(res) ||\n // the GMG request didn't fail, it returned data, but\n (!!res.length &&\n // it didn't return either GG or GMG data,\n !('id' in res[0]) &&\n !('apiVersions' in res[0])))\n ) {\n // try with the GG endpoint.\n if (this.debugLogging) {\n this.log(`Retrying fetching APIs using ${this.gg_apisEndpoint}`);\n }\n try {\n res = await (await fetch(this.gg_apisEndpoint, fetchInit)).json();\n } catch {}\n }\n if (this.debugLogging) {\n this.log(\n 'Performed fetch and recieved the response: ' + JSON.stringify(res),\n );\n }\n\n let processedAPIs: (API | ApiVersionExtended)[] = [];\n if (!!res?.length) {\n //\n // Check the portal server API type\n //\n var identifiedPortalServerType: PortalServerType = 'unknown';\n if ('id' in res[0]) {\n identifiedPortalServerType = 'gloo-gateway';\n } else {\n identifiedPortalServerType = 'gloo-mesh-gateway';\n }\n if (\n this.debugLogging &&\n this.portalServerType !== identifiedPortalServerType\n ) {\n this.log(\n 'Portal server type identified as: ' + identifiedPortalServerType,\n );\n }\n this.updatePortalServerType(identifiedPortalServerType);\n\n //\n // Transform the data\n //\n // For \"gloo-mesh-gateway\"\n if (identifiedPortalServerType === 'gloo-mesh-gateway') {\n if ('apiVersions' in res[0]) {\n // Some versions return the data grouped by APIProduct,\n // so we convert it back to a list here.\n const apiProducts = res as APIProduct[];\n processedAPIs = apiProducts.reduce((accum, curProd) => {\n accum.push(\n ...curProd.apiVersions.reduce((accumVer, api) => {\n accumVer.push({\n apiId: api.apiId,\n apiProductDisplayName: curProd.apiProductDisplayName,\n apiProductId: curProd.apiProductId,\n apiVersion: api.apiVersion,\n contact: api.contact,\n customMetadata: api.customMetadata,\n description: api.description,\n license: api.license,\n termsOfService: api.termsOfService,\n title: api.title,\n usagePlans: api.usagePlans,\n });\n return accumVer;\n }, [] as API[]),\n );\n return accum;\n }, [] as API[]);\n } else {\n processedAPIs = res as API[];\n }\n }\n // For \"gloo-gateway\"\n else if (identifiedPortalServerType === 'gloo-gateway') {\n // Fetch the information for each version.\n const summaries = res as ApiProductSummary[];\n // Reset the processedAPIs so we can add each version to it.\n processedAPIs = [];\n // We have to do a separate request for each ApiProduct in order to get their versions.\n for (let i = 0; i < summaries.length; i++) {\n const apiProductSummary = summaries[i];\n const getVersionsUrl = `${this.apisEndpoint}/${apiProductSummary.id}/versions`;\n if (this.debugLogging) {\n this.log(\n `Fetching API versions from ${getVersionsUrl} (identified as ${this.portalServerType}).`,\n );\n }\n let versions: ApiVersion[] = [];\n try {\n versions = await (await fetch(getVersionsUrl, fetchInit)).json();\n } catch {}\n if (this.debugLogging) {\n this.log(\n `Fetched ${getVersionsUrl} (identified as ${\n this.portalServerType\n }) and recieved the response: ${JSON.stringify(versions)}`,\n );\n }\n if (!!versions?.length) {\n // Add each API product's version to the processedAPIs.\n processedAPIs.push(\n ...versions.map(v => ({\n ...v,\n apiProductDescription: apiProductSummary.description,\n })),\n );\n }\n }\n }\n }\n\n return processedAPIs;\n }\n\n private async applyEntityTransformation(entity: Entity, api: ApiVersionExtended | API) {\n if (!!this.entityTransformation) {\n return await this.entityTransformation(entity, api);\n }\n\n return entity;\n }\n}\n"],"names":["fetch"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -135,4 +135,5 @@ declare class GlooPlatformPortalProvider implements EntityProvider {
135
135
  private applyEntityTransformation;
136
136
  }
137
137
 
138
- export { type API, type ApiVersion, GlooPlatformPortalProvider };
138
+ export { GlooPlatformPortalProvider };
139
+ export type { API, ApiVersion };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@solo.io/platform-portal-backstage-plugin-backend",
3
3
  "description": "A Backstage backend plugin that synchronizes Gloo Platform Portal APIs with the Backstage catalog.",
4
- "version": "0.0.50",
4
+ "version": "0.0.53",
5
5
  "main": "dist/index.cjs.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "license": "Apache-2.0",
@@ -25,7 +25,11 @@
25
25
  "gloo-platform-portal"
26
26
  ],
27
27
  "backstage": {
28
- "role": "backend-plugin"
28
+ "role": "backend-plugin",
29
+ "pluginId": "catalog",
30
+ "pluginPackages": [
31
+ "@solo.io/platform-portal-backstage-plugin-backend"
32
+ ]
29
33
  },
30
34
  "scripts": {
31
35
  "start": "backstage-cli package start",
@@ -37,11 +41,12 @@
37
41
  "postpack": "backstage-cli package postpack"
38
42
  },
39
43
  "dependencies": {
40
- "@backstage/backend-common": "^0.18.2-next.0",
44
+ "@backstage/backend-common": "^0.24.1-next.0",
41
45
  "@backstage/catalog-model": "^1.1.6-next.0",
42
46
  "@backstage/config": "^1.0.6",
43
47
  "@backstage/plugin-catalog-node": "^1.3.3-next.0",
44
48
  "@types/express": "*",
49
+ "@types/node-fetch": "^2.6.13",
45
50
  "express": "^4.18.1",
46
51
  "express-promise-router": "^4.1.0",
47
52
  "node-fetch": "2",
@@ -49,7 +54,7 @@
49
54
  "yn": "^4.0.0"
50
55
  },
51
56
  "devDependencies": {
52
- "@backstage/cli": "^0.22.1",
57
+ "@backstage/cli": "^0.26.5",
53
58
  "@types/supertest": "^2.0.8",
54
59
  "msw": "^0.49.0",
55
60
  "supertest": "^6.2.4"