@backstage/plugin-catalog-backend 3.1.1-next.1 → 3.1.2-next.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,16 @@
1
1
  # @backstage/plugin-catalog-backend
2
2
 
3
+ ## 3.1.2-next.2
4
+
5
+ ### Patch Changes
6
+
7
+ - 6493c98: Log before provider-orphaning eviction happens
8
+ - 77516c5: Added new `catalog:validate-entity` action to actions registry.
9
+
10
+ This action can be used to validate entities against the software catalog.
11
+ This is useful for validating `catalog-info.yaml` file changes locally using the
12
+ Backstage MCP server.
13
+
3
14
  ## 3.1.1-next.1
4
15
 
5
16
  ### Patch Changes
@@ -0,0 +1,77 @@
1
+ 'use strict';
2
+
3
+ var yaml = require('yaml');
4
+
5
+ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
6
+
7
+ var yaml__default = /*#__PURE__*/_interopDefaultCompat(yaml);
8
+
9
+ const createValidateEntityAction = (options) => {
10
+ const { actionsRegistry, catalog } = options;
11
+ actionsRegistry.register({
12
+ name: "validate-entity",
13
+ title: "Validate Catalog Entity",
14
+ description: `
15
+ This action can be used to validate catalog-info.yaml file contents meant to be used with the software catalog.
16
+ It checks both that the YAML syntax is correct, and that the entity content is valid according to the catalog's rules.
17
+ `,
18
+ attributes: {
19
+ readOnly: true,
20
+ idempotent: true,
21
+ destructive: false
22
+ },
23
+ schema: {
24
+ input: (z) => z.object({
25
+ entity: z.string().describe("Entity YAML content to validate"),
26
+ location: z.string().url().optional().describe("Location to validate")
27
+ }),
28
+ output: (z) => z.object({
29
+ isValid: z.boolean().describe("Whether the entity is valid"),
30
+ isValidYaml: z.boolean().describe("Whether the YAML syntax is valid"),
31
+ errors: z.array(z.string()).describe("Array of validation errors"),
32
+ entity: z.record(z.any()).optional().describe("Parsed entity object if valid")
33
+ })
34
+ },
35
+ action: async ({ input, credentials }) => {
36
+ const { entity: content, location } = input;
37
+ try {
38
+ let entity;
39
+ try {
40
+ entity = yaml__default.default.parse(content);
41
+ } catch (yamlError) {
42
+ return {
43
+ output: {
44
+ isValid: false,
45
+ isValidYaml: false,
46
+ errors: [`YAML parsing error: ${yamlError.message}`]
47
+ }
48
+ };
49
+ }
50
+ const resp = await catalog.validateEntity(
51
+ entity,
52
+ location ?? "url:https://localhost/entity-validator",
53
+ { credentials }
54
+ );
55
+ return {
56
+ output: {
57
+ isValid: resp.valid,
58
+ isValidYaml: true,
59
+ errors: resp.valid ? [] : resp.errors.map((e) => e.message),
60
+ entity: resp.valid ? entity : void 0
61
+ }
62
+ };
63
+ } catch (error) {
64
+ return {
65
+ output: {
66
+ isValid: false,
67
+ isValidYaml: false,
68
+ errors: [`Validation error: ${error.message}`]
69
+ }
70
+ };
71
+ }
72
+ }
73
+ });
74
+ };
75
+
76
+ exports.createValidateEntityAction = createValidateEntityAction;
77
+ //# sourceMappingURL=createValidateEntityAction.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createValidateEntityAction.cjs.js","sources":["../../src/actions/createValidateEntityAction.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { ActionsRegistryService } from '@backstage/backend-plugin-api/alpha';\nimport yaml from 'yaml';\nimport { CatalogService } from '@backstage/plugin-catalog-node';\n\nexport const createValidateEntityAction = (options: {\n actionsRegistry: ActionsRegistryService;\n catalog: CatalogService;\n}) => {\n const { actionsRegistry, catalog } = options;\n actionsRegistry.register({\n name: 'validate-entity',\n title: 'Validate Catalog Entity',\n description: `\n This action can be used to validate catalog-info.yaml file contents meant to be used with the software catalog.\n It checks both that the YAML syntax is correct, and that the entity content is valid according to the catalog's rules.\n `,\n attributes: {\n readOnly: true,\n idempotent: true,\n destructive: false,\n },\n schema: {\n input: z =>\n z.object({\n entity: z.string().describe('Entity YAML content to validate'),\n location: z\n .string()\n .url()\n .optional()\n .describe('Location to validate'),\n }),\n output: z =>\n z.object({\n isValid: z.boolean().describe('Whether the entity is valid'),\n isValidYaml: z.boolean().describe('Whether the YAML syntax is valid'),\n errors: z.array(z.string()).describe('Array of validation errors'),\n entity: z\n .record(z.any())\n .optional()\n .describe('Parsed entity object if valid'),\n }),\n },\n action: async ({ input, credentials }) => {\n const { entity: content, location } = input;\n try {\n let entity;\n try {\n entity = yaml.parse(content);\n } catch (yamlError) {\n return {\n output: {\n isValid: false,\n isValidYaml: false,\n errors: [`YAML parsing error: ${yamlError.message}`],\n },\n };\n }\n\n const resp = await catalog.validateEntity(\n entity,\n location ?? 'url:https://localhost/entity-validator',\n { credentials },\n );\n\n return {\n output: {\n isValid: resp.valid,\n isValidYaml: true,\n errors: resp.valid ? [] : resp.errors.map(e => e.message),\n entity: resp.valid ? entity : undefined,\n },\n };\n } catch (error) {\n return {\n output: {\n isValid: false,\n isValidYaml: false,\n errors: [`Validation error: ${error.message}`],\n },\n };\n }\n },\n });\n};\n"],"names":["yaml"],"mappings":";;;;;;;;AAmBO,MAAM,0BAAA,GAA6B,CAAC,OAAA,KAGrC;AACJ,EAAA,MAAM,EAAE,eAAA,EAAiB,OAAA,EAAQ,GAAI,OAAA;AACrC,EAAA,eAAA,CAAgB,QAAA,CAAS;AAAA,IACvB,IAAA,EAAM,iBAAA;AAAA,IACN,KAAA,EAAO,yBAAA;AAAA,IACP,WAAA,EAAa;AAAA;AAAA;AAAA,MAAA,CAAA;AAAA,IAIb,UAAA,EAAY;AAAA,MACV,QAAA,EAAU,IAAA;AAAA,MACV,UAAA,EAAY,IAAA;AAAA,MACZ,WAAA,EAAa;AAAA,KACf;AAAA,IACA,MAAA,EAAQ;AAAA,MACN,KAAA,EAAO,CAAA,CAAA,KACL,CAAA,CAAE,MAAA,CAAO;AAAA,QACP,MAAA,EAAQ,CAAA,CAAE,MAAA,EAAO,CAAE,SAAS,iCAAiC,CAAA;AAAA,QAC7D,QAAA,EAAU,EACP,MAAA,EAAO,CACP,KAAI,CACJ,QAAA,EAAS,CACT,QAAA,CAAS,sBAAsB;AAAA,OACnC,CAAA;AAAA,MACH,MAAA,EAAQ,CAAA,CAAA,KACN,CAAA,CAAE,MAAA,CAAO;AAAA,QACP,OAAA,EAAS,CAAA,CAAE,OAAA,EAAQ,CAAE,SAAS,6BAA6B,CAAA;AAAA,QAC3D,WAAA,EAAa,CAAA,CAAE,OAAA,EAAQ,CAAE,SAAS,kCAAkC,CAAA;AAAA,QACpE,MAAA,EAAQ,EAAE,KAAA,CAAM,CAAA,CAAE,QAAQ,CAAA,CAAE,SAAS,4BAA4B,CAAA;AAAA,QACjE,MAAA,EAAQ,CAAA,CACL,MAAA,CAAO,CAAA,CAAE,GAAA,EAAK,CAAA,CACd,QAAA,EAAS,CACT,QAAA,CAAS,+BAA+B;AAAA,OAC5C;AAAA,KACL;AAAA,IACA,MAAA,EAAQ,OAAO,EAAE,KAAA,EAAO,aAAY,KAAM;AACxC,MAAA,MAAM,EAAE,MAAA,EAAQ,OAAA,EAAS,QAAA,EAAS,GAAI,KAAA;AACtC,MAAA,IAAI;AACF,QAAA,IAAI,MAAA;AACJ,QAAA,IAAI;AACF,UAAA,MAAA,GAASA,qBAAA,CAAK,MAAM,OAAO,CAAA;AAAA,QAC7B,SAAS,SAAA,EAAW;AAClB,UAAA,OAAO;AAAA,YACL,MAAA,EAAQ;AAAA,cACN,OAAA,EAAS,KAAA;AAAA,cACT,WAAA,EAAa,KAAA;AAAA,cACb,MAAA,EAAQ,CAAC,CAAA,oBAAA,EAAuB,SAAA,CAAU,OAAO,CAAA,CAAE;AAAA;AACrD,WACF;AAAA,QACF;AAEA,QAAA,MAAM,IAAA,GAAO,MAAM,OAAA,CAAQ,cAAA;AAAA,UACzB,MAAA;AAAA,UACA,QAAA,IAAY,wCAAA;AAAA,UACZ,EAAE,WAAA;AAAY,SAChB;AAEA,QAAA,OAAO;AAAA,UACL,MAAA,EAAQ;AAAA,YACN,SAAS,IAAA,CAAK,KAAA;AAAA,YACd,WAAA,EAAa,IAAA;AAAA,YACb,MAAA,EAAQ,IAAA,CAAK,KAAA,GAAQ,EAAC,GAAI,KAAK,MAAA,CAAO,GAAA,CAAI,CAAA,CAAA,KAAK,CAAA,CAAE,OAAO,CAAA;AAAA,YACxD,MAAA,EAAQ,IAAA,CAAK,KAAA,GAAQ,MAAA,GAAS,KAAA;AAAA;AAChC,SACF;AAAA,MACF,SAAS,KAAA,EAAO;AACd,QAAA,OAAO;AAAA,UACL,MAAA,EAAQ;AAAA,YACN,OAAA,EAAS,KAAA;AAAA,YACT,WAAA,EAAa,KAAA;AAAA,YACb,MAAA,EAAQ,CAAC,CAAA,kBAAA,EAAqB,KAAA,CAAM,OAAO,CAAA,CAAE;AAAA;AAC/C,SACF;AAAA,MACF;AAAA,IACF;AAAA,GACD,CAAA;AACH;;;;"}
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ var createGetCatalogEntityAction = require('./createGetCatalogEntityAction.cjs.js');
4
+ var createValidateEntityAction = require('./createValidateEntityAction.cjs.js');
5
+
6
+ const createCatalogActions = (options) => {
7
+ createGetCatalogEntityAction.createGetCatalogEntityAction(options);
8
+ createValidateEntityAction.createValidateEntityAction(options);
9
+ };
10
+
11
+ exports.createCatalogActions = createCatalogActions;
12
+ //# sourceMappingURL=index.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs.js","sources":["../../src/actions/index.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { ActionsRegistryService } from '@backstage/backend-plugin-api/alpha';\nimport { CatalogService } from '@backstage/plugin-catalog-node';\nimport { createGetCatalogEntityAction } from './createGetCatalogEntityAction.ts';\nimport { createValidateEntityAction } from './createValidateEntityAction.ts';\n\nexport const createCatalogActions = (options: {\n actionsRegistry: ActionsRegistryService;\n catalog: CatalogService;\n}) => {\n createGetCatalogEntityAction(options);\n createValidateEntityAction(options);\n};\n"],"names":["createGetCatalogEntityAction","createValidateEntityAction"],"mappings":";;;;;AAoBO,MAAM,oBAAA,GAAuB,CAAC,OAAA,KAG/B;AACJ,EAAAA,yDAAA,CAA6B,OAAO,CAAA;AACpC,EAAAC,qDAAA,CAA2B,OAAO,CAAA;AACpC;;;;"}
@@ -2,15 +2,26 @@
2
2
 
