@backstage-community/plugin-tech-radar-backend 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,16 @@
1
1
  # @backstage-community/plugin-tech-radar-backend
2
2
 
3
+ ## 1.1.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 8acb5d5: Backstage version bump to v1.34.1
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [8acb5d5]
12
+ - @backstage-community/plugin-tech-radar-common@1.1.0
13
+
3
14
  ## 1.0.0
4
15
 
5
16
  ### Major Changes
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.cjs.js","sources":["../src/plugin.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { createRouter } from './service/router';\n\n/**\n * techRadarPlugin backend plugin\n *\n * @public\n */\nexport const techRadarPlugin = createBackendPlugin({\n pluginId: 'tech-radar',\n register(env) {\n env.registerInit({\n deps: {\n httpRouter: coreServices.httpRouter,\n logger: coreServices.logger,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n },\n async init({ httpRouter, logger, config, reader }) {\n httpRouter.use(\n await createRouter({\n logger,\n config,\n reader,\n }),\n );\n httpRouter.addAuthPolicy({\n path: '/health',\n allow: 'unauthenticated',\n });\n },\n });\n },\n});\n"],"names":["createBackendPlugin","coreServices","createRouter"],"mappings":";;;;;AA0BO,MAAM,kBAAkBA,oCAAoB,CAAA;AAAA,EACjD,QAAU,EAAA,YAAA;AAAA,EACV,SAAS,GAAK,EAAA;AACZ,IAAA,GAAA,CAAI,YAAa,CAAA;AAAA,MACf,IAAM,EAAA;AAAA,QACJ,YAAYC,6BAAa,CAAA,UAAA;AAAA,QACzB,QAAQA,6BAAa,CAAA,MAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA,UAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA,SAAA;AAAA,OACvB;AAAA,MACA,MAAM,IAAK,CAAA,EAAE,YAAY,MAAQ,EAAA,MAAA,EAAQ,QAAU,EAAA;AACjD,QAAW,UAAA,CAAA,GAAA;AAAA,UACT,MAAMC,mBAAa,CAAA;AAAA,YACjB,MAAA;AAAA,YACA,MAAA;AAAA,YACA,MAAA;AAAA,WACD,CAAA;AAAA,SACH,CAAA;AACA,QAAA,UAAA,CAAW,aAAc,CAAA;AAAA,UACvB,IAAM,EAAA,SAAA;AAAA,UACN,KAAO,EAAA,iBAAA;AAAA,SACR,CAAA,CAAA;AAAA,OACH;AAAA,KACD,CAAA,CAAA;AAAA,GACH;AACF,CAAC;;;;"}
1
+ {"version":3,"file":"plugin.cjs.js","sources":["../src/plugin.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { createRouter } from './service/router';\n\n/**\n * techRadarPlugin backend plugin\n *\n * @public\n */\nexport const techRadarPlugin = createBackendPlugin({\n pluginId: 'tech-radar',\n register(env) {\n env.registerInit({\n deps: {\n httpRouter: coreServices.httpRouter,\n logger: coreServices.logger,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n },\n async init({ httpRouter, logger, config, reader }) {\n httpRouter.use(\n await createRouter({\n logger,\n config,\n reader,\n }),\n );\n httpRouter.addAuthPolicy({\n path: '/health',\n allow: 'unauthenticated',\n });\n },\n });\n },\n});\n"],"names":["createBackendPlugin","coreServices","createRouter"],"mappings":";;;;;AA0BO,MAAM,kBAAkBA,oCAAoB,CAAA;AAAA,EACjD,QAAU,EAAA,YAAA;AAAA,EACV,SAAS,GAAK,EAAA;AACZ,IAAA,GAAA,CAAI,YAAa,CAAA;AAAA,MACf,IAAM,EAAA;AAAA,QACJ,YAAYC,6BAAa,CAAA,UAAA;AAAA,QACzB,QAAQA,6BAAa,CAAA,MAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA,UAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA;AAAA,OACvB;AAAA,MACA,MAAM,IAAK,CAAA,EAAE,YAAY,MAAQ,EAAA,MAAA,EAAQ,QAAU,EAAA;AACjD,QAAW,UAAA,CAAA,GAAA;AAAA,UACT,MAAMC,mBAAa,CAAA;AAAA,YACjB,MAAA;AAAA,YACA,MAAA;AAAA,YACA;AAAA,WACD;AAAA,SACH;AACA,QAAA,UAAA,CAAW,aAAc,CAAA;AAAA,UACvB,IAAM,EAAA,SAAA;AAAA,UACN,KAAO,EAAA;AAAA,SACR,CAAA;AAAA;AACH,KACD,CAAA;AAAA;AAEL,CAAC;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"router.cjs.js","sources":["../../src/service/router.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport {\n LoggerService,\n RootConfigService,\n UrlReaderService,\n} from '@backstage/backend-plugin-api';\nimport express from 'express';\nimport Router from 'express-promise-router';\nimport { readTechRadarResponseFromURL } from '../utils';\n\n/**\n * See UrlReader documentation: https://backstage.io/docs/backend-system/core-services/url-reader/\n *\n * @public\n */\nexport interface RouterOptions {\n logger: LoggerService;\n config: RootConfigService;\n reader: UrlReaderService;\n}\n\n/**\n * Create the Tech Radar Router, used for reading the Tech Radar data from the provided URL.\n *\n * @public\n *\n * @param options - Router options\n */\nexport async function createRouter(\n options: RouterOptions,\n): Promise<express.Router> {\n const { logger, config, reader } = options;\n\n const router = Router();\n router.use(express.json());\n const url = config.getString('techRadar.url');\n\n router.get('/health', (_, response) => {\n logger.info('PONG!');\n response.json({ status: 'ok' });\n });\n\n router.get('/data', async (_, response) => {\n const dataFromUrl = await readTechRadarResponseFromURL(url, reader, logger);\n if (!dataFromUrl) {\n response\n .status(502)\n .json({ message: 'Unable to retrieve data from provided URL' });\n return;\n }\n response.json(dataFromUrl);\n });\n\n const middleware = MiddlewareFactory.create({ logger, config });\n\n router.use(middleware.error());\n return router;\n}\n"],"names":["Router","express","readTechRadarResponseFromURL","MiddlewareFactory"],"mappings":";;;;;;;;;;;;AA2CA,eAAsB,aACpB,OACyB,EAAA;AACzB,EAAA,MAAM,EAAE,MAAA,EAAQ,MAAQ,EAAA,MAAA,EAAW,GAAA,OAAA,CAAA;AAEnC,EAAA,MAAM,SAASA,uBAAO,EAAA,CAAA;AACtB,EAAO,MAAA,CAAA,GAAA,CAAIC,wBAAQ,CAAA,IAAA,EAAM,CAAA,CAAA;AACzB,EAAM,MAAA,GAAA,GAAM,MAAO,CAAA,SAAA,CAAU,eAAe,CAAA,CAAA;AAE5C,EAAA,MAAA,CAAO,GAAI,CAAA,SAAA,EAAW,CAAC,CAAA,EAAG,QAAa,KAAA;AACrC,IAAA,MAAA,CAAO,KAAK,OAAO,CAAA,CAAA;AACnB,IAAA,QAAA,CAAS,IAAK,CAAA,EAAE,MAAQ,EAAA,IAAA,EAAM,CAAA,CAAA;AAAA,GAC/B,CAAA,CAAA;AAED,EAAA,MAAA,CAAO,GAAI,CAAA,OAAA,EAAS,OAAO,CAAA,EAAG,QAAa,KAAA;AACzC,IAAA,MAAM,WAAc,GAAA,MAAMC,kCAA6B,CAAA,GAAA,EAAK,QAAQ,MAAM,CAAA,CAAA;AAC1E,IAAA,IAAI,CAAC,WAAa,EAAA;AAChB,MAAA,QAAA,CACG,OAAO,GAAG,CAAA,CACV,KAAK,EAAE,OAAA,EAAS,6CAA6C,CAAA,CAAA;AAChE,MAAA,OAAA;AAAA,KACF;AACA,IAAA,QAAA,CAAS,KAAK,WAAW,CAAA,CAAA;AAAA,GAC1B,CAAA,CAAA;AAED,EAAA,MAAM,aAAaC,gCAAkB,CAAA,MAAA,CAAO,EAAE,MAAA,EAAQ,QAAQ,CAAA,CAAA;AAE9D,EAAO,MAAA,CAAA,GAAA,CAAI,UAAW,CAAA,KAAA,EAAO,CAAA,CAAA;AAC7B,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
1
+ {"version":3,"file":"router.cjs.js","sources":["../../src/service/router.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport {\n LoggerService,\n RootConfigService,\n UrlReaderService,\n} from '@backstage/backend-plugin-api';\nimport express from 'express';\nimport Router from 'express-promise-router';\nimport { readTechRadarResponseFromURL } from '../utils';\n\n/**\n * See UrlReader documentation: https://backstage.io/docs/backend-system/core-services/url-reader/\n *\n * @public\n */\nexport interface RouterOptions {\n logger: LoggerService;\n config: RootConfigService;\n reader: UrlReaderService;\n}\n\n/**\n * Create the Tech Radar Router, used for reading the Tech Radar data from the provided URL.\n *\n * @public\n *\n * @param options - Router options\n */\nexport async function createRouter(\n options: RouterOptions,\n): Promise<express.Router> {\n const { logger, config, reader } = options;\n\n const router = Router();\n router.use(express.json());\n const url = config.getString('techRadar.url');\n\n router.get('/health', (_, response) => {\n logger.info('PONG!');\n response.json({ status: 'ok' });\n });\n\n router.get('/data', async (_, response) => {\n const dataFromUrl = await readTechRadarResponseFromURL(url, reader, logger);\n if (!dataFromUrl) {\n response\n .status(502)\n .json({ message: 'Unable to retrieve data from provided URL' });\n return;\n }\n response.json(dataFromUrl);\n });\n\n const middleware = MiddlewareFactory.create({ logger, config });\n\n router.use(middleware.error());\n return router;\n}\n"],"names":["Router","express","readTechRadarResponseFromURL","MiddlewareFactory"],"mappings":";;;;;;;;;;;;AA2CA,eAAsB,aACpB,OACyB,EAAA;AACzB,EAAA,MAAM,EAAE,MAAA,EAAQ,MAAQ,EAAA,MAAA,EAAW,GAAA,OAAA;AAEnC,EAAA,MAAM,SAASA,uBAAO,EAAA;AACtB,EAAO,MAAA,CAAA,GAAA,CAAIC,wBAAQ,CAAA,IAAA,EAAM,CAAA;AACzB,EAAM,MAAA,GAAA,GAAM,MAAO,CAAA,SAAA,CAAU,eAAe,CAAA;AAE5C,EAAA,MAAA,CAAO,GAAI,CAAA,SAAA,EAAW,CAAC,CAAA,EAAG,QAAa,KAAA;AACrC,IAAA,MAAA,CAAO,KAAK,OAAO,CAAA;AACnB,IAAA,QAAA,CAAS,IAAK,CAAA,EAAE,MAAQ,EAAA,IAAA,EAAM,CAAA;AAAA,GAC/B,CAAA;AAED,EAAA,MAAA,CAAO,GAAI,CAAA,OAAA,EAAS,OAAO,CAAA,EAAG,QAAa,KAAA;AACzC,IAAA,MAAM,WAAc,GAAA,MAAMC,kCAA6B,CAAA,GAAA,EAAK,QAAQ,MAAM,CAAA;AAC1E,IAAA,IAAI,CAAC,WAAa,EAAA;AAChB,MAAA,QAAA,CACG,OAAO,GAAG,CAAA,CACV,KAAK,EAAE,OAAA,EAAS,6CAA6C,CAAA;AAChE,MAAA;AAAA;AAEF,IAAA,QAAA,CAAS,KAAK,WAAW,CAAA;AAAA,GAC1B,CAAA;AAED,EAAA,MAAM,aAAaC,gCAAkB,CAAA,MAAA,CAAO,EAAE,MAAA,EAAQ,QAAQ,CAAA;AAE9D,EAAO,MAAA,CAAA,GAAA,CAAI,UAAW,CAAA,KAAA,EAAO,CAAA;AAC7B,EAAO,OAAA,MAAA;AACT;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { LoggerService, UrlReaderService } from '@backstage/backend-plugin-api';\nimport {\n TechRadarLoaderResponse,\n TechRadarLoaderResponseParser,\n} from '@backstage-community/plugin-tech-radar-common';\nimport { ZodError } from 'zod';\n\n/**\n * Reads data from a URL via the urlReader, then parses it into a TechRadarLoaderResponse.\n * Returns undefined if the data could not be read or parsed safely.\n * @param url - the URL to read from.\n * @param urlReader - a URLReader for reading from integrations.\n * @param LoggerService - a logger for logging errors.\n *\n * @internal\n */\nexport async function readTechRadarResponseFromURL(\n url: string,\n urlReader: UrlReaderService,\n logger: LoggerService,\n): Promise<TechRadarLoaderResponse | undefined> {\n let buffer = undefined;\n let responseJson = undefined;\n try {\n const response = await urlReader.readUrl(url);\n buffer = await response.buffer();\n } catch (e) {\n // Log a warning.\n logger.warn(\n `Failed to read file from ${url} with provided integrations (error is \"${e.message}\").`,\n );\n }\n\n if (buffer) {\n try {\n responseJson = JSON.parse(buffer.toString());\n const validationResult =\n TechRadarLoaderResponseParser.safeParse(responseJson);\n if (!validationResult.success) {\n const errorMessage = `Could not parse data from remote URL '${url}' because validation failed: ${aggregateErrorMessages(\n validationResult.error,\n )}. URL must serve JSON that is compatible with the TechRadarLoaderResponse schema.`;\n logger.error(errorMessage);\n }\n return validationResult.data;\n } catch (e) {\n logger.error(\n `Failed to parse JSON from remote resource ${url}, data will not be loaded!`,\n );\n }\n }\n\n return undefined;\n}\n\n/**\n * Aggregates error messages from a ZodError.\n * @internal\n * @param zodError\n */\nfunction aggregateErrorMessages(zodError: ZodError): string {\n return zodError.issues.reduce((acc, issue) => {\n if (issue) {\n return [acc, `${issue.message} parameter '${issue.path}'`]\n .filter(Boolean)\n .join('. ');\n }\n return acc;\n }, '');\n}\n"],"names":["TechRadarLoaderResponseParser"],"mappings":";;;;AA+BsB,eAAA,4BAAA,CACpB,GACA,EAAA,SAAA,EACA,MAC8C,EAAA;AAC9C,EAAA,IAAI,MAAS,GAAA,KAAA,CAAA,CAAA;AACb,EAAA,IAAI,YAAe,GAAA,KAAA,CAAA,CAAA;AACnB,EAAI,IAAA;AACF,IAAA,MAAM,QAAW,GAAA,MAAM,SAAU,CAAA,OAAA,CAAQ,GAAG,CAAA,CAAA;AAC5C,IAAS,MAAA,GAAA,MAAM,SAAS,MAAO,EAAA,CAAA;AAAA,WACxB,CAAG,EAAA;AAEV,IAAO,MAAA,CAAA,IAAA;AAAA,MACL,CAA4B,yBAAA,EAAA,GAAG,CAA0C,uCAAA,EAAA,CAAA,CAAE,OAAO,CAAA,GAAA,CAAA;AAAA,KACpF,CAAA;AAAA,GACF;AAEA,EAAA,IAAI,MAAQ,EAAA;AACV,IAAI,IAAA;AACF,MAAA,YAAA,GAAe,IAAK,CAAA,KAAA,CAAM,MAAO,CAAA,QAAA,EAAU,CAAA,CAAA;AAC3C,MAAM,MAAA,gBAAA,GACJA,mDAA8B,CAAA,SAAA,CAAU,YAAY,CAAA,CAAA;AACtD,MAAI,IAAA,CAAC,iBAAiB,OAAS,EAAA;AAC7B,QAAM,MAAA,YAAA,GAAe,CAAyC,sCAAA,EAAA,GAAG,CAAgC,6BAAA,EAAA,sBAAA;AAAA,UAC/F,gBAAiB,CAAA,KAAA;AAAA,SAClB,CAAA,iFAAA,CAAA,CAAA;AACD,QAAA,MAAA,CAAO,MAAM,YAAY,CAAA,CAAA;AAAA,OAC3B;AACA,MAAA,OAAO,gBAAiB,CAAA,IAAA,CAAA;AAAA,aACjB,CAAG,EAAA;AACV,MAAO,MAAA,CAAA,KAAA;AAAA,QACL,6CAA6C,GAAG,CAAA,0BAAA,CAAA;AAAA,OAClD,CAAA;AAAA,KACF;AAAA,GACF;AAEA,EAAO,OAAA,KAAA,CAAA,CAAA;AACT,CAAA;AAOA,SAAS,uBAAuB,QAA4B,EAAA;AAC1D,EAAA,OAAO,QAAS,CAAA,MAAA,CAAO,MAAO,CAAA,CAAC,KAAK,KAAU,KAAA;AAC5C,IAAA,IAAI,KAAO,EAAA;AACT,MAAA,OAAO,CAAC,GAAA,EAAK,CAAG,EAAA,KAAA,CAAM,OAAO,CAAe,YAAA,EAAA,KAAA,CAAM,IAAI,CAAA,CAAA,CAAG,CACtD,CAAA,MAAA,CAAO,OAAO,CAAA,CACd,KAAK,IAAI,CAAA,CAAA;AAAA,KACd;AACA,IAAO,OAAA,GAAA,CAAA;AAAA,KACN,EAAE,CAAA,CAAA;AACP;;;;"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../../src/utils/index.ts"],"sourcesContent":["/*\n * Copyright 2024 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 { LoggerService, UrlReaderService } from '@backstage/backend-plugin-api';\nimport {\n TechRadarLoaderResponse,\n TechRadarLoaderResponseParser,\n} from '@backstage-community/plugin-tech-radar-common';\nimport { ZodError } from 'zod';\n\n/**\n * Reads data from a URL via the urlReader, then parses it into a TechRadarLoaderResponse.\n * Returns undefined if the data could not be read or parsed safely.\n * @param url - the URL to read from.\n * @param urlReader - a URLReader for reading from integrations.\n * @param LoggerService - a logger for logging errors.\n *\n * @internal\n */\nexport async function readTechRadarResponseFromURL(\n url: string,\n urlReader: UrlReaderService,\n logger: LoggerService,\n): Promise<TechRadarLoaderResponse | undefined> {\n let buffer = undefined;\n let responseJson = undefined;\n try {\n const response = await urlReader.readUrl(url);\n buffer = await response.buffer();\n } catch (e) {\n // Log a warning.\n logger.warn(\n `Failed to read file from ${url} with provided integrations (error is \"${e.message}\").`,\n );\n }\n\n if (buffer) {\n try {\n responseJson = JSON.parse(buffer.toString());\n const validationResult =\n TechRadarLoaderResponseParser.safeParse(responseJson);\n if (!validationResult.success) {\n const errorMessage = `Could not parse data from remote URL '${url}' because validation failed: ${aggregateErrorMessages(\n validationResult.error,\n )}. URL must serve JSON that is compatible with the TechRadarLoaderResponse schema.`;\n logger.error(errorMessage);\n }\n return validationResult.data;\n } catch (e) {\n logger.error(\n `Failed to parse JSON from remote resource ${url}, data will not be loaded!`,\n );\n }\n }\n\n return undefined;\n}\n\n/**\n * Aggregates error messages from a ZodError.\n * @internal\n * @param zodError\n */\nfunction aggregateErrorMessages(zodError: ZodError): string {\n return zodError.issues.reduce((acc, issue) => {\n if (issue) {\n return [acc, `${issue.message} parameter '${issue.path}'`]\n .filter(Boolean)\n .join('. ');\n }\n return acc;\n }, '');\n}\n"],"names":["TechRadarLoaderResponseParser"],"mappings":";;;;AA+BsB,eAAA,4BAAA,CACpB,GACA,EAAA,SAAA,EACA,MAC8C,EAAA;AAC9C,EAAA,IAAI,MAAS,GAAA,KAAA,CAAA;AACb,EAAA,IAAI,YAAe,GAAA,KAAA,CAAA;AACnB,EAAI,IAAA;AACF,IAAA,MAAM,QAAW,GAAA,MAAM,SAAU,CAAA,OAAA,CAAQ,GAAG,CAAA;AAC5C,IAAS,MAAA,GAAA,MAAM,SAAS,MAAO,EAAA;AAAA,WACxB,CAAG,EAAA;AAEV,IAAO,MAAA,CAAA,IAAA;AAAA,MACL,CAA4B,yBAAA,EAAA,GAAG,CAA0C,uCAAA,EAAA,CAAA,CAAE,OAAO,CAAA,GAAA;AAAA,KACpF;AAAA;AAGF,EAAA,IAAI,MAAQ,EAAA;AACV,IAAI,IAAA;AACF,MAAA,YAAA,GAAe,IAAK,CAAA,KAAA,CAAM,MAAO,CAAA,QAAA,EAAU,CAAA;AAC3C,MAAM,MAAA,gBAAA,GACJA,mDAA8B,CAAA,SAAA,CAAU,YAAY,CAAA;AACtD,MAAI,IAAA,CAAC,iBAAiB,OAAS,EAAA;AAC7B,QAAM,MAAA,YAAA,GAAe,CAAyC,sCAAA,EAAA,GAAG,CAAgC,6BAAA,EAAA,sBAAA;AAAA,UAC/F,gBAAiB,CAAA;AAAA,SAClB,CAAA,iFAAA,CAAA;AACD,QAAA,MAAA,CAAO,MAAM,YAAY,CAAA;AAAA;AAE3B,MAAA,OAAO,gBAAiB,CAAA,IAAA;AAAA,aACjB,CAAG,EAAA;AACV,MAAO,MAAA,CAAA,KAAA;AAAA,QACL,6CAA6C,GAAG,CAAA,0BAAA;AAAA,OAClD;AAAA;AACF;AAGF,EAAO,OAAA,KAAA,CAAA;AACT;AAOA,SAAS,uBAAuB,QAA4B,EAAA;AAC1D,EAAA,OAAO,QAAS,CAAA,MAAA,CAAO,MAAO,CAAA,CAAC,KAAK,KAAU,KAAA;AAC5C,IAAA,IAAI,KAAO,EAAA;AACT,MAAA,OAAO,CAAC,GAAA,EAAK,CAAG,EAAA,KAAA,CAAM,OAAO,CAAe,YAAA,EAAA,KAAA,CAAM,IAAI,CAAA,CAAA,CAAG,CACtD,CAAA,MAAA,CAAO,OAAO,CAAA,CACd,KAAK,IAAI,CAAA;AAAA;AAEd,IAAO,OAAA,GAAA;AAAA,KACN,EAAE,CAAA;AACP;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage-community/plugin-tech-radar-backend",
3
- "version": "1.0.0",
3
+ "version": "1.1.0",
4
4
  "main": "dist/index.cjs.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "license": "Apache-2.0",
@@ -34,20 +34,20 @@
34
34
  "postpack": "backstage-cli package postpack"
35
35
  },
36
36
  "dependencies": {
37
- "@backstage-community/plugin-tech-radar-common": "^1.0.0",
38
- "@backstage/backend-defaults": "^0.5.0",
39
- "@backstage/backend-plugin-api": "^1.0.0",
40
- "@backstage/config": "^1.2.0",
37
+ "@backstage-community/plugin-tech-radar-common": "^1.1.0",
38
+ "@backstage/backend-defaults": "^0.6.1",
39
+ "@backstage/backend-plugin-api": "^1.1.0",
40
+ "@backstage/config": "^1.3.1",
41
41
  "express": "^4.17.1",
42
42
  "express-promise-router": "^4.1.0",
43
43
  "node-fetch": "^2.6.7",
44
44
  "zod": "^3.20.0"
45
45
  },
46
46
  "devDependencies": {
47
- "@backstage/backend-test-utils": "^1.0.0",
48
- "@backstage/cli": "^0.27.1",
49
- "@backstage/plugin-auth-backend": "^0.23.0",
50
- "@backstage/plugin-auth-backend-module-guest-provider": "^0.2.0",
47
+ "@backstage/backend-test-utils": "^1.2.0",
48
+ "@backstage/cli": "^0.29.4",
49
+ "@backstage/plugin-auth-backend": "^0.24.1",
50
+ "@backstage/plugin-auth-backend-module-guest-provider": "^0.2.3",
51
51
  "@types/express": "*",
52
52
  "@types/supertest": "^2.0.12",
53
53
  "msw": "^2.3.1",
@@ -57,5 +57,12 @@
57
57
  "dist",
58
58
  "config.d.ts"
59
59
  ],
60
- "configSchema": "config.d.ts"
60
+ "configSchema": "config.d.ts",
61
+ "typesVersions": {
62
+ "*": {
63
+ "index": [
64
+ "dist/index.d.ts"
65
+ ]
66
+ }
67
+ }
61
68
  }