@pagerduty/backstage-plugin-entity-processor 0.3.0-next.4 → 0.3.0-next.40

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
@@ -46,7 +46,7 @@ class PagerDutyClient {
46
46
  case 400:
47
47
  throw new Error(await response.text());
48
48
  case 404:
49
- return {};
49
+ return void 0;
50
50
  default:
51
51
  this.logger.debug(`Found mapping for ${type}:${namespace}/${name}: ${JSON.stringify(foundMapping.mapping)}`);
52
52
  return {
@@ -61,6 +61,71 @@ class PagerDutyClient {
61
61
  throw new Error(`Failed to retrieve mapping for ${type}:${namespace}/${name}: ${error}`);
62
62
  }
63
63
  }
64
+ async findServiceMappingById(serviceId) {
65
+ let response;
66
+ if (this.baseUrl === "") {
67
+ this.baseUrl = await this.discovery.getBaseUrl("pagerduty");
68
+ }
69
+ const options = {
70
+ method: "GET",
71
+ headers: {
72
+ "Content-Type": "application/json; charset=UTF-8",
73
+ Accept: "application/json, text/plain, */*"
74
+ }
75
+ };
76
+ const url = `${await this.discovery.getBaseUrl(
77
+ "pagerduty"
78
+ )}/mapping/entity/service/${serviceId}`;
79
+ try {
80
+ response = await fetch__default["default"](url, options);
81
+ const foundMapping = await response.json();
82
+ switch (response.status) {
83
+ case 400:
84
+ throw new Error(await response.text());
85
+ case 404:
86
+ return void 0;
87
+ default:
88
+ this.logger.debug(`Found mapping for serviceId ${serviceId}: ${JSON.stringify(foundMapping.mapping)}`);
89
+ return {
90
+ serviceId: foundMapping.mapping.serviceId,
91
+ integrationKey: foundMapping.mapping.integrationKey,
92
+ entityRef: foundMapping.mapping.entityRef,
93
+ account: foundMapping.mapping.account
94
+ };
95
+ }
96
+ } catch (error) {
97
+ this.logger.error(`Failed to retrieve mapping for serviceId ${serviceId}: ${error}`);
98
+ throw new Error(`Failed to retrieve mapping for serviceId ${serviceId}: ${error}`);
99
+ }
100
+ }
101
+ async insertServiceMapping(mapping) {
102
+ let response;
103
+ if (this.baseUrl === "") {
104
+ this.baseUrl = await this.discovery.getBaseUrl("pagerduty");
105
+ }
106
+ this.logger.info(`Adding mapping for ${mapping.entityRef} to database with payload: ${JSON.stringify(mapping)}`);
107
+ const options = {
108
+ method: "POST",
109
+ headers: {
110
+ "Content-Type": "application/json; charset=UTF-8",
111
+ Accept: "application/json, text/plain, */*"
112
+ },
113
+ body: JSON.stringify(mapping)
114
+ };
115
+ const url = `${await this.discovery.getBaseUrl(
116
+ "pagerduty"
117
+ )}/mapping/entity`;
118
+ try {
119
+ response = await fetch__default["default"](url, options);
120
+ if (!response.ok) {
121
+ throw new Error(await response.text());
122
+ }
123
+ this.logger.info(`Mapping for ${mapping.entityRef} added to database.`);
124
+ } catch (error) {
125
+ this.logger.error(`Failed to add mapping for ${mapping.entityRef}: ${error}`);
126
+ throw new Error(`Failed to add mapping for ${mapping.entityRef}: ${error}`);
127
+ }
128
+ }
64
129
  async getServiceDependencies(serviceId, account) {
65
130
  let response;
66
131
  if (this.baseUrl === "") {
@@ -88,7 +153,7 @@ class PagerDutyClient {
88
153
  case 404:
89
154
  return [];
90
155
  default:
91
- this.logger.info(`Found mapping for ${serviceId}: ${JSON.stringify(foundDependencies.relationships)}`);
156
+ this.logger.info(`Found dependencies for ${serviceId}: ${JSON.stringify(foundDependencies.relationships)}`);
92
157
  return foundDependencies.relationships;
93
158
  }
94
159
  } catch (error) {
@@ -130,6 +195,118 @@ class PagerDutyClient {
130
195
  throw new Error(`Failed to retrieve a PagerDuty service id for ${entityRef}: ${error}`);
131
196
  }
132
197
  }
198
+ async getServiceIdFromIntegrationKey(integrationKey, account) {
199
+ let response;
200
+ if (this.baseUrl === "") {
201
+ this.baseUrl = await this.discovery.getBaseUrl("pagerduty");
202
+ }
203
+ const options = {
204
+ method: "GET",
205
+ headers: {
206
+ "Content-Type": "application/json; charset=UTF-8",
207
+ Accept: "application/json, text/plain, */*"
208
+ }
209
+ };
210
+ let url = `${await this.discovery.getBaseUrl(
211
+ "pagerduty"
212
+ )}/services?integration_key=${integrationKey}`;
213
+ if (account) {
214
+ url = url.concat(`&account=${account}`);
215
+ }
216
+ try {
217
+ response = await fetch__default["default"](url, options);
218
+ const foundService = await response.json();
219
+ switch (response.status) {
220
+ case 400:
221
+ throw new Error(await response.text());
222
+ case 404:
223
+ return "";
224
+ default:
225
+ this.logger.info(`Found service id ${foundService.service.id} from integration key ${integrationKey}`);
226
+ return foundService.service.id;
227
+ }
228
+ } catch (error) {
229
+ this.logger.error(`Failed to retrieve a PagerDuty service id for integration key ${integrationKey}: ${error}`);
230
+ throw new Error(`Failed to retrieve a PagerDuty service id for integration key ${integrationKey}: ${error}`);
231
+ }
232
+ }
233
+ async getIntegrationKeyFromServiceId(serviceId, account) {
234
+ var _a;
235
+ let response;
236
+ if (this.baseUrl === "") {
237
+ this.baseUrl = await this.discovery.getBaseUrl("pagerduty");
238
+ }
239
+ const options = {
240
+ method: "GET",
241
+ headers: {
242
+ "Content-Type": "application/json; charset=UTF-8",
243
+ Accept: "application/json, text/plain, */*"
244
+ }
245
+ };
246
+ let url = `${await this.discovery.getBaseUrl(
247
+ "pagerduty"
248
+ )}/services/${serviceId}`;
249
+ if (account) {
250
+ url = url.concat(`?account=${account}`);
251
+ }
252
+ try {
253
+ response = await fetch__default["default"](url, options);
254
+ const foundService = await response.json();
255
+ const backstageIntegration = (_a = foundService.service.integrations) == null ? void 0 : _a.find((integration) => {
256
+ var _a2;
257
+ return ((_a2 = integration.vendor) == null ? void 0 : _a2.id) === "PRO19CT";
258
+ });
259
+ switch (response.status) {
260
+ case 400:
261
+ throw new Error(await response.text());
262
+ case 404:
263
+ return "";
264
+ default:
265
+ if (!backstageIntegration) {
266
+ this.logger.info(`No Backstage integration found in service ${foundService.service.id}`);
267
+ return void 0;
268
+ }
269
+ this.logger.info(`Found Backstage integration in service ${foundService.service.id}`);
270
+ return backstageIntegration.integration_key;
271
+ }
272
+ } catch (error) {
273
+ this.logger.error(`No Backstage integration found for service id ${serviceId}: ${error}`);
274
+ throw new Error(`No Backstage integration found for service id ${serviceId}: ${error}`);
275
+ }
276
+ }
277
+ async createBackstageIntegration(serviceId, account) {
278
+ const backstageVendorId = "PRO19CT";
279
+ let response;
280
+ const options = {
281
+ method: "POST",
282
+ headers: {
283
+ "Content-Type": "application/json; charset=UTF-8",
284
+ Accept: "application/json, text/plain, */*"
285
+ }
286
+ };
287
+ let url = `${await this.discovery.getBaseUrl(
288
+ "pagerduty"
289
+ )}/services/${serviceId}/integration/${backstageVendorId}`;
290
+ if (account) {
291
+ url = url.concat(`?account=${account}`);
292
+ }
293
+ try {
294
+ response = await fetch__default["default"](url, options);
295
+ const integrationKey = await response.json();
296
+ switch (response.status) {
297
+ case 400:
298
+ throw new Error(await response.text());
299
+ case 404:
300
+ return "";
301
+ default:
302
+ this.logger.info(`Created Backstage integration for service id ${serviceId}: ${integrationKey}`);
303
+ return integrationKey;
304
+ }
305
+ } catch (error) {
306
+ this.logger.error(`Could not create a Backstage integration for service id ${serviceId}: ${error}`);
307
+ throw new Error(`Could not create a Backstage integration for service id ${serviceId}: ${error}`);
308
+ }
309
+ }
133
310
  }
134
311
 
135
312
  var __defProp = Object.defineProperty;
@@ -154,7 +331,7 @@ class PagerDutyEntityProcessor {
154
331
  return "PagerDutyEntityProcessor";
155
332
  }
156
333
  async postProcessEntity(entity) {
157
- var _a, _b, _c;
334
+ var _a, _b, _c, _d;
158
335
  if (this.shouldProcessEntity(entity)) {
159
336
  try {
160
337
  const mapping = await client.findServiceMapping({
@@ -162,64 +339,103 @@ class PagerDutyEntityProcessor {
162
339
  namespace: entity.metadata.namespace.toLowerCase(),
163
340
  name: entity.metadata.name.toLowerCase()
164
341
  });
165
- if (mapping.serviceId) {
166
- if (mapping.serviceId && mapping.serviceId !== "") {
167
- entity.metadata.annotations["pagerduty.com/service-id"] = mapping.serviceId;
168
- } else {
169
- delete entity.metadata.annotations["pagerduty.com/service-id"];
170
- }
171
- if (mapping.integrationKey && mapping.integrationKey !== "") {
172
- entity.metadata.annotations["pagerduty.com/integration-key"] = mapping.integrationKey;
173
- } else {
174
- delete entity.metadata.annotations["pagerduty.com/integration-key"];
175
- }
176
- if (mapping.account && mapping.account !== "") {
177
- entity.metadata.annotations["pagerduty.com/account"] = mapping.account;
178
- } else {
179
- delete entity.metadata.annotations["pagerduty.com/account"];
180
- }
342
+ this.logger.info(`Got mapping result ${JSON.stringify(mapping)}`);
343
+ if (mapping) {
344
+ updateAnnotations(
345
+ entity,
346
+ {
347
+ serviceId: mapping.serviceId,
348
+ integrationKey: mapping.integrationKey,
349
+ account: mapping.account
350
+ }
351
+ );
181
352
  this.logger.debug(`Added annotations to entity ${entity.metadata.name} with service id: ${mapping.serviceId}, integration key: ${mapping.integrationKey} and account: ${mapping.account}`);
182
353
  } else {
183
- this.logger.debug(`No mapping found for entity: ${entity.metadata.name}`);
184
- }
185
- if ((_a = entity.spec) == null ? void 0 : _a.dependsOn) {
186
- const serviceId = entity.metadata.annotations["pagerduty.com/service-id"];
187
- const dependencyAnnotations = JSON.parse(JSON.stringify((_b = entity.spec) == null ? void 0 : _b.dependsOn));
188
- this.logger.info(`Existing dependencies for entity: ${entity.metadata.name}. Dependencies: ${JSON.stringify(dependencyAnnotations)}`);
189
- if (serviceId && (dependencyAnnotations == null ? void 0 : dependencyAnnotations.length) > 0) {
190
- const existingDependencies = await buildExistingDependencies(dependencyAnnotations);
191
- const account = entity.metadata.annotations["pagerduty.com/account"];
192
- const dependencies = await client.getServiceDependencies(serviceId, account);
193
- this.logger.info(`Dependencies from PagerDuty service: ${serviceId}. Dependencies: ${JSON.stringify(dependencies)}`);
194
- const newDependencies = dependencies.filter((dependency) => !existingDependencies.includes(dependency.supporting_service.id));
195
- this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);
196
- if (newDependencies.length > 0) {
197
- this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);
354
+ this.logger.info(`No mapping found for entity: ${entity.metadata.name}. Adding annotations to the database.`);
355
+ let serviceId = (_a = entity.metadata.annotations) == null ? void 0 : _a["pagerduty.com/service-id"];
356
+ let integrationKey = (_b = entity.metadata.annotations) == null ? void 0 : _b["pagerduty.com/integration-key"];
357
+ const account = (_c = entity.metadata.annotations) == null ? void 0 : _c["pagerduty.com/account"];
358
+ const entityRef = `${entity.kind.toLowerCase()}:${(_d = entity.metadata.namespace) == null ? void 0 : _d.toLowerCase()}/${entity.metadata.name.toLowerCase()}`;
359
+ if (serviceId) {
360
+ const serviceMappingOverrideFound = await client.findServiceMappingById(serviceId);
361
+ if (!serviceMappingOverrideFound) {
362
+ if (!integrationKey) {
363
+ const foundIntegrationKey = await client.getIntegrationKeyFromServiceId(serviceId, account);
364
+ if (foundIntegrationKey) {
365
+ integrationKey = foundIntegrationKey;
366
+ } else {
367
+ this.logger.info(`Adding Backstage integration to service: ${serviceId}`);
368
+ integrationKey = await client.createBackstageIntegration(serviceId, account);
369
+ this.logger.info(`Backstage integration created for service: ${serviceId}`);
370
+ }
371
+ }
372
+ this.logger.info(`Inserting mapping for entity: ${entityRef} with service id: ${serviceId}, integration key: ${integrationKey} and account: ${account}`);
373
+ await client.insertServiceMapping({
374
+ entityRef,
375
+ serviceId,
376
+ integrationKey,
377
+ account
378
+ });
379
+ updateAnnotations(
380
+ entity,
381
+ {
382
+ serviceId,
383
+ integrationKey,
384
+ account
385
+ }
386
+ );
387
+ } else {
388
+ this.logger.info(`Service mapping override found for service id: ${serviceId}.`);
389
+ updateAnnotations(entity, {});
390
+ }
391
+ } else if (integrationKey) {
392
+ serviceId = await client.getServiceIdFromIntegrationKey(integrationKey, account);
393
+ const serviceMappingOverrideFound = await client.findServiceMappingById(serviceId);
394
+ if (!serviceMappingOverrideFound) {
395
+ this.logger.info(`Inserting mapping for entity: ${entityRef} with new service id: ${serviceId}, integration key: ${integrationKey} and account: ${account}`);
396
+ await client.insertServiceMapping({
397
+ entityRef,
398
+ serviceId,
399
+ integrationKey,
400
+ account
401
+ });
402
+ updateAnnotations(
403
+ entity,
404
+ {
405
+ serviceId,
406
+ integrationKey,
407
+ account
408
+ }
409
+ );
410
+ } else {
411
+ this.logger.info(`Service mapping override found for service id: ${serviceId}. Skipping adding to the database.`);
412
+ updateAnnotations(entity, {});
198
413
  }
199
414
  }
200
- } else {
201
- this.logger.info(`No dependencies found for entity: ${entity.metadata.name}`);
202
- }
203
- if ((_c = entity.spec) == null ? void 0 : _c.dependencyOf) {
204
- this.logger.info(`Processing dependents for entity: ${entity.metadata.name}. Dependents: ${JSON.stringify(entity.spec.dependencyOf)}`);
205
415
  }
206
416
  } catch (error) {
207
- this.logger.error(`Error processing entity: ${entity.metadata.name}`);
208
- this.logger.error(`${error}`);
417
+ this.logger.error(`Error processing entity ${entity.metadata.name}: ${error}`);
209
418
  }
210
419
  }
211
420
  return entity;
212
421
  }
213
422
  }
214
- async function buildExistingDependencies(dependencyAnnotations) {
215
- const dependencies = [];
216
- dependencyAnnotations.map(async (dependency) => {
217
- const foundServiceId = await client.getServiceIdAnnotationFromCatalog(dependency);
218
- if (foundServiceId !== "") {
219
- dependencies.push(foundServiceId);
220
- }
221
- });
222
- return dependencies;
423
+ function updateAnnotations(entity, annotations) {
424
+ if (annotations.serviceId && annotations.serviceId !== "") {
425
+ entity.metadata.annotations["pagerduty.com/service-id"] = annotations.serviceId;
426
+ } else {
427
+ delete entity.metadata.annotations["pagerduty.com/service-id"];
428
+ }
429
+ if (annotations.integrationKey && annotations.integrationKey !== "") {
430
+ entity.metadata.annotations["pagerduty.com/integration-key"] = annotations.integrationKey;
431
+ } else {
432
+ delete entity.metadata.annotations["pagerduty.com/integration-key"];
433
+ }
434
+ if (annotations.account && annotations.account !== "") {
435
+ entity.metadata.annotations["pagerduty.com/account"] = annotations.account;
436
+ } else {
437
+ delete entity.metadata.annotations["pagerduty.com/account"];
438
+ }
223
439
  }
224
440
 
225
441
  const pagerDutyEntityProcessor = backendPluginApi.createBackendModule({
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/apis/client.ts","../src/processor/PagerDutyEntityProcessor.ts","../src/module.ts"],"sourcesContent":["import fetch from 'node-fetch';\nimport type { RequestInit, Response } from 'node-fetch';\nimport type { EntityMapping } from '../types';\nimport { DiscoveryService, LoggerService } from '@backstage/backend-plugin-api';\nimport { PagerDutyEntityMappingResponse, PagerDutyServiceDependency, PagerDutyServiceDependencyResponse } from '@pagerduty/backstage-plugin-common';\n\nexport interface PagerDutyClientOptions {\n discovery: DiscoveryService;\n logger: LoggerService;\n};\n\nexport type BackstageEntityRef = {\n type: string;\n namespace: string;\n name: string;\n}\n\nexport class PagerDutyClient {\n private discovery: DiscoveryService;\n private logger: LoggerService;\n private baseUrl: string = \"\";\n \n constructor({ discovery, logger }: PagerDutyClientOptions) {\n this.discovery = discovery;\n this.logger = logger;\n }\n\n async findServiceMapping({ type, namespace, name }: BackstageEntityRef): Promise<EntityMapping> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/mapping/entity/${type}/${namespace}/${name}`;\n\n try {\n response = await fetch(url, options);\n\n const foundMapping: PagerDutyEntityMappingResponse = await response.json(); \n\n switch (response.status) {\n case 400: \n throw new Error(await response.text());\n case 404:\n return {};\n default: // 200\n this.logger.debug(`Found mapping for ${type}:${namespace}/${name}: ${JSON.stringify(foundMapping.mapping)}`);\n\n return {\n serviceId: foundMapping.mapping.serviceId,\n integrationKey: foundMapping.mapping.integrationKey,\n entityRef: foundMapping.mapping.entityRef,\n account: foundMapping.mapping.account,\n }\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve mapping for ${type}:${namespace}/${name}: ${error}`);\n throw new Error(`Failed to retrieve mapping for ${type}:${namespace}/${name}: ${error}`);\n }\n }\n\n async getServiceDependencies(serviceId: string, account?: string): Promise<PagerDutyServiceDependency[]> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n let url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/dependencies/service/${serviceId}`;\n\n if (account) {\n url = url.concat(`?account=${account}`);\n }\n\n try {\n response = await fetch(url, options);\n\n const foundDependencies: PagerDutyServiceDependencyResponse = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return [];\n default: // 200\n this.logger.info(`Found mapping for ${serviceId}: ${JSON.stringify(foundDependencies.relationships)}`);\n\n return foundDependencies.relationships;\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve mapping for ${serviceId}: ${error}`);\n throw new Error(`Failed to retrieve mapping for ${serviceId}: ${error}`);\n }\n }\n\n async getServiceIdAnnotationFromCatalog(entityRef: string): Promise<string> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n // extract type, namespace and name from type:namespace/name\n const [type, rest] = entityRef.split(':');\n const [namespace, name] = rest.split('/');\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/catalog/entity/${type}/${namespace}/${name}`;\n\n try {\n response = await fetch(url, options);\n\n const foundServiceId: string = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return \"\";\n default: // 200\n this.logger.info(`Found serviceId for ${entityRef}: ${JSON.stringify(foundServiceId)}`);\n\n return foundServiceId;\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve a PagerDuty service id for ${entityRef}: ${error}`);\n throw new Error(`Failed to retrieve a PagerDuty service id for ${entityRef}: ${error}`);\n }\n }\n\n}","import { DiscoveryService, LoggerService } from \"@backstage/backend-plugin-api\";\nimport { Entity } from \"@backstage/catalog-model\";\nimport { CatalogProcessor } from \"@backstage/plugin-catalog-node\";\nimport { PagerDutyClient } from \"../apis/client\";\n\n/**\n * A function which given an entity, determines if it should be processed for linguist tags.\n * @public\n */\nexport type ShouldProcessEntity = (entity: Entity) => boolean;\n\nexport interface PagerDutyEntityProcessorOptions {\n logger: LoggerService;\n discovery: DiscoveryService;\n};\n\nlet client : PagerDutyClient;\n\nexport class PagerDutyEntityProcessor implements CatalogProcessor {\n private logger: LoggerService;\n private discovery: DiscoveryService;\n\n private shouldProcessEntity: ShouldProcessEntity = (entity: Entity) => {\n return entity.kind === 'Component';\n }\n\n constructor({ logger, discovery }: PagerDutyEntityProcessorOptions) {\n this.logger = logger;\n this.discovery = discovery;\n\n client = new PagerDutyClient({ discovery: this.discovery, logger: this.logger });\n }\n\n getProcessorName(): string {\n return \"PagerDutyEntityProcessor\";\n }\n\n async postProcessEntity(entity: Entity): Promise<Entity> {\n if (this.shouldProcessEntity(entity)) {\n try {\n // Process service mapping overrides\n // Find the service mapping for the entity in database\n const mapping = await client.findServiceMapping({\n type: entity.kind.toLowerCase(),\n namespace: entity.metadata.namespace!.toLowerCase(),\n name: entity.metadata.name.toLowerCase(),\n });\n\n // If mapping exists add the annotations to the entity\n if (mapping.serviceId) { \n \n // If serviceId is present, add the annotations to the entity\n if (mapping.serviceId && mapping.serviceId !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/service-id\"] = mapping.serviceId;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/service-id\"];\n }\n\n // If integrationKey is present, add the annotations to the entity\n if (mapping.integrationKey && mapping.integrationKey !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/integration-key\"] = mapping.integrationKey;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/integration-key\"];\n }\n\n // If account is present, add the annotations to the entity\n if (mapping.account && mapping.account !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/account\"] = mapping.account;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/account\"];\n }\n\n this.logger.debug(`Added annotations to entity ${entity.metadata.name} with service id: ${mapping.serviceId}, integration key: ${mapping.integrationKey} and account: ${mapping.account}`);\n } else {\n this.logger.debug(`No mapping found for entity: ${entity.metadata.name}`);\n }\n\n // Process service dependencies\n if(entity.spec?.dependsOn){\n // Check if ServiceId exists get service dependencies from PagerDuty \n const serviceId = entity.metadata.annotations![\"pagerduty.com/service-id\"];\n\n // Check if service has dependencies configured\n const dependencyAnnotations: string[] = JSON.parse(JSON.stringify(entity.spec?.dependsOn));\n this.logger.info(`Existing dependencies for entity: ${entity.metadata.name}. Dependencies: ${JSON.stringify(dependencyAnnotations)}`);\n\n if (serviceId && dependencyAnnotations?.length > 0) {\n const existingDependencies: string[] = await buildExistingDependencies(dependencyAnnotations);\n\n // Get dependencies from PagerDuty for the service\n const account = entity.metadata.annotations![\"pagerduty.com/account\"];\n const dependencies = await client.getServiceDependencies(serviceId, account);\n\n this.logger.info(`Dependencies from PagerDuty service: ${serviceId}. Dependencies: ${JSON.stringify(dependencies)}`);\n\n // compare dependencies with existing dependencies defined on the entity\n const newDependencies = dependencies.filter((dependency) => !existingDependencies.includes(dependency.supporting_service.id));\n this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);\n\n // Update dependencies on PagerDuty\n if (newDependencies.length > 0){\n // await client.updateServiceDependencies(serviceId, newDependencies);\n this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);\n }\n }\n }\n else {\n this.logger.info(`No dependencies found for entity: ${entity.metadata.name}`);\n }\n\n if(entity.spec?.dependencyOf){\n this.logger.info(`Processing dependents for entity: ${entity.metadata.name}. Dependents: ${JSON.stringify(entity.spec.dependencyOf)}`);\n }\n\n } catch (error) {\n this.logger.error(`Error processing entity: ${entity.metadata.name}`);\n this.logger.error(`${error}`);\n }\n }\n\n return entity;\n }\n}\n\nasync function buildExistingDependencies(dependencyAnnotations: string[]): Promise<string[]> {\n const dependencies: string[] = [];\n\n // Get all service ids matching the dependency annotations\n dependencyAnnotations.map(async (dependency) => {\n const foundServiceId = await client.getServiceIdAnnotationFromCatalog(dependency);\n\n if (foundServiceId !== \"\") {\n dependencies.push(foundServiceId);\n }\n });\n\n return dependencies;\n\n}","import { coreServices, createBackendModule } from \"@backstage/backend-plugin-api\";\nimport { catalogProcessingExtensionPoint } from '@backstage/plugin-catalog-node/alpha';\nimport { PagerDutyEntityProcessor } from \"./processor\";\n\n/** @public */\nexport const pagerDutyEntityProcessor = createBackendModule({\n pluginId: 'catalog',\n moduleId: 'pagerduty-entity-processor',\n register(env) {\n env.registerInit({\n deps: {\n logger: coreServices.logger,\n catalog: catalogProcessingExtensionPoint,\n discovery: coreServices.discovery,\n },\n async init({ logger, discovery, catalog }) {\n catalog.addProcessor(new PagerDutyEntityProcessor({ logger, discovery}));\n },\n });\n },\n});\n"],"names":["__publicField","fetch","createBackendModule","coreServices","catalogProcessingExtensionPoint"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/apis/client.ts","../src/processor/PagerDutyEntityProcessor.ts","../src/module.ts"],"sourcesContent":["import fetch from 'node-fetch';\nimport type { RequestInit, Response } from 'node-fetch';\nimport type { EntityMapping } from '../types';\nimport { DiscoveryService, LoggerService } from '@backstage/backend-plugin-api';\nimport { PagerDutyEntityMapping, PagerDutyEntityMappingResponse, PagerDutyServiceDependency, PagerDutyServiceDependencyResponse, PagerDutyServiceResponse } from '@pagerduty/backstage-plugin-common';\n\nexport interface PagerDutyClientOptions {\n discovery: DiscoveryService;\n logger: LoggerService;\n};\n\nexport type BackstageEntityRef = {\n type: string;\n namespace: string;\n name: string;\n}\n\nexport class PagerDutyClient {\n private discovery: DiscoveryService;\n private logger: LoggerService;\n private baseUrl: string = \"\";\n \n constructor({ discovery, logger }: PagerDutyClientOptions) {\n this.discovery = discovery;\n this.logger = logger;\n }\n\n async findServiceMapping({ type, namespace, name }: BackstageEntityRef): Promise<EntityMapping | undefined> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/mapping/entity/${type}/${namespace}/${name}`;\n\n try {\n response = await fetch(url, options);\n\n const foundMapping: PagerDutyEntityMappingResponse = await response.json(); \n\n switch (response.status) {\n case 400: \n throw new Error(await response.text());\n case 404:\n return undefined;\n default: // 200\n this.logger.debug(`Found mapping for ${type}:${namespace}/${name}: ${JSON.stringify(foundMapping.mapping)}`);\n\n return {\n serviceId: foundMapping.mapping.serviceId,\n integrationKey: foundMapping.mapping.integrationKey,\n entityRef: foundMapping.mapping.entityRef,\n account: foundMapping.mapping.account,\n }\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve mapping for ${type}:${namespace}/${name}: ${error}`);\n throw new Error(`Failed to retrieve mapping for ${type}:${namespace}/${name}: ${error}`);\n }\n }\n\n async findServiceMappingById(serviceId: string): Promise<EntityMapping | undefined> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/mapping/entity/service/${serviceId}`;\n\n try {\n response = await fetch(url, options);\n\n const foundMapping: PagerDutyEntityMappingResponse = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return undefined;\n default: // 200\n this.logger.debug(`Found mapping for serviceId ${serviceId}: ${JSON.stringify(foundMapping.mapping)}`);\n\n return {\n serviceId: foundMapping.mapping.serviceId,\n integrationKey: foundMapping.mapping.integrationKey,\n entityRef: foundMapping.mapping.entityRef,\n account: foundMapping.mapping.account,\n };\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve mapping for serviceId ${serviceId}: ${error}`);\n throw new Error(`Failed to retrieve mapping for serviceId ${serviceId}: ${error}`);\n }\n }\n\n async insertServiceMapping(mapping: PagerDutyEntityMapping): Promise<void> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n this.logger.info(`Adding mapping for ${mapping.entityRef} to database with payload: ${JSON.stringify(mapping)}`);\n\n const options: RequestInit = {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n body: JSON.stringify(mapping),\n };\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/mapping/entity`;\n\n try {\n response = await fetch(url, options);\n\n if(!response.ok) {\n throw new Error(await response.text());\n }\n\n this.logger.info(`Mapping for ${mapping.entityRef} added to database.`); \n } catch (error) {\n this.logger.error(`Failed to add mapping for ${mapping.entityRef}: ${error}`);\n throw new Error(`Failed to add mapping for ${mapping.entityRef}: ${error}`);\n }\n }\n\n async getServiceDependencies(serviceId: string, account?: string): Promise<PagerDutyServiceDependency[]> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n let url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/dependencies/service/${serviceId}`;\n\n if (account) {\n url = url.concat(`?account=${account}`);\n }\n\n try {\n response = await fetch(url, options);\n\n const foundDependencies: PagerDutyServiceDependencyResponse = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return [];\n default: // 200\n this.logger.info(`Found dependencies for ${serviceId}: ${JSON.stringify(foundDependencies.relationships)}`);\n return foundDependencies.relationships;\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve mapping for ${serviceId}: ${error}`);\n throw new Error(`Failed to retrieve mapping for ${serviceId}: ${error}`);\n }\n }\n\n async getServiceIdAnnotationFromCatalog(entityRef: string): Promise<string> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n // extract type, namespace and name from type:namespace/name\n const [type, rest] = entityRef.split(':');\n const [namespace, name] = rest.split('/');\n\n const url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/catalog/entity/${type}/${namespace}/${name}`;\n\n try {\n response = await fetch(url, options);\n\n const foundServiceId: string = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return \"\";\n default: // 200\n this.logger.info(`Found serviceId for ${entityRef}: ${JSON.stringify(foundServiceId)}`);\n\n return foundServiceId;\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve a PagerDuty service id for ${entityRef}: ${error}`);\n throw new Error(`Failed to retrieve a PagerDuty service id for ${entityRef}: ${error}`);\n }\n }\n\n async getServiceIdFromIntegrationKey(integrationKey: string, account?: string): Promise<string> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n let url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/services?integration_key=${integrationKey}`;\n\n if(account){\n url = url.concat(`&account=${account}`);\n }\n\n try {\n response = await fetch(url, options);\n\n const foundService: PagerDutyServiceResponse = await response.json();\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return \"\";\n default: // 200\n this.logger.info(`Found service id ${foundService.service.id} from integration key ${integrationKey}`);\n\n return foundService.service.id;\n }\n } catch (error) {\n this.logger.error(`Failed to retrieve a PagerDuty service id for integration key ${integrationKey}: ${error}`);\n throw new Error(`Failed to retrieve a PagerDuty service id for integration key ${integrationKey}: ${error}`);\n }\n }\n\n async getIntegrationKeyFromServiceId(serviceId: string, account?: string): Promise<string | undefined> {\n let response: Response;\n\n if (this.baseUrl === \"\") {\n this.baseUrl = await this.discovery.getBaseUrl('pagerduty');\n }\n\n const options: RequestInit = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n let url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/services/${serviceId}`;\n\n if (account) {\n url = url.concat(`?account=${account}`);\n }\n\n try {\n response = await fetch(url, options);\n\n const foundService: PagerDutyServiceResponse = await response.json();\n const backstageIntegration = foundService.service.integrations?.find(integration => integration.vendor?.id === \"PRO19CT\");\n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return \"\";\n default: // 200\n\n if (!backstageIntegration) {\n this.logger.info(`No Backstage integration found in service ${foundService.service.id}`);\n return undefined;\n }\n \n this.logger.info(`Found Backstage integration in service ${foundService.service.id}`);\n return backstageIntegration.integration_key;\n }\n } catch (error) {\n this.logger.error(`No Backstage integration found for service id ${serviceId}: ${error}`);\n throw new Error(`No Backstage integration found for service id ${serviceId}: ${error}`);\n }\n }\n\n async createBackstageIntegration(serviceId: string, account?: string) : Promise<string> {\n const backstageVendorId = \"PRO19CT\";\n let response: Response;\n\n const options: RequestInit = {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json; charset=UTF-8',\n Accept: 'application/json, text/plain, */*',\n },\n };\n\n let url = `${await this.discovery.getBaseUrl(\n 'pagerduty',\n )}/services/${serviceId}/integration/${backstageVendorId}`;\n\n if (account) {\n url = url.concat(`?account=${account}`);\n }\n\n try {\n response = await fetch(url, options);\n\n const integrationKey: string = await response.json(); \n\n switch (response.status) {\n case 400:\n throw new Error(await response.text());\n case 404:\n return \"\";\n default: // 200\n this.logger.info(`Created Backstage integration for service id ${serviceId}: ${integrationKey}`);\n return integrationKey;\n }\n } catch (error) {\n this.logger.error(`Could not create a Backstage integration for service id ${serviceId}: ${error}`);\n throw new Error(`Could not create a Backstage integration for service id ${serviceId}: ${error}`);\n }\n\n }\n}","import { DiscoveryService, LoggerService } from \"@backstage/backend-plugin-api\";\nimport { Entity } from \"@backstage/catalog-model\";\nimport { CatalogProcessor } from \"@backstage/plugin-catalog-node\";\nimport { PagerDutyClient } from \"../apis/client\";\n\n/**\n * A function which given an entity, determines if it should be processed for linguist tags.\n * @public\n */\nexport type ShouldProcessEntity = (entity: Entity) => boolean;\n\nexport interface PagerDutyEntityProcessorOptions {\n logger: LoggerService;\n discovery: DiscoveryService;\n};\n\nlet client : PagerDutyClient;\n\nexport class PagerDutyEntityProcessor implements CatalogProcessor {\n private logger: LoggerService;\n private discovery: DiscoveryService;\n\n private shouldProcessEntity: ShouldProcessEntity = (entity: Entity) => {\n return entity.kind === 'Component';\n }\n\n constructor({ logger, discovery }: PagerDutyEntityProcessorOptions) {\n this.logger = logger;\n this.discovery = discovery;\n\n client = new PagerDutyClient({ discovery: this.discovery, logger: this.logger });\n }\n\n getProcessorName(): string {\n return \"PagerDutyEntityProcessor\";\n }\n\n async postProcessEntity(entity: Entity): Promise<Entity> {\n if (this.shouldProcessEntity(entity)) {\n try {\n // Process service mapping overrides\n // Find the service mapping for the entity in database\n const mapping = await client.findServiceMapping({\n type: entity.kind.toLowerCase(),\n namespace: entity.metadata.namespace!.toLowerCase(),\n name: entity.metadata.name.toLowerCase(),\n });\n\n this.logger.info(`Got mapping result ${JSON.stringify(mapping)}`);\n\n\n // If mapping exists add the annotations to the entity\n if (mapping) { \n updateAnnotations(entity,\n {\n serviceId: mapping.serviceId,\n integrationKey: mapping.integrationKey,\n account: mapping.account\n }\n );\n\n this.logger.debug(`Added annotations to entity ${entity.metadata.name} with service id: ${mapping.serviceId}, integration key: ${mapping.integrationKey} and account: ${mapping.account}`);\n } else {\n this.logger.info(`No mapping found for entity: ${entity.metadata.name}. Adding annotations to the database.`);\n\n // Add the mapping to the database based on entity annotations\n let serviceId = entity.metadata.annotations?.[\"pagerduty.com/service-id\"];\n let integrationKey = entity.metadata.annotations?.[\"pagerduty.com/integration-key\"];\n const account = entity.metadata.annotations?.[\"pagerduty.com/account\"];\n\n // Build the entityRef string\n const entityRef = `${entity.kind.toLowerCase()}:${entity.metadata.namespace?.toLowerCase()}/${entity.metadata.name.toLowerCase()}`;\n\n if (serviceId) { \n // Check for mapping override by user\n const serviceMappingOverrideFound = await client.findServiceMappingById(serviceId);\n\n // If service mapping override is not found\n // insert the mapping into the database\n if (!serviceMappingOverrideFound) {\n // if integrationKey annotation does not exist\n // try to retrieve it from PagerDuty\n if (!integrationKey) {\n const foundIntegrationKey = await client.getIntegrationKeyFromServiceId(serviceId, account);\n\n if (foundIntegrationKey) {\n integrationKey = foundIntegrationKey;\n }\n else {\n this.logger.info(`Adding Backstage integration to service: ${serviceId}`);\n integrationKey = await client.createBackstageIntegration(serviceId, account);\n\n this.logger.info(`Backstage integration created for service: ${serviceId}`);\n }\n }\n\n // Insert the mapping into the database\n this.logger.info(`Inserting mapping for entity: ${entityRef} with service id: ${serviceId}, integration key: ${integrationKey} and account: ${account}`);\n await client.insertServiceMapping({\n entityRef,\n serviceId,\n integrationKey,\n account,\n });\n\n // Add the annotations to the entity\n updateAnnotations(entity,\n {\n serviceId,\n integrationKey,\n account\n }\n );\n }\n else {\n this.logger.info(`Service mapping override found for service id: ${serviceId}.`);\n updateAnnotations(entity, {}); // delete annotations because user unmapped the service\n }\n } \n else if (integrationKey) {\n serviceId = await client.getServiceIdFromIntegrationKey(integrationKey, account);\n\n // Check for mapping override by user\n const serviceMappingOverrideFound = await client.findServiceMappingById(serviceId);\n\n // If service mapping override is not found\n // insert the mapping into the database\n if (!serviceMappingOverrideFound) {\n // Insert the mapping into the database\n this.logger.info(`Inserting mapping for entity: ${entityRef} with new service id: ${serviceId}, integration key: ${integrationKey} and account: ${account}`);\n await client.insertServiceMapping({\n entityRef,\n serviceId,\n integrationKey,\n account,\n });\n\n updateAnnotations(entity,\n {\n serviceId,\n integrationKey,\n account\n }\n );\n }\n else {\n this.logger.info(`Service mapping override found for service id: ${serviceId}. Skipping adding to the database.`);\n updateAnnotations(entity, {}); // delete annotations because user unmapped the service\n }\n }\n }\n\n // Process service dependencies\n // if(entity.spec?.dependsOn){\n // // Check if ServiceId exists get service dependencies from PagerDuty \n // const serviceId = entity.metadata.annotations![\"pagerduty.com/service-id\"];\n\n // // Check if service has dependencies configured\n // const dependencyAnnotations: string[] = JSON.parse(JSON.stringify(entity.spec?.dependsOn));\n // this.logger.info(`Existing dependencies for entity: ${entity.metadata.name}. Dependencies: ${JSON.stringify(dependencyAnnotations)}`);\n\n // if (serviceId && dependencyAnnotations?.length > 0) {\n // const entityDependencies: string[] = await buildExistingDependencies(dependencyAnnotations);\n // this.logger.info(`Dependencies from Annotations in ${serviceId}: ${JSON.stringify(entityDependencies)}`);\n\n // // Get dependencies from PagerDuty for the service\n // const account = entity.metadata.annotations?.[\"pagerduty.com/account\"];\n // const dependencies = await client.getServiceDependencies(serviceId, account);\n // const filteredDependencies = dependencies.filter(x => x.dependent_service.id === serviceId);\n // const dependencyIds = filteredDependencies.map(x => x.supporting_service.id);\n\n // this.logger.info(`Filtered dependencies from PagerDuty service ${serviceId}: ${JSON.stringify(filteredDependencies)}`);\n // this.logger.info(`Dependencies from PagerDuty service ${serviceId}: ${JSON.stringify(dependencyIds)}`);\n\n // // compare dependencies with existing dependencies defined on the entity\n // // const newDependencies = dependencies.filter((dependency) => existingDependencies.includes(dependency.dependent_service.id) && !existingDependencies.includes(dependency.dependent_service.id) && dependency.dependent_service.id !== serviceId);\n // const dependenciesToAdd = dependencyIds.filter(x => !entityDependencies.includes(x));\n // this.logger.info(`Dependencies missing in PagerDuty: ${JSON.stringify(dependenciesToAdd)}`);\n // const dependenciesToRemove = entityDependencies.filter(x => !dependencyIds.includes(x));\n // this.logger.info(`Dependencies missing in Backstage: ${JSON.stringify(dependenciesToRemove)}`);\n\n // const newDependencies = [...dependenciesToAdd, ...dependenciesToRemove];\n \n // this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);\n\n // // Update dependencies on PagerDuty\n // if (newDependencies.length > 0){\n // // await client.updateServiceDependencies(serviceId, newDependencies);\n // this.logger.info(`Updated dependencies for service: ${serviceId}. New dependencies: ${JSON.stringify(newDependencies)}`);\n // }\n // }\n // }\n // else {\n // this.logger.info(`No dependencies found for entity: ${entity.metadata.name}`);\n // }\n\n // if(entity.spec?.dependencyOf){\n // this.logger.info(`Processing dependents for entity: ${entity.metadata.name}. Dependents: ${JSON.stringify(entity.spec.dependencyOf)}`);\n // }\n\n } catch (error) {\n this.logger.error(`Error processing entity ${entity.metadata.name}: ${error}`);\n }\n }\n\n return entity;\n }\n}\n\nexport type AnnotationUpdateProps = {\n serviceId?: string;\n integrationKey?: string;\n account?: string;\n};\n\nfunction updateAnnotations(entity: Entity, annotations: AnnotationUpdateProps): void {\n // If serviceId is present, add the annotations to the entity\n if (annotations.serviceId && annotations.serviceId !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/service-id\"] = annotations.serviceId;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/service-id\"];\n }\n\n // If integrationKey is present, add the annotations to the entity\n if (annotations.integrationKey && annotations.integrationKey !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/integration-key\"] = annotations.integrationKey;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/integration-key\"];\n }\n\n // If account is present, add the annotations to the entity\n if (annotations.account && annotations.account !== \"\") {\n entity.metadata.annotations![\"pagerduty.com/account\"] = annotations.account;\n }\n else {\n delete entity.metadata.annotations![\"pagerduty.com/account\"];\n }\n}\n\n// async function buildExistingDependencies(dependencyAnnotations: string[]): Promise<string[]> {\n// const dependencies: string[] = [];\n\n// // Get all service ids matching the dependency annotations\n// await Promise.all(\n// dependencyAnnotations.map(async (dependency) => {\n// const foundServiceId = await client.getServiceIdAnnotationFromCatalog(dependency);\n// console.log(`Found service id for ${dependency}: ${foundServiceId}`);\n\n// if (foundServiceId !== \"\") {\n// dependencies.push(foundServiceId);\n// }\n// })\n// );\n\n// return dependencies;\n\n// }","import { coreServices, createBackendModule } from \"@backstage/backend-plugin-api\";\nimport { catalogProcessingExtensionPoint } from '@backstage/plugin-catalog-node/alpha';\nimport { PagerDutyEntityProcessor } from \"./processor\";\n\n/** @public */\nexport const pagerDutyEntityProcessor = createBackendModule({\n pluginId: 'catalog',\n moduleId: 'pagerduty-entity-processor',\n register(env) {\n env.registerInit({\n deps: {\n logger: coreServices.logger,\n catalog: catalogProcessingExtensionPoint,\n discovery: coreServices.discovery,\n },\n async init({ logger, discovery, catalog }) {\n catalog.addProcessor(new PagerDutyEntityProcessor({ logger, discovery}));\n },\n });\n },\n});\n"],"names":["__publicField","fetch","_a","createBackendModule","coreServices","catalogProcessingExtensionPoint"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pagerduty/backstage-plugin-entity-processor",
3
- "version": "0.3.0-next.4",
3
+ "version": "0.3.0-next.40",
4
4
  "main": "dist/index.cjs.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "license": "Apache-2.0",
@@ -37,7 +37,7 @@
37
37
  "@backstage/catalog-model": "^1.5.0",
38
38
  "@backstage/config": "^1.2.0",
39
39
  "@backstage/plugin-catalog-node": "^1.12.2",
40
- "@pagerduty/backstage-plugin-common": "0.2.1-next.0",
40
+ "@pagerduty/backstage-plugin-common": "0.2.1-next.2",
41
41
  "@rjsf/core": "^5.14.3",
42
42
  "node-fetch": "^2.6.7",
43
43
  "winston": "^3.2.1",