3
3
  async function getOrphanedEntityProviderNames({
4
4
  db,
5
- providers
5
+ providers,
6
+ logger
6
7
  }) {
7
8
  const dbProviderNames = await db.transaction(
8
9
  async (tx) => db.listReferenceSourceKeys(tx)
9
10
  );
10
11
  const providerNames = providers.map((p) => p.getProviderName());
11
- return dbProviderNames.filter(
12
+ const orphaned = dbProviderNames.filter(
12
13
  (dbProviderName) => !providerNames.includes(dbProviderName)
13
14
  );
15
+ if (orphaned.length) {
16
+ const dbProviderNamesString = dbProviderNames.map((p) => `'${p}'`).join(", ");
17
+ const providerNamesString = providerNames.map((p) => `'${p}'`).join(", ");
18
+ const orphanedString = orphaned.map((p) => `'${p}'`).join(", ");
19
+ logger.warn(`Found ${orphaned.length} orphaned entity provider(s)`);
20
+ logger.warn(`Database contained providers: ${dbProviderNamesString}`);
21
+ logger.warn(`Installed providers were: ${providerNamesString}`);
22
+ logger.warn(`Orphaned providers were thus: ${orphanedString}`);
23
+ }
24
+ return orphaned;
14
25
  }
15
26
  async function removeEntitiesForProvider({
16
27
  db,
@@ -44,4 +55,5 @@ async function evictEntitiesFromOrphanedProviders(options) {
44
55
  }
45
56
 
46
57
  exports.evictEntitiesFromOrphanedProviders = evictEntitiesFromOrphanedProviders;
58
+ exports.getOrphanedEntityProviderNames = getOrphanedEntityProviderNames;
47
59
  //# sourceMappingURL=evictEntitiesFromOrphanedProviders.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"evictEntitiesFromOrphanedProviders.cjs.js","sources":["../../src/processing/evictEntitiesFromOrphanedProviders.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EntityProvider } from '@backstage/plugin-catalog-node';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { ProviderDatabase } from '../database/types';\n\nasync function getOrphanedEntityProviderNames({\n db,\n providers,\n}: {\n db: ProviderDatabase;\n providers: EntityProvider[];\n}): Promise<string[]> {\n const dbProviderNames = await db.transaction(async tx =>\n db.listReferenceSourceKeys(tx),\n );\n\n const providerNames = providers.map(p => p.getProviderName());\n\n return dbProviderNames.filter(\n dbProviderName => !providerNames.includes(dbProviderName),\n );\n}\n\nasync function removeEntitiesForProvider({\n db,\n providerName,\n logger,\n}: {\n db: ProviderDatabase;\n providerName: string;\n logger: LoggerService;\n}) {\n try {\n await db.transaction(async tx => {\n await db.replaceUnprocessedEntities(tx, {\n sourceKey: providerName,\n type: 'full',\n items: [],\n });\n });\n logger.info(`Removed entities for orphaned provider ${providerName}`);\n } catch (e) {\n logger.error(\n `Failed to remove entities for orphaned provider ${providerName}`,\n e,\n );\n }\n}\n\nexport async function evictEntitiesFromOrphanedProviders(options: {\n db: ProviderDatabase;\n providers: EntityProvider[];\n logger: LoggerService;\n}) {\n for (const providerName of await getOrphanedEntityProviderNames(options)) {\n await removeEntitiesForProvider({\n db: options.db,\n providerName,\n logger: options.logger,\n });\n }\n}\n"],"names":[],"mappings":";;AAoBA,eAAe,8BAAA,CAA+B;AAAA,EAC5C,EAAA;AAAA,EACA;AACF,CAAA,EAGsB;AACpB,EAAA,MAAM,eAAA,GAAkB,MAAM,EAAA,CAAG,WAAA;AAAA,IAAY,OAAM,EAAA,KACjD,EAAA,CAAG,uBAAA,CAAwB,EAAE;AAAA,GAC/B;AAEA,EAAA,MAAM,gBAAgB,SAAA,CAAU,GAAA,CAAI,CAAA,CAAA,KAAK,CAAA,CAAE,iBAAiB,CAAA;AAE5D,EAAA,OAAO,eAAA,CAAgB,MAAA;AAAA,IACrB,CAAA,cAAA,KAAkB,CAAC,aAAA,CAAc,QAAA,CAAS,cAAc;AAAA,GAC1D;AACF;AAEA,eAAe,yBAAA,CAA0B;AAAA,EACvC,EAAA;AAAA,EACA,YAAA;AAAA,EACA;AACF,CAAA,EAIG;AACD,EAAA,IAAI;AACF,IAAA,MAAM,EAAA,CAAG,WAAA,CAAY,OAAM,EAAA,KAAM;AAC/B,MAAA,MAAM,EAAA,CAAG,2BAA2B,EAAA,EAAI;AAAA,QACtC,SAAA,EAAW,YAAA;AAAA,QACX,IAAA,EAAM,MAAA;AAAA,QACN,OAAO;AAAC,OACT,CAAA;AAAA,IACH,CAAC,CAAA;AACD,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,uCAAA,EAA0C,YAAY,CAAA,CAAE,CAAA;AAAA,EACtE,SAAS,CAAA,EAAG;AACV,IAAA,MAAA,CAAO,KAAA;AAAA,MACL,mDAAmD,YAAY,CAAA,CAAA;AAAA,MAC/D;AAAA,KACF;AAAA,EACF;AACF;AAEA,eAAsB,mCAAmC,OAAA,EAItD;AACD,EAAA,KAAA,MAAW,YAAA,IAAgB,MAAM,8BAAA,CAA+B,OAAO,CAAA,EAAG;AACxE,IAAA,MAAM,yBAAA,CAA0B;AAAA,MAC9B,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,YAAA;AAAA,MACA,QAAQ,OAAA,CAAQ;AAAA,KACjB,CAAA;AAAA,EACH;AACF;;;;"}
1
+ {"version":3,"file":"evictEntitiesFromOrphanedProviders.cjs.js","sources":["../../src/processing/evictEntitiesFromOrphanedProviders.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EntityProvider } from '@backstage/plugin-catalog-node';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { ProviderDatabase } from '../database/types';\n\nexport async function getOrphanedEntityProviderNames({\n db,\n providers,\n logger,\n}: {\n db: ProviderDatabase;\n providers: EntityProvider[];\n logger: LoggerService;\n}): Promise<string[]> {\n const dbProviderNames = await db.transaction(async tx =>\n db.listReferenceSourceKeys(tx),\n );\n\n const providerNames = providers.map(p => p.getProviderName());\n\n const orphaned = dbProviderNames.filter(\n dbProviderName => !providerNames.includes(dbProviderName),\n );\n\n if (orphaned.length) {\n const dbProviderNamesString = dbProviderNames.map(p => `'${p}'`).join(', ');\n const providerNamesString = providerNames.map(p => `'${p}'`).join(', ');\n const orphanedString = orphaned.map(p => `'${p}'`).join(', ');\n logger.warn(`Found ${orphaned.length} orphaned entity provider(s)`);\n logger.warn(`Database contained providers: ${dbProviderNamesString}`);\n logger.warn(`Installed providers were: ${providerNamesString}`);\n logger.warn(`Orphaned providers were thus: ${orphanedString}`);\n }\n\n return orphaned;\n}\n\nasync function removeEntitiesForProvider({\n db,\n providerName,\n logger,\n}: {\n db: ProviderDatabase;\n providerName: string;\n logger: LoggerService;\n}) {\n try {\n await db.transaction(async tx => {\n await db.replaceUnprocessedEntities(tx, {\n sourceKey: providerName,\n type: 'full',\n items: [],\n });\n });\n logger.info(`Removed entities for orphaned provider ${providerName}`);\n } catch (e) {\n logger.error(\n `Failed to remove entities for orphaned provider ${providerName}`,\n e,\n );\n }\n}\n\nexport async function evictEntitiesFromOrphanedProviders(options: {\n db: ProviderDatabase;\n providers: EntityProvider[];\n logger: LoggerService;\n}) {\n for (const providerName of await getOrphanedEntityProviderNames(options)) {\n await removeEntitiesForProvider({\n db: options.db,\n providerName,\n logger: options.logger,\n });\n }\n}\n"],"names":[],"mappings":";;AAoBA,eAAsB,8BAAA,CAA+B;AAAA,EACnD,EAAA;AAAA,EACA,SAAA;AAAA,EACA;AACF,CAAA,EAIsB;AACpB,EAAA,MAAM,eAAA,GAAkB,MAAM,EAAA,CAAG,WAAA;AAAA,IAAY,OAAM,EAAA,KACjD,EAAA,CAAG,uBAAA,CAAwB,EAAE;AAAA,GAC/B;AAEA,EAAA,MAAM,gBAAgB,SAAA,CAAU,GAAA,CAAI,CAAA,CAAA,KAAK,CAAA,CAAE,iBAAiB,CAAA;AAE5D,EAAA,MAAM,WAAW,eAAA,CAAgB,MAAA;AAAA,IAC/B,CAAA,cAAA,KAAkB,CAAC,aAAA,CAAc,QAAA,CAAS,cAAc;AAAA,GAC1D;AAEA,EAAA,IAAI,SAAS,MAAA,EAAQ;AACnB,IAAA,MAAM,qBAAA,GAAwB,gBAAgB,GAAA,CAAI,CAAA,CAAA,KAAK,IAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAC1E,IAAA,MAAM,mBAAA,GAAsB,cAAc,GAAA,CAAI,CAAA,CAAA,KAAK,IAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AACtE,IAAA,MAAM,cAAA,GAAiB,SAAS,GAAA,CAAI,CAAA,CAAA,KAAK,IAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAC5D,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,MAAA,EAAS,QAAA,CAAS,MAAM,CAAA,4BAAA,CAA8B,CAAA;AAClE,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,8BAAA,EAAiC,qBAAqB,CAAA,CAAE,CAAA;AACpE,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,0BAAA,EAA6B,mBAAmB,CAAA,CAAE,CAAA;AAC9D,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,8BAAA,EAAiC,cAAc,CAAA,CAAE,CAAA;AAAA,EAC/D;AAEA,EAAA,OAAO,QAAA;AACT;AAEA,eAAe,yBAAA,CAA0B;AAAA,EACvC,EAAA;AAAA,EACA,YAAA;AAAA,EACA;AACF,CAAA,EAIG;AACD,EAAA,IAAI;AACF,IAAA,MAAM,EAAA,CAAG,WAAA,CAAY,OAAM,EAAA,KAAM;AAC/B,MAAA,MAAM,EAAA,CAAG,2BAA2B,EAAA,EAAI;AAAA,QACtC,SAAA,EAAW,YAAA;AAAA,QACX,IAAA,EAAM,MAAA;AAAA,QACN,OAAO;AAAC,OACT,CAAA;AAAA,IACH,CAAC,CAAA;AACD,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,uCAAA,EAA0C,YAAY,CAAA,CAAE,CAAA;AAAA,EACtE,SAAS,CAAA,EAAG;AACV,IAAA,MAAA,CAAO,KAAA;AAAA,MACL,mDAAmD,YAAY,CAAA,CAAA;AAAA,MAC/D;AAAA,KACF;AAAA,EACF;AACF;AAEA,eAAsB,mCAAmC,OAAA,EAItD;AACD,EAAA,KAAA,MAAW,YAAA,IAAgB,MAAM,8BAAA,CAA+B,OAAO,CAAA,EAAG;AACxE,IAAA,MAAM,yBAAA,CAA0B;AAAA,MAC9B,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,YAAA;AAAA,MACA,QAAQ,OAAA,CAAQ;AAAA,KACjB,CAAA;AAAA,EACH;AACF;;;;;"}
@@ -8,7 +8,7 @@ var pluginEventsNode = require('@backstage/plugin-events-node');
8
8
  var lodash = require('lodash');
9
9
  var CatalogBuilder = require('./CatalogBuilder.cjs.js');
10
10
  var alpha$1 = require('@backstage/backend-plugin-api/alpha');
11
- var createGetCatalogEntityAction = require('../actions/createGetCatalogEntityAction.cjs.js');
11
+ var index = require('../actions/index.cjs.js');
12
12
 
13
13
  class CatalogLocationsExtensionPointImpl {
14
14
  #locationTypes;
@@ -216,7 +216,7 @@ const catalogPlugin = backendPluginApi.createBackendPlugin({
216
216
  lifecycle.addShutdownHook(() => processingEngine.stop());
217
217
  }
218
218
  httpRouter.use(router);
219
- createGetCatalogEntityAction.createGetCatalogEntityAction({
219
+ index.createCatalogActions({
220
220
  catalog,
221
221
  actionsRegistry
222
222
  });
@@ -1 +1 @@
1
- {"version":3,"file":"CatalogPlugin.cjs.js","sources":["../../src/service/CatalogPlugin.ts"],"sourcesContent":["/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n coreServices,\n createBackendPlugin,\n} from '@backstage/backend-plugin-api';\nimport { Entity, Validators } from '@backstage/catalog-model';\nimport { ForwardedError } from '@backstage/errors';\nimport {\n CatalogProcessor,\n CatalogProcessorParser,\n catalogServiceRef,\n EntityProvider,\n LocationAnalyzer,\n PlaceholderResolver,\n ScmLocationAnalyzer,\n} from '@backstage/plugin-catalog-node';\nimport {\n catalogAnalysisExtensionPoint,\n CatalogLocationsExtensionPoint,\n catalogLocationsExtensionPoint,\n CatalogModelExtensionPoint,\n catalogModelExtensionPoint,\n CatalogPermissionExtensionPoint,\n catalogPermissionExtensionPoint,\n CatalogPermissionRuleInput,\n CatalogProcessingExtensionPoint,\n catalogProcessingExtensionPoint,\n} from '@backstage/plugin-catalog-node/alpha';\nimport { eventsServiceRef } from '@backstage/plugin-events-node';\nimport { Permission } from '@backstage/plugin-permission-common';\nimport { merge } from 'lodash';\nimport { CatalogBuilder } from './CatalogBuilder';\nimport { actionsRegistryServiceRef } from '@backstage/backend-plugin-api/alpha';\nimport { createGetCatalogEntityAction } from '../actions/createGetCatalogEntityAction';\n\nclass CatalogLocationsExtensionPointImpl\n implements CatalogLocationsExtensionPoint\n{\n #locationTypes: string[] | undefined;\n\n setAllowedLocationTypes(locationTypes: Array<string>) {\n this.#locationTypes = locationTypes;\n }\n\n get allowedLocationTypes() {\n return this.#locationTypes;\n }\n}\n\nclass CatalogProcessingExtensionPointImpl\n implements CatalogProcessingExtensionPoint\n{\n #processors = new Array<CatalogProcessor>();\n #entityProviders = new Array<EntityProvider>();\n #placeholderResolvers: Record<string, PlaceholderResolver> = {};\n #onProcessingErrorHandler?: (event: {\n unprocessedEntity: Entity;\n errors: Error[];\n }) => Promise<void> | void;\n\n addProcessor(\n ...processors: Array<CatalogProcessor | Array<CatalogProcessor>>\n ): void {\n this.#processors.push(...processors.flat());\n }\n\n addEntityProvider(\n ...providers: Array<EntityProvider | Array<EntityProvider>>\n ): void {\n this.#entityProviders.push(...providers.flat());\n }\n\n addPlaceholderResolver(key: string, resolver: PlaceholderResolver) {\n if (key in this.#placeholderResolvers)\n throw new Error(\n `A placeholder resolver for '${key}' has already been set up, please check your config.`,\n );\n this.#placeholderResolvers[key] = resolver;\n }\n\n setOnProcessingErrorHandler(\n handler: (event: {\n unprocessedEntity: Entity;\n errors: Error[];\n }) => Promise<void> | void,\n ) {\n this.#onProcessingErrorHandler = handler;\n }\n\n get processors() {\n return this.#processors;\n }\n\n get entityProviders() {\n return this.#entityProviders;\n }\n\n get placeholderResolvers() {\n return this.#placeholderResolvers;\n }\n\n get onProcessingErrorHandler() {\n return this.#onProcessingErrorHandler;\n }\n}\n\nclass CatalogPermissionExtensionPointImpl\n implements CatalogPermissionExtensionPoint\n{\n #permissions = new Array<Permission>();\n #permissionRules = new Array<CatalogPermissionRuleInput>();\n\n addPermissions(...permission: Array<Permission | Array<Permission>>): void {\n this.#permissions.push(...permission.flat());\n }\n\n addPermissionRules(\n ...rules: Array<\n CatalogPermissionRuleInput | Array<CatalogPermissionRuleInput>\n >\n ): void {\n this.#permissionRules.push(...rules.flat());\n }\n\n get permissions() {\n return this.#permissions;\n }\n\n get permissionRules() {\n return this.#permissionRules;\n }\n}\n\nclass CatalogModelExtensionPointImpl implements CatalogModelExtensionPoint {\n #fieldValidators: Partial<Validators> = {};\n\n setFieldValidators(validators: Partial<Validators>): void {\n merge(this.#fieldValidators, validators);\n }\n\n get fieldValidators() {\n return this.#fieldValidators;\n }\n\n #entityDataParser?: CatalogProcessorParser;\n\n setEntityDataParser(parser: CatalogProcessorParser): void {\n if (this.#entityDataParser) {\n throw new Error(\n 'Attempted to install second EntityDataParser. Only one can be set.',\n );\n }\n this.#entityDataParser = parser;\n }\n\n get entityDataParser() {\n return this.#entityDataParser;\n }\n}\n\n/**\n * Catalog plugin\n * @public\n */\nexport const catalogPlugin = createBackendPlugin({\n pluginId: 'catalog',\n register(env) {\n const processingExtensions = new CatalogProcessingExtensionPointImpl();\n // plugins depending on this API will be initialized before this plugins init method is executed.\n env.registerExtensionPoint(\n catalogProcessingExtensionPoint,\n processingExtensions,\n );\n\n let locationAnalyzerFactory:\n | ((options: {\n scmLocationAnalyzers: ScmLocationAnalyzer[];\n }) => Promise<{ locationAnalyzer: LocationAnalyzer }>)\n | undefined = undefined;\n const scmLocationAnalyzers = new Array<ScmLocationAnalyzer>();\n env.registerExtensionPoint(catalogAnalysisExtensionPoint, {\n setLocationAnalyzer(analyzerOrFactory) {\n if (locationAnalyzerFactory) {\n throw new Error('LocationAnalyzer has already been set');\n }\n if (typeof analyzerOrFactory === 'function') {\n locationAnalyzerFactory = analyzerOrFactory;\n } else {\n locationAnalyzerFactory = async () => ({\n locationAnalyzer: analyzerOrFactory,\n });\n }\n },\n addScmLocationAnalyzer(analyzer: ScmLocationAnalyzer) {\n scmLocationAnalyzers.push(analyzer);\n },\n });\n\n const permissionExtensions = new CatalogPermissionExtensionPointImpl();\n env.registerExtensionPoint(\n catalogPermissionExtensionPoint,\n permissionExtensions,\n );\n\n const modelExtensions = new CatalogModelExtensionPointImpl();\n env.registerExtensionPoint(catalogModelExtensionPoint, modelExtensions);\n\n const locationTypeExtensions = new CatalogLocationsExtensionPointImpl();\n env.registerExtensionPoint(\n catalogLocationsExtensionPoint,\n locationTypeExtensions,\n );\n\n env.registerInit({\n deps: {\n logger: coreServices.logger,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n permissions: coreServices.permissions,\n permissionsRegistry: coreServices.permissionsRegistry,\n database: coreServices.database,\n httpRouter: coreServices.httpRouter,\n lifecycle: coreServices.rootLifecycle,\n scheduler: coreServices.scheduler,\n auth: coreServices.auth,\n httpAuth: coreServices.httpAuth,\n auditor: coreServices.auditor,\n events: eventsServiceRef,\n catalog: catalogServiceRef,\n actionsRegistry: actionsRegistryServiceRef,\n },\n async init({\n logger,\n config,\n reader,\n database,\n permissions,\n permissionsRegistry,\n httpRouter,\n lifecycle,\n scheduler,\n auth,\n httpAuth,\n catalog,\n actionsRegistry,\n auditor,\n events,\n }) {\n const builder = await CatalogBuilder.create({\n config,\n reader,\n permissions,\n permissionsRegistry,\n database,\n scheduler,\n logger,\n auth,\n httpAuth,\n auditor,\n events,\n });\n\n if (processingExtensions.onProcessingErrorHandler) {\n builder.subscribe({\n onProcessingError: processingExtensions.onProcessingErrorHandler,\n });\n }\n builder.addProcessor(...processingExtensions.processors);\n builder.addEntityProvider(...processingExtensions.entityProviders);\n\n if (modelExtensions.entityDataParser) {\n builder.setEntityDataParser(modelExtensions.entityDataParser);\n }\n\n Object.entries(processingExtensions.placeholderResolvers).forEach(\n ([key, resolver]) => builder.setPlaceholderResolver(key, resolver),\n );\n if (locationAnalyzerFactory) {\n const { locationAnalyzer } = await locationAnalyzerFactory({\n scmLocationAnalyzers,\n }).catch(e => {\n throw new ForwardedError('Failed to create LocationAnalyzer', e);\n });\n builder.setLocationAnalyzer(locationAnalyzer);\n } else {\n builder.addLocationAnalyzers(...scmLocationAnalyzers);\n }\n builder.addPermissions(...permissionExtensions.permissions);\n builder.addPermissionRules(...permissionExtensions.permissionRules);\n builder.setFieldFormatValidators(modelExtensions.fieldValidators);\n\n if (locationTypeExtensions.allowedLocationTypes) {\n builder.setAllowedLocationTypes(\n locationTypeExtensions.allowedLocationTypes,\n );\n }\n\n const { processingEngine, router } = await builder.build();\n\n if (config.getOptional('catalog.processingInterval') ?? true) {\n lifecycle.addStartupHook(async () => {\n await processingEngine.start();\n });\n lifecycle.addShutdownHook(() => processingEngine.stop());\n }\n\n httpRouter.use(router);\n\n createGetCatalogEntityAction({\n catalog,\n actionsRegistry,\n });\n },\n });\n },\n});\n"],"names":["merge","createBackendPlugin","catalogProcessingExtensionPoint","catalogAnalysisExtensionPoint","catalogPermissionExtensionPoint","catalogModelExtensionPoint","catalogLocationsExtensionPoint","coreServices","eventsServiceRef","catalogServiceRef","actionsRegistryServiceRef","CatalogBuilder","ForwardedError","createGetCatalogEntityAction"],"mappings":";;;;;;;;;;;;AAiDA,MAAM,kCAAA,CAEN;AAAA,EACE,cAAA;AAAA,EAEA,wBAAwB,aAAA,EAA8B;AACpD,IAAA,IAAA,CAAK,cAAA,GAAiB,aAAA;AAAA,EACxB;AAAA,EAEA,IAAI,oBAAA,GAAuB;AACzB,IAAA,OAAO,IAAA,CAAK,cAAA;AAAA,EACd;AACF;AAEA,MAAM,mCAAA,CAEN;AAAA,EACE,WAAA,GAAc,IAAI,KAAA,EAAwB;AAAA,EAC1C,gBAAA,GAAmB,IAAI,KAAA,EAAsB;AAAA,EAC7C,wBAA6D,EAAC;AAAA,EAC9D,yBAAA;AAAA,EAKA,gBACK,UAAA,EACG;AACN,IAAA,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,GAAG,UAAA,CAAW,MAAM,CAAA;AAAA,EAC5C;AAAA,EAEA,qBACK,SAAA,EACG;AACN,IAAA,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,GAAG,SAAA,CAAU,MAAM,CAAA;AAAA,EAChD;AAAA,EAEA,sBAAA,CAAuB,KAAa,QAAA,EAA+B;AACjE,IAAA,IAAI,OAAO,IAAA,CAAK,qBAAA;AACd,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,+BAA+B,GAAG,CAAA,oDAAA;AAAA,OACpC;AACF,IAAA,IAAA,CAAK,qBAAA,CAAsB,GAAG,CAAA,GAAI,QAAA;AAAA,EACpC;AAAA,EAEA,4BACE,OAAA,EAIA;AACA,IAAA,IAAA,CAAK,yBAAA,GAA4B,OAAA;AAAA,EACnC;AAAA,EAEA,IAAI,UAAA,GAAa;AACf,IAAA,OAAO,IAAA,CAAK,WAAA;AAAA,EACd;AAAA,EAEA,IAAI,eAAA,GAAkB;AACpB,IAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,EACd;AAAA,EAEA,IAAI,oBAAA,GAAuB;AACzB,IAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,EACd;AAAA,EAEA,IAAI,wBAAA,GAA2B;AAC7B,IAAA,OAAO,IAAA,CAAK,yBAAA;AAAA,EACd;AACF;AAEA,MAAM,mCAAA,CAEN;AAAA,EACE,YAAA,GAAe,IAAI,KAAA,EAAkB;AAAA,EACrC,gBAAA,GAAmB,IAAI,KAAA,EAAkC;AAAA,EAEzD,kBAAkB,UAAA,EAAyD;AACzE,IAAA,IAAA,CAAK,YAAA,CAAa,IAAA,CAAK,GAAG,UAAA,CAAW,MAAM,CAAA;AAAA,EAC7C;AAAA,EAEA,sBACK,KAAA,EAGG;AACN,IAAA,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,GAAG,KAAA,CAAM,MAAM,CAAA;AAAA,EAC5C;AAAA,EAEA,IAAI,WAAA,GAAc;AAChB,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA,EAEA,IAAI,eAAA,GAAkB;AACpB,IAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,EACd;AACF;AAEA,MAAM,8BAAA,CAAqE;AAAA,EACzE,mBAAwC,EAAC;AAAA,EAEzC,mBAAmB,UAAA,EAAuC;AACxD,IAAAA,YAAA,CAAM,IAAA,CAAK,kBAAkB,UAAU,CAAA;AAAA,EACzC;AAAA,EAEA,IAAI,eAAA,GAAkB;AACpB,IAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,EACd;AAAA,EAEA,iBAAA;AAAA,EAEA,oBAAoB,MAAA,EAAsC;AACxD,IAAA,IAAI,KAAK,iBAAA,EAAmB;AAC1B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AACA,IAAA,IAAA,CAAK,iBAAA,GAAoB,MAAA;AAAA,EAC3B;AAAA,EAEA,IAAI,gBAAA,GAAmB;AACrB,IAAA,OAAO,IAAA,CAAK,iBAAA;AAAA,EACd;AACF;AAMO,MAAM,gBAAgBC,oCAAA,CAAoB;AAAA,EAC/C,QAAA,EAAU,SAAA;AAAA,EACV,SAAS,GAAA,EAAK;AACZ,IAAA,MAAM,oBAAA,GAAuB,IAAI,mCAAA,EAAoC;AAErE,IAAA,GAAA,CAAI,sBAAA;AAAA,MACFC,qCAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,IAAI,uBAAA,GAIY,MAAA;AAChB,IAAA,MAAM,oBAAA,GAAuB,IAAI,KAAA,EAA2B;AAC5D,IAAA,GAAA,CAAI,uBAAuBC,mCAAA,EAA+B;AAAA,MACxD,oBAAoB,iBAAA,EAAmB;AACrC,QAAA,IAAI,uBAAA,EAAyB;AAC3B,UAAA,MAAM,IAAI,MAAM,uCAAuC,CAAA;AAAA,QACzD;AACA,QAAA,IAAI,OAAO,sBAAsB,UAAA,EAAY;AAC3C,UAAA,uBAAA,GAA0B,iBAAA;AAAA,QAC5B,CAAA,MAAO;AACL,UAAA,uBAAA,GAA0B,aAAa;AAAA,YACrC,gBAAA,EAAkB;AAAA,WACpB,CAAA;AAAA,QACF;AAAA,MACF,CAAA;AAAA,MACA,uBAAuB,QAAA,EAA+B;AACpD,QAAA,oBAAA,CAAqB,KAAK,QAAQ,CAAA;AAAA,MACpC;AAAA,KACD,CAAA;AAED,IAAA,MAAM,oBAAA,GAAuB,IAAI,mCAAA,EAAoC;AACrE,IAAA,GAAA,CAAI,sBAAA;AAAA,MACFC,qCAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,MAAM,eAAA,GAAkB,IAAI,8BAAA,EAA+B;AAC3D,IAAA,GAAA,CAAI,sBAAA,CAAuBC,kCAA4B,eAAe,CAAA;AAEtE,IAAA,MAAM,sBAAA,GAAyB,IAAI,kCAAA,EAAmC;AACtE,IAAA,GAAA,CAAI,sBAAA;AAAA,MACFC,oCAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,GAAA,CAAI,YAAA,CAAa;AAAA,MACf,IAAA,EAAM;AAAA,QACJ,QAAQC,6BAAA,CAAa,MAAA;AAAA,QACrB,QAAQA,6BAAA,CAAa,UAAA;AAAA,QACrB,QAAQA,6BAAA,CAAa,SAAA;AAAA,QACrB,aAAaA,6BAAA,CAAa,WAAA;AAAA,QAC1B,qBAAqBA,6BAAA,CAAa,mBAAA;AAAA,QAClC,UAAUA,6BAAA,CAAa,QAAA;AAAA,QACvB,YAAYA,6BAAA,CAAa,UAAA;AAAA,QACzB,WAAWA,6BAAA,CAAa,aAAA;AAAA,QACxB,WAAWA,6BAAA,CAAa,SAAA;AAAA,QACxB,MAAMA,6BAAA,CAAa,IAAA;AAAA,QACnB,UAAUA,6BAAA,CAAa,QAAA;AAAA,QACvB,SAASA,6BAAA,CAAa,OAAA;AAAA,QACtB,MAAA,EAAQC,iCAAA;AAAA,QACR,OAAA,EAASC,mCAAA;AAAA,QACT,eAAA,EAAiBC;AAAA,OACnB;AAAA,MACA,MAAM,IAAA,CAAK;AAAA,QACT,MAAA;AAAA,QACA,MAAA;AAAA,QACA,MAAA;AAAA,QACA,QAAA;AAAA,QACA,WAAA;AAAA,QACA,mBAAA;AAAA,QACA,UAAA;AAAA,QACA,SAAA;AAAA,QACA,SAAA;AAAA,QACA,IAAA;AAAA,QACA,QAAA;AAAA,QACA,OAAA;AAAA,QACA,eAAA;AAAA,QACA,OAAA;AAAA,QACA;AAAA,OACF,EAAG;AACD,QAAA,MAAM,OAAA,GAAU,MAAMC,6BAAA,CAAe,MAAA,CAAO;AAAA,UAC1C,MAAA;AAAA,UACA,MAAA;AAAA,UACA,WAAA;AAAA,UACA,mBAAA;AAAA,UACA,QAAA;AAAA,UACA,SAAA;AAAA,UACA,MAAA;AAAA,UACA,IAAA;AAAA,UACA,QAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AAED,QAAA,IAAI,qBAAqB,wBAAA,EAA0B;AACjD,UAAA,OAAA,CAAQ,SAAA,CAAU;AAAA,YAChB,mBAAmB,oBAAA,CAAqB;AAAA,WACzC,CAAA;AAAA,QACH;AACA,QAAA,OAAA,CAAQ,YAAA,CAAa,GAAG,oBAAA,CAAqB,UAAU,CAAA;AACvD,QAAA,OAAA,CAAQ,iBAAA,CAAkB,GAAG,oBAAA,CAAqB,eAAe,CAAA;AAEjE,QAAA,IAAI,gBAAgB,gBAAA,EAAkB;AACpC,UAAA,OAAA,CAAQ,mBAAA,CAAoB,gBAAgB,gBAAgB,CAAA;AAAA,QAC9D;AAEA,QAAA,MAAA,CAAO,OAAA,CAAQ,oBAAA,CAAqB,oBAAoB,CAAA,CAAE,OAAA;AAAA,UACxD,CAAC,CAAC,GAAA,EAAK,QAAQ,MAAM,OAAA,CAAQ,sBAAA,CAAuB,KAAK,QAAQ;AAAA,SACnE;AACA,QAAA,IAAI,uBAAA,EAAyB;AAC3B,UAAA,MAAM,EAAE,gBAAA,EAAiB,GAAI,MAAM,uBAAA,CAAwB;AAAA,YACzD;AAAA,WACD,CAAA,CAAE,KAAA,CAAM,CAAA,CAAA,KAAK;AACZ,YAAA,MAAM,IAAIC,qBAAA,CAAe,mCAAA,EAAqC,CAAC,CAAA;AAAA,UACjE,CAAC,CAAA;AACD,UAAA,OAAA,CAAQ,oBAAoB,gBAAgB,CAAA;AAAA,QAC9C,CAAA,MAAO;AACL,UAAA,OAAA,CAAQ,oBAAA,CAAqB,GAAG,oBAAoB,CAAA;AAAA,QACtD;AACA,QAAA,OAAA,CAAQ,cAAA,CAAe,GAAG,oBAAA,CAAqB,WAAW,CAAA;AAC1D,QAAA,OAAA,CAAQ,kBAAA,CAAmB,GAAG,oBAAA,CAAqB,eAAe,CAAA;AAClE,QAAA,OAAA,CAAQ,wBAAA,CAAyB,gBAAgB,eAAe,CAAA;AAEhE,QAAA,IAAI,uBAAuB,oBAAA,EAAsB;AAC/C,UAAA,OAAA,CAAQ,uBAAA;AAAA,YACN,sBAAA,CAAuB;AAAA,WACzB;AAAA,QACF;AAEA,QAAA,MAAM,EAAE,gBAAA,EAAkB,MAAA,EAAO,GAAI,MAAM,QAAQ,KAAA,EAAM;AAEzD,QAAA,IAAI,MAAA,CAAO,WAAA,CAAY,4BAA4B,CAAA,IAAK,IAAA,EAAM;AAC5D,UAAA,SAAA,CAAU,eAAe,YAAY;AACnC,YAAA,MAAM,iBAAiB,KAAA,EAAM;AAAA,UAC/B,CAAC,CAAA;AACD,UAAA,SAAA,CAAU,eAAA,CAAgB,MAAM,gBAAA,CAAiB,IAAA,EAAM,CAAA;AAAA,QACzD;AAEA,QAAA,UAAA,CAAW,IAAI,MAAM,CAAA;AAErB,QAAAC,yDAAA,CAA6B;AAAA,UAC3B,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AAAA,MACH;AAAA,KACD,CAAA;AAAA,EACH;AACF,CAAC;;;;"}
1
+ {"version":3,"file":"CatalogPlugin.cjs.js","sources":["../../src/service/CatalogPlugin.ts"],"sourcesContent":["/*\n * Copyright 2022 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n coreServices,\n createBackendPlugin,\n} from '@backstage/backend-plugin-api';\nimport { Entity, Validators } from '@backstage/catalog-model';\nimport { ForwardedError } from '@backstage/errors';\nimport {\n CatalogProcessor,\n CatalogProcessorParser,\n catalogServiceRef,\n EntityProvider,\n LocationAnalyzer,\n PlaceholderResolver,\n ScmLocationAnalyzer,\n} from '@backstage/plugin-catalog-node';\nimport {\n catalogAnalysisExtensionPoint,\n CatalogLocationsExtensionPoint,\n catalogLocationsExtensionPoint,\n CatalogModelExtensionPoint,\n catalogModelExtensionPoint,\n CatalogPermissionExtensionPoint,\n catalogPermissionExtensionPoint,\n CatalogPermissionRuleInput,\n CatalogProcessingExtensionPoint,\n catalogProcessingExtensionPoint,\n} from '@backstage/plugin-catalog-node/alpha';\nimport { eventsServiceRef } from '@backstage/plugin-events-node';\nimport { Permission } from '@backstage/plugin-permission-common';\nimport { merge } from 'lodash';\nimport { CatalogBuilder } from './CatalogBuilder';\nimport { actionsRegistryServiceRef } from '@backstage/backend-plugin-api/alpha';\nimport { createCatalogActions } from '../actions';\n\nclass CatalogLocationsExtensionPointImpl\n implements CatalogLocationsExtensionPoint\n{\n #locationTypes: string[] | undefined;\n\n setAllowedLocationTypes(locationTypes: Array<string>) {\n this.#locationTypes = locationTypes;\n }\n\n get allowedLocationTypes() {\n return this.#locationTypes;\n }\n}\n\nclass CatalogProcessingExtensionPointImpl\n implements CatalogProcessingExtensionPoint\n{\n #processors = new Array<CatalogProcessor>();\n #entityProviders = new Array<EntityProvider>();\n #placeholderResolvers: Record<string, PlaceholderResolver> = {};\n #onProcessingErrorHandler?: (event: {\n unprocessedEntity: Entity;\n errors: Error[];\n }) => Promise<void> | void;\n\n addProcessor(\n ...processors: Array<CatalogProcessor | Array<CatalogProcessor>>\n ): void {\n this.#processors.push(...processors.flat());\n }\n\n addEntityProvider(\n ...providers: Array<EntityProvider | Array<EntityProvider>>\n ): void {\n this.#entityProviders.push(...providers.flat());\n }\n\n addPlaceholderResolver(key: string, resolver: PlaceholderResolver) {\n if (key in this.#placeholderResolvers)\n throw new Error(\n `A placeholder resolver for '${key}' has already been set up, please check your config.`,\n );\n this.#placeholderResolvers[key] = resolver;\n }\n\n setOnProcessingErrorHandler(\n handler: (event: {\n unprocessedEntity: Entity;\n errors: Error[];\n }) => Promise<void> | void,\n ) {\n this.#onProcessingErrorHandler = handler;\n }\n\n get processors() {\n return this.#processors;\n }\n\n get entityProviders() {\n return this.#entityProviders;\n }\n\n get placeholderResolvers() {\n return this.#placeholderResolvers;\n }\n\n get onProcessingErrorHandler() {\n return this.#onProcessingErrorHandler;\n }\n}\n\nclass CatalogPermissionExtensionPointImpl\n implements CatalogPermissionExtensionPoint\n{\n #permissions = new Array<Permission>();\n #permissionRules = new Array<CatalogPermissionRuleInput>();\n\n addPermissions(...permission: Array<Permission | Array<Permission>>): void {\n this.#permissions.push(...permission.flat());\n }\n\n addPermissionRules(\n ...rules: Array<\n CatalogPermissionRuleInput | Array<CatalogPermissionRuleInput>\n >\n ): void {\n this.#permissionRules.push(...rules.flat());\n }\n\n get permissions() {\n return this.#permissions;\n }\n\n get permissionRules() {\n return this.#permissionRules;\n }\n}\n\nclass CatalogModelExtensionPointImpl implements CatalogModelExtensionPoint {\n #fieldValidators: Partial<Validators> = {};\n\n setFieldValidators(validators: Partial<Validators>): void {\n merge(this.#fieldValidators, validators);\n }\n\n get fieldValidators() {\n return this.#fieldValidators;\n }\n\n #entityDataParser?: CatalogProcessorParser;\n\n setEntityDataParser(parser: CatalogProcessorParser): void {\n if (this.#entityDataParser) {\n throw new Error(\n 'Attempted to install second EntityDataParser. Only one can be set.',\n );\n }\n this.#entityDataParser = parser;\n }\n\n get entityDataParser() {\n return this.#entityDataParser;\n }\n}\n\n/**\n * Catalog plugin\n * @public\n */\nexport const catalogPlugin = createBackendPlugin({\n pluginId: 'catalog',\n register(env) {\n const processingExtensions = new CatalogProcessingExtensionPointImpl();\n // plugins depending on this API will be initialized before this plugins init method is executed.\n env.registerExtensionPoint(\n catalogProcessingExtensionPoint,\n processingExtensions,\n );\n\n let locationAnalyzerFactory:\n | ((options: {\n scmLocationAnalyzers: ScmLocationAnalyzer[];\n }) => Promise<{ locationAnalyzer: LocationAnalyzer }>)\n | undefined = undefined;\n const scmLocationAnalyzers = new Array<ScmLocationAnalyzer>();\n env.registerExtensionPoint(catalogAnalysisExtensionPoint, {\n setLocationAnalyzer(analyzerOrFactory) {\n if (locationAnalyzerFactory) {\n throw new Error('LocationAnalyzer has already been set');\n }\n if (typeof analyzerOrFactory === 'function') {\n locationAnalyzerFactory = analyzerOrFactory;\n } else {\n locationAnalyzerFactory = async () => ({\n locationAnalyzer: analyzerOrFactory,\n });\n }\n },\n addScmLocationAnalyzer(analyzer: ScmLocationAnalyzer) {\n scmLocationAnalyzers.push(analyzer);\n },\n });\n\n const permissionExtensions = new CatalogPermissionExtensionPointImpl();\n env.registerExtensionPoint(\n catalogPermissionExtensionPoint,\n permissionExtensions,\n );\n\n const modelExtensions = new CatalogModelExtensionPointImpl();\n env.registerExtensionPoint(catalogModelExtensionPoint, modelExtensions);\n\n const locationTypeExtensions = new CatalogLocationsExtensionPointImpl();\n env.registerExtensionPoint(\n catalogLocationsExtensionPoint,\n locationTypeExtensions,\n );\n\n env.registerInit({\n deps: {\n logger: coreServices.logger,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n permissions: coreServices.permissions,\n permissionsRegistry: coreServices.permissionsRegistry,\n database: coreServices.database,\n httpRouter: coreServices.httpRouter,\n lifecycle: coreServices.rootLifecycle,\n scheduler: coreServices.scheduler,\n auth: coreServices.auth,\n httpAuth: coreServices.httpAuth,\n auditor: coreServices.auditor,\n events: eventsServiceRef,\n catalog: catalogServiceRef,\n actionsRegistry: actionsRegistryServiceRef,\n },\n async init({\n logger,\n config,\n reader,\n database,\n permissions,\n permissionsRegistry,\n httpRouter,\n lifecycle,\n scheduler,\n auth,\n httpAuth,\n catalog,\n actionsRegistry,\n auditor,\n events,\n }) {\n const builder = await CatalogBuilder.create({\n config,\n reader,\n permissions,\n permissionsRegistry,\n database,\n scheduler,\n logger,\n auth,\n httpAuth,\n auditor,\n events,\n });\n\n if (processingExtensions.onProcessingErrorHandler) {\n builder.subscribe({\n onProcessingError: processingExtensions.onProcessingErrorHandler,\n });\n }\n builder.addProcessor(...processingExtensions.processors);\n builder.addEntityProvider(...processingExtensions.entityProviders);\n\n if (modelExtensions.entityDataParser) {\n builder.setEntityDataParser(modelExtensions.entityDataParser);\n }\n\n Object.entries(processingExtensions.placeholderResolvers).forEach(\n ([key, resolver]) => builder.setPlaceholderResolver(key, resolver),\n );\n if (locationAnalyzerFactory) {\n const { locationAnalyzer } = await locationAnalyzerFactory({\n scmLocationAnalyzers,\n }).catch(e => {\n throw new ForwardedError('Failed to create LocationAnalyzer', e);\n });\n builder.setLocationAnalyzer(locationAnalyzer);\n } else {\n builder.addLocationAnalyzers(...scmLocationAnalyzers);\n }\n builder.addPermissions(...permissionExtensions.permissions);\n builder.addPermissionRules(...permissionExtensions.permissionRules);\n builder.setFieldFormatValidators(modelExtensions.fieldValidators);\n\n if (locationTypeExtensions.allowedLocationTypes) {\n builder.setAllowedLocationTypes(\n locationTypeExtensions.allowedLocationTypes,\n );\n }\n\n const { processingEngine, router } = await builder.build();\n\n if (config.getOptional('catalog.processingInterval') ?? true) {\n lifecycle.addStartupHook(async () => {\n await processingEngine.start();\n });\n lifecycle.addShutdownHook(() => processingEngine.stop());\n }\n\n httpRouter.use(router);\n\n createCatalogActions({\n catalog,\n actionsRegistry,\n });\n },\n });\n },\n});\n"],"names":["merge","createBackendPlugin","catalogProcessingExtensionPoint","catalogAnalysisExtensionPoint","catalogPermissionExtensionPoint","catalogModelExtensionPoint","catalogLocationsExtensionPoint","coreServices","eventsServiceRef","catalogServiceRef","actionsRegistryServiceRef","CatalogBuilder","ForwardedError","createCatalogActions"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage/plugin-catalog-backend",
3
- "version": "3.1.1-next.1",
3
+ "version": "3.1.2-next.2",
4
4
  "description": "The Backstage backend plugin that provides the Backstage catalog",
5
5
  "backstage": {
6
6
  "role": "backend-plugin",
@@ -77,7 +77,7 @@
77
77
  "@backstage/backend-plugin-api": "1.4.4-next.0",
78
78
  "@backstage/catalog-client": "1.12.0",
79
79
  "@backstage/catalog-model": "1.7.5",
80
- "@backstage/config": "1.3.4-next.0",
80
+ "@backstage/config": "1.3.5-next.0",
81
81
  "@backstage/errors": "1.2.7",
82
82
  "@backstage/integration": "1.18.1-next.1",
83
83
  "@backstage/plugin-catalog-common": "1.1.6-next.0",
@@ -106,9 +106,9 @@
106
106
  "zod": "^3.22.4"
107
107
  },
108
108
  "devDependencies": {
109
- "@backstage/backend-defaults": "0.13.0-next.1",
109
+ "@backstage/backend-defaults": "0.13.0-next.2",
110
110
  "@backstage/backend-test-utils": "1.9.1-next.1",
111
- "@backstage/cli": "0.34.4-next.1",
111
+ "@backstage/cli": "0.34.4-next.2",
112
112
  "@backstage/plugin-permission-common": "0.9.2-next.0",
113
113
  "@backstage/repo-tools": "0.15.3-next.0",
114
114
  "@types/core-js": "^2.5.4",