@secustor/backstage-plugin-renovate-backend 0.15.8 → 0.16.1

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,21 @@
1
1
  # @secustor/backstage-plugin-renovate-backend
2
2
 
3
+ ## 0.16.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [`01a41bd`](https://github.com/secustor/backstage-plugins/commit/01a41bdbfb456fcbe6af1dfcf56143d6c59aef7c) Thanks [@renovate[bot]](https://github.com/renovate%5Bbot%5D)! - Bump Backstage to 1.42.1
8
+
9
+ - Updated dependencies [[`01a41bd`](https://github.com/secustor/backstage-plugins/commit/01a41bdbfb456fcbe6af1dfcf56143d6c59aef7c)]:
10
+ - @secustor/backstage-plugin-renovate-common@0.9.3
11
+ - @secustor/backstage-plugin-renovate-node@0.5.7
12
+
13
+ ## 0.16.0
14
+
15
+ ### Minor Changes
16
+
17
+ - [#785](https://github.com/secustor/backstage-plugins/pull/785) [`a046b09`](https://github.com/secustor/backstage-plugins/commit/a046b0910cecf2b0b98c410ba80b7df0fe3dc233) Thanks [@veenarm](https://github.com/veenarm)! - Implemented ability to pass host environment variables to the renovate runner. These can be auto passed or overwritten using renovate.runtime.environment array with name/value keys. This is to resolve an issue with directs inability to use fork node process of custom CAs.
18
+
3
19
  ## 0.15.8
4
20
 
5
21
  ### Patch Changes
package/README.md CHANGED
@@ -87,7 +87,13 @@ renovate:
87
87
  runtime:
88
88
  # ID of the runtime provided via extension point. This option is required as the backend comes with no runtime by default.
89
89
  type: docker
90
-
90
+ # add variables to the designated runner or pass through from existing instance.
91
+ environment:
92
+ # forward simply the NODE_EXTRA_CA_CERTS variable
93
+ - name: NODE_EXTRA_CA_CERTS
94
+ # set the variable to a specific value
95
+ - name: HTTPS_PROXY
96
+ value: http://proxy.my.com:8080
91
97
  queue:
92
98
  type: local-fastq
93
99
 
package/config.d.ts CHANGED
@@ -47,12 +47,26 @@ export interface Config {
47
47
  * For module-specific configuration sees the relevant module
48
48
  */
49
49
  type: string;
50
+
51
+ /**
52
+ * Runtime environment variables
53
+ */
54
+ environment?: Array<{
55
+ /**
56
+ * Name of the environment variable
57
+ */
58
+ name: string;
59
+ /**
60
+ * Optional explicit value (falls back to `process.env[name]`)
61
+ */
62
+ value?: string;
63
+ }>;
50
64
  };
51
65
 
52
66
  /**
53
67
  * Config for queues
54
68
  */
55
- queues: {
69
+ queue: {
56
70
  /**
57
71
  * The queue to use. The value references id of a queue supplied by a module
58
72
  * For module-specific configuration sees the relevant module
@@ -13,9 +13,11 @@ function getRenovateConfig(rootConfig) {
13
13
  function getRuntimeConfigs(rootConfig) {
14
14
  const runtimeConfig = getPluginConfig(rootConfig).getConfig("runtime");
15
15
  const runtime = runtimeConfig.getString("type");
16
+ const environment = runtimeConfig.getOptionalConfigArray("environment") ?? [];
16
17
  return {
17
18
  runtime,
18
- config: runtimeConfig.getConfig(runtime)
19
+ config: runtimeConfig.getConfig(runtime),
20
+ environment
19
21
  };
20
22
  }
21
23
  function getScheduleDefinition(pluginConfig, variant) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../../src/config/index.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport { readSchedulerServiceTaskScheduleDefinitionFromConfig } from '@backstage/backend-plugin-api';\nimport { JsonValue } from '@backstage/types';\n\nimport { EnabledScheduleDefinition } from './types';\n\nexport const RENOVATE_ANNOTATION_KEEP_UPDATED =\n 'renovate.secustor.dev/keep-updated';\n\nexport function getPluginConfig(rootConfig: Config): Config {\n return rootConfig.getConfig('renovate');\n}\n\nexport function getRenovateConfig(rootConfig: Config): JsonValue {\n const value = getPluginConfig(rootConfig).getOptional('config');\n return value ?? null;\n}\n\nexport function getRuntimeConfigs(rootConfig: Config): {\n runtime: string;\n config: Config | null;\n} {\n const runtimeConfig = getPluginConfig(rootConfig).getConfig('runtime');\n const runtime = runtimeConfig.getString('type');\n return {\n runtime,\n config: runtimeConfig.getConfig(runtime),\n };\n}\n\nexport function getScheduleDefinition(\n pluginConfig: Config,\n variant: 'renovation' | 'cleanup',\n): EnabledScheduleDefinition {\n try {\n const scheduleConfig = pluginConfig.getConfig(`schedules.${variant}`);\n return {\n enabled: scheduleConfig.getOptionalBoolean('enabled') ?? true,\n ...readSchedulerServiceTaskScheduleDefinitionFromConfig(scheduleConfig),\n };\n } catch (e) {\n return {\n enabled: true,\n scope: 'global',\n timeout: { minutes: 60 },\n frequency: { minutes: 60 },\n };\n }\n}\n"],"names":["readSchedulerServiceTaskScheduleDefinitionFromConfig"],"mappings":";;;;AAMO,MAAM,gCACX,GAAA;AAEK,SAAS,gBAAgB,UAA4B,EAAA;AAC1D,EAAO,OAAA,UAAA,CAAW,UAAU,UAAU,CAAA;AACxC;AAEO,SAAS,kBAAkB,UAA+B,EAAA;AAC/D,EAAA,MAAM,KAAQ,GAAA,eAAA,CAAgB,UAAU,CAAA,CAAE,YAAY,QAAQ,CAAA;AAC9D,EAAA,OAAO,KAAS,IAAA,IAAA;AAClB;AAEO,SAAS,kBAAkB,UAGhC,EAAA;AACA,EAAA,MAAM,aAAgB,GAAA,eAAA,CAAgB,UAAU,CAAA,CAAE,UAAU,SAAS,CAAA;AACrE,EAAM,MAAA,OAAA,GAAU,aAAc,CAAA,SAAA,CAAU,MAAM,CAAA;AAC9C,EAAO,OAAA;AAAA,IACL,OAAA;AAAA,IACA,MAAA,EAAQ,aAAc,CAAA,SAAA,CAAU,OAAO;AAAA,GACzC;AACF;AAEgB,SAAA,qBAAA,CACd,cACA,OAC2B,EAAA;AAC3B,EAAI,IAAA;AACF,IAAA,MAAM,cAAiB,GAAA,YAAA,CAAa,SAAU,CAAA,CAAA,UAAA,EAAa,OAAO,CAAE,CAAA,CAAA;AACpE,IAAO,OAAA;AAAA,MACL,OAAS,EAAA,cAAA,CAAe,kBAAmB,CAAA,SAAS,CAAK,IAAA,IAAA;AAAA,MACzD,GAAGA,sEAAqD,cAAc;AAAA,KACxE;AAAA,WACO,CAAG,EAAA;AACV,IAAO,OAAA;AAAA,MACL,OAAS,EAAA,IAAA;AAAA,MACT,KAAO,EAAA,QAAA;AAAA,MACP,OAAA,EAAS,EAAE,OAAA,EAAS,EAAG,EAAA;AAAA,MACvB,SAAA,EAAW,EAAE,OAAA,EAAS,EAAG;AAAA,KAC3B;AAAA;AAEJ;;;;;;;;"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../../src/config/index.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport { readSchedulerServiceTaskScheduleDefinitionFromConfig } from '@backstage/backend-plugin-api';\nimport { JsonValue } from '@backstage/types';\n\nimport { EnabledScheduleDefinition } from './types';\n\nexport const RENOVATE_ANNOTATION_KEEP_UPDATED =\n 'renovate.secustor.dev/keep-updated';\n\nexport function getPluginConfig(rootConfig: Config): Config {\n return rootConfig.getConfig('renovate');\n}\n\nexport function getRenovateConfig(rootConfig: Config): JsonValue {\n const value = getPluginConfig(rootConfig).getOptional('config');\n return value ?? null;\n}\n\nexport function getRuntimeConfigs(rootConfig: Config): {\n runtime: string;\n config: Config | null;\n environment: Config[];\n} {\n const runtimeConfig = getPluginConfig(rootConfig).getConfig('runtime');\n const runtime = runtimeConfig.getString('type');\n const environment = runtimeConfig.getOptionalConfigArray('environment') ?? [];\n return {\n runtime,\n config: runtimeConfig.getConfig(runtime),\n environment,\n };\n}\n\nexport function getScheduleDefinition(\n pluginConfig: Config,\n variant: 'renovation' | 'cleanup',\n): EnabledScheduleDefinition {\n try {\n const scheduleConfig = pluginConfig.getConfig(`schedules.${variant}`);\n return {\n enabled: scheduleConfig.getOptionalBoolean('enabled') ?? true,\n ...readSchedulerServiceTaskScheduleDefinitionFromConfig(scheduleConfig),\n };\n } catch (e) {\n return {\n enabled: true,\n scope: 'global',\n timeout: { minutes: 60 },\n frequency: { minutes: 60 },\n };\n }\n}\n"],"names":["readSchedulerServiceTaskScheduleDefinitionFromConfig"],"mappings":";;;;AAMO,MAAM,gCAAA,GACX;AAEK,SAAS,gBAAgB,UAAA,EAA4B;AAC1D,EAAA,OAAO,UAAA,CAAW,UAAU,UAAU,CAAA;AACxC;AAEO,SAAS,kBAAkB,UAAA,EAA+B;AAC/D,EAAA,MAAM,KAAA,GAAQ,eAAA,CAAgB,UAAU,CAAA,CAAE,YAAY,QAAQ,CAAA;AAC9D,EAAA,OAAO,KAAA,IAAS,IAAA;AAClB;AAEO,SAAS,kBAAkB,UAAA,EAIhC;AACA,EAAA,MAAM,aAAA,GAAgB,eAAA,CAAgB,UAAU,CAAA,CAAE,UAAU,SAAS,CAAA;AACrE,EAAA,MAAM,OAAA,GAAU,aAAA,CAAc,SAAA,CAAU,MAAM,CAAA;AAC9C,EAAA,MAAM,WAAA,GAAc,aAAA,CAAc,sBAAA,CAAuB,aAAa,KAAK,EAAC;AAC5E,EAAA,OAAO;AAAA,IACL,OAAA;AAAA,IACA,MAAA,EAAQ,aAAA,CAAc,SAAA,CAAU,OAAO,CAAA;AAAA,IACvC;AAAA,GACF;AACF;AAEO,SAAS,qBAAA,CACd,cACA,OAAA,EAC2B;AAC3B,EAAA,IAAI;AACF,IAAA,MAAM,cAAA,GAAiB,YAAA,CAAa,SAAA,CAAU,CAAA,UAAA,EAAa,OAAO,CAAA,CAAE,CAAA;AACpE,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,cAAA,CAAe,kBAAA,CAAmB,SAAS,CAAA,IAAK,IAAA;AAAA,MACzD,GAAGA,sEAAqD,cAAc;AAAA,KACxE;AAAA,EACF,SAAS,CAAA,EAAG;AACV,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,IAAA;AAAA,MACT,KAAA,EAAO,QAAA;AAAA,MACP,OAAA,EAAS,EAAE,OAAA,EAAS,EAAA,EAAG;AAAA,MACvB,SAAA,EAAW,EAAE,OAAA,EAAS,EAAA;AAAG,KAC3B;AAAA,EACF;AACF;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.cjs.js","sources":["../src/plugin.ts"],"sourcesContent":["import {\n coreServices,\n createBackendPlugin,\n} from '@backstage/backend-plugin-api';\nimport { createRouter } from './service/router';\nimport { RenovateWrapper } from '@secustor/backstage-plugin-renovate-common';\nimport { RenovateRunner } from './wrapper';\nimport { RouterOptions } from './service/types';\nimport { DatabaseHandler } from './service/databaseHandler';\nimport {\n QueueFactory,\n renovateQueueExtensionPoint,\n renovateRuntimeExtensionPoint,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\nimport { scheduleJobSync } from './service/jobSync';\nimport { scheduleCleanupTask } from './service/cleanupTask';\n\n/**\n * Renovate backend plugin\n *\n * @public\n */\nexport const renovatePlugin = createBackendPlugin({\n pluginId: 'renovate',\n register(env) {\n // allow modules provide additional runtimes\n const runtimes = new Map<string, RenovateWrapper>();\n env.registerExtensionPoint(renovateRuntimeExtensionPoint, {\n addRuntime(id: string, runtime: RenovateWrapper) {\n if (runtimes.has(id)) {\n throw new Error(\n ` ${id} has been already registered. Only one wrapper with the same ID is allowed to be registered`,\n );\n }\n runtimes.set(id, runtime);\n },\n });\n\n const queueFactories = new Map<string, QueueFactory<RunOptions>>();\n env.registerExtensionPoint(renovateQueueExtensionPoint, {\n addQueueFactory(id: string, factory: QueueFactory<RunOptions>) {\n if (queueFactories.has(id)) {\n throw new Error(\n ` ${id} has been already registered. Only one queue with the same ID is allowed to be registered`,\n );\n }\n queueFactories.set(id, factory);\n },\n });\n\n env.registerInit({\n deps: {\n rootConfig: coreServices.rootConfig,\n logger: coreServices.logger,\n httpRouter: coreServices.httpRouter,\n database: coreServices.database,\n scheduler: coreServices.scheduler,\n discovery: coreServices.discovery,\n auth: coreServices.auth,\n },\n async init(options) {\n const { database, httpRouter, logger } = options;\n\n const routerOptions: RouterOptions = {\n ...options,\n databaseHandler: await DatabaseHandler.create({ database, logger }),\n runtimes,\n queueFactories,\n };\n const renovateRunner = await RenovateRunner.from(routerOptions);\n\n await scheduleJobSync(renovateRunner, routerOptions);\n await scheduleCleanupTask(routerOptions);\n\n httpRouter.use(await createRouter(renovateRunner, routerOptions));\n httpRouter.addAuthPolicy({\n path: '/health',\n allow: 'unauthenticated',\n });\n },\n });\n },\n});\n"],"names":["createBackendPlugin","renovateRuntimeExtensionPoint","renovateQueueExtensionPoint","coreServices","DatabaseHandler","renovateRunner","RenovateRunner","scheduleJobSync","scheduleCleanupTask","createRouter"],"mappings":";;;;;;;;;;AAuBO,MAAM,iBAAiBA,oCAAoB,CAAA;AAAA,EAChD,QAAU,EAAA,UAAA;AAAA,EACV,SAAS,GAAK,EAAA;AAEZ,IAAM,MAAA,QAAA,uBAAe,GAA6B,EAAA;AAClD,IAAA,GAAA,CAAI,uBAAuBC,yDAA+B,EAAA;AAAA,MACxD,UAAA,CAAW,IAAY,OAA0B,EAAA;AAC/C,QAAI,IAAA,QAAA,CAAS,GAAI,CAAA,EAAE,CAAG,EAAA;AACpB,UAAA,MAAM,IAAI,KAAA;AAAA,YACR,IAAI,EAAE,CAAA,2FAAA;AAAA,WACR;AAAA;AAEF,QAAS,QAAA,CAAA,GAAA,CAAI,IAAI,OAAO,CAAA;AAAA;AAC1B,KACD,CAAA;AAED,IAAM,MAAA,cAAA,uBAAqB,GAAsC,EAAA;AACjE,IAAA,GAAA,CAAI,uBAAuBC,uDAA6B,EAAA;AAAA,MACtD,eAAA,CAAgB,IAAY,OAAmC,EAAA;AAC7D,QAAI,IAAA,cAAA,CAAe,GAAI,CAAA,EAAE,CAAG,EAAA;AAC1B,UAAA,MAAM,IAAI,KAAA;AAAA,YACR,IAAI,EAAE,CAAA,yFAAA;AAAA,WACR;AAAA;AAEF,QAAe,cAAA,CAAA,GAAA,CAAI,IAAI,OAAO,CAAA;AAAA;AAChC,KACD,CAAA;AAED,IAAA,GAAA,CAAI,YAAa,CAAA;AAAA,MACf,IAAM,EAAA;AAAA,QACJ,YAAYC,6BAAa,CAAA,UAAA;AAAA,QACzB,QAAQA,6BAAa,CAAA,MAAA;AAAA,QACrB,YAAYA,6BAAa,CAAA,UAAA;AAAA,QACzB,UAAUA,6BAAa,CAAA,QAAA;AAAA,QACvB,WAAWA,6BAAa,CAAA,SAAA;AAAA,QACxB,WAAWA,6BAAa,CAAA,SAAA;AAAA,QACxB,MAAMA,6BAAa,CAAA;AAAA,OACrB;AAAA,MACA,MAAM,KAAK,OAAS,EAAA;AAClB,QAAA,MAAM,EAAE,QAAA,EAAU,UAAY,EAAA,MAAA,EAAW,GAAA,OAAA;AAEzC,QAAA,MAAM,aAA+B,GAAA;AAAA,UACnC,GAAG,OAAA;AAAA,UACH,iBAAiB,MAAMC,+BAAA,CAAgB,OAAO,EAAE,QAAA,EAAU,QAAQ,CAAA;AAAA,UAClE,QAAA;AAAA,UACA;AAAA,SACF;AACA,QAAA,MAAMC,gBAAiB,GAAA,MAAMC,6BAAe,CAAA,IAAA,CAAK,aAAa,CAAA;AAE9D,QAAM,MAAAC,uBAAA,CAAgBF,kBAAgB,aAAa,CAAA;AACnD,QAAA,MAAMG,gCAAoB,aAAa,CAAA;AAEvC,QAAA,UAAA,CAAW,GAAI,CAAA,MAAMC,mBAAa,CAAAJ,gBAAA,EAAgB,aAAa,CAAC,CAAA;AAChE,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
+ {"version":3,"file":"plugin.cjs.js","sources":["../src/plugin.ts"],"sourcesContent":["import {\n coreServices,\n createBackendPlugin,\n} from '@backstage/backend-plugin-api';\nimport { createRouter } from './service/router';\nimport { RenovateWrapper } from '@secustor/backstage-plugin-renovate-common';\nimport { RenovateRunner } from './wrapper';\nimport { RouterOptions } from './service/types';\nimport { DatabaseHandler } from './service/databaseHandler';\nimport {\n QueueFactory,\n renovateQueueExtensionPoint,\n renovateRuntimeExtensionPoint,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\nimport { scheduleJobSync } from './service/jobSync';\nimport { scheduleCleanupTask } from './service/cleanupTask';\n\n/**\n * Renovate backend plugin\n *\n * @public\n */\nexport const renovatePlugin = createBackendPlugin({\n pluginId: 'renovate',\n register(env) {\n // allow modules provide additional runtimes\n const runtimes = new Map<string, RenovateWrapper>();\n env.registerExtensionPoint(renovateRuntimeExtensionPoint, {\n addRuntime(id: string, runtime: RenovateWrapper) {\n if (runtimes.has(id)) {\n throw new Error(\n ` ${id} has been already registered. Only one wrapper with the same ID is allowed to be registered`,\n );\n }\n runtimes.set(id, runtime);\n },\n });\n\n const queueFactories = new Map<string, QueueFactory<RunOptions>>();\n env.registerExtensionPoint(renovateQueueExtensionPoint, {\n addQueueFactory(id: string, factory: QueueFactory<RunOptions>) {\n if (queueFactories.has(id)) {\n throw new Error(\n ` ${id} has been already registered. Only one queue with the same ID is allowed to be registered`,\n );\n }\n queueFactories.set(id, factory);\n },\n });\n\n env.registerInit({\n deps: {\n rootConfig: coreServices.rootConfig,\n logger: coreServices.logger,\n httpRouter: coreServices.httpRouter,\n database: coreServices.database,\n scheduler: coreServices.scheduler,\n discovery: coreServices.discovery,\n auth: coreServices.auth,\n },\n async init(options) {\n const { database, httpRouter, logger } = options;\n\n const routerOptions: RouterOptions = {\n ...options,\n databaseHandler: await DatabaseHandler.create({ database, logger }),\n runtimes,\n queueFactories,\n };\n const renovateRunner = await RenovateRunner.from(routerOptions);\n\n await scheduleJobSync(renovateRunner, routerOptions);\n await scheduleCleanupTask(routerOptions);\n\n httpRouter.use(await createRouter(renovateRunner, routerOptions));\n httpRouter.addAuthPolicy({\n path: '/health',\n allow: 'unauthenticated',\n });\n },\n });\n },\n});\n"],"names":["createBackendPlugin","renovateRuntimeExtensionPoint","renovateQueueExtensionPoint","coreServices","DatabaseHandler","renovateRunner","RenovateRunner","scheduleJobSync","scheduleCleanupTask","createRouter"],"mappings":";;;;;;;;;;AAuBO,MAAM,iBAAiBA,oCAAA,CAAoB;AAAA,EAChD,QAAA,EAAU,UAAA;AAAA,EACV,SAAS,GAAA,EAAK;AAEZ,IAAA,MAAM,QAAA,uBAAe,GAAA,EAA6B;AAClD,IAAA,GAAA,CAAI,uBAAuBC,yDAAA,EAA+B;AAAA,MACxD,UAAA,CAAW,IAAY,OAAA,EAA0B;AAC/C,QAAA,IAAI,QAAA,CAAS,GAAA,CAAI,EAAE,CAAA,EAAG;AACpB,UAAA,MAAM,IAAI,KAAA;AAAA,YACR,IAAI,EAAE,CAAA,2FAAA;AAAA,WACR;AAAA,QACF;AACA,QAAA,QAAA,CAAS,GAAA,CAAI,IAAI,OAAO,CAAA;AAAA,MAC1B;AAAA,KACD,CAAA;AAED,IAAA,MAAM,cAAA,uBAAqB,GAAA,EAAsC;AACjE,IAAA,GAAA,CAAI,uBAAuBC,uDAAA,EAA6B;AAAA,MACtD,eAAA,CAAgB,IAAY,OAAA,EAAmC;AAC7D,QAAA,IAAI,cAAA,CAAe,GAAA,CAAI,EAAE,CAAA,EAAG;AAC1B,UAAA,MAAM,IAAI,KAAA;AAAA,YACR,IAAI,EAAE,CAAA,yFAAA;AAAA,WACR;AAAA,QACF;AACA,QAAA,cAAA,CAAe,GAAA,CAAI,IAAI,OAAO,CAAA;AAAA,MAChC;AAAA,KACD,CAAA;AAED,IAAA,GAAA,CAAI,YAAA,CAAa;AAAA,MACf,IAAA,EAAM;AAAA,QACJ,YAAYC,6BAAA,CAAa,UAAA;AAAA,QACzB,QAAQA,6BAAA,CAAa,MAAA;AAAA,QACrB,YAAYA,6BAAA,CAAa,UAAA;AAAA,QACzB,UAAUA,6BAAA,CAAa,QAAA;AAAA,QACvB,WAAWA,6BAAA,CAAa,SAAA;AAAA,QACxB,WAAWA,6BAAA,CAAa,SAAA;AAAA,QACxB,MAAMA,6BAAA,CAAa;AAAA,OACrB;AAAA,MACA,MAAM,KAAK,OAAA,EAAS;AAClB,QAAA,MAAM,EAAE,QAAA,EAAU,UAAA,EAAY,MAAA,EAAO,GAAI,OAAA;AAEzC,QAAA,MAAM,aAAA,GAA+B;AAAA,UACnC,GAAG,OAAA;AAAA,UACH,iBAAiB,MAAMC,+BAAA,CAAgB,OAAO,EAAE,QAAA,EAAU,QAAQ,CAAA;AAAA,UAClE,QAAA;AAAA,UACA;AAAA,SACF;AACA,QAAA,MAAMC,gBAAA,GAAiB,MAAMC,6BAAA,CAAe,IAAA,CAAK,aAAa,CAAA;AAE9D,QAAA,MAAMC,uBAAA,CAAgBF,kBAAgB,aAAa,CAAA;AACnD,QAAA,MAAMG,gCAAoB,aAAa,CAAA;AAEvC,QAAA,UAAA,CAAW,GAAA,CAAI,MAAMC,mBAAA,CAAaJ,gBAAA,EAAgB,aAAa,CAAC,CAAA;AAChE,QAAA,UAAA,CAAW,aAAA,CAAc;AAAA,UACvB,IAAA,EAAM,SAAA;AAAA,UACN,KAAA,EAAO;AAAA,SACR,CAAA;AAAA,MACH;AAAA,KACD,CAAA;AAAA,EACH;AACF,CAAC;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"factory.cjs.js","sources":["../../src/queue/factory.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport { getPluginConfig } from '../config';\nimport {\n QueueFactory,\n RenovateQueue,\n Runnable,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport function createQueue<T extends object>(\n queues: Map<string, QueueFactory<T>>,\n rootConfig: Config,\n runnable: Runnable<T>,\n): RenovateQueue<T> {\n const type = getPluginConfig(rootConfig).getString('queue.type');\n\n const factory = queues.get(type);\n if (!factory) {\n throw new Error(`Could not find Queue implementation ${type}`);\n }\n\n return factory(runnable);\n}\n"],"names":["getPluginConfig"],"mappings":";;;;AAQgB,SAAA,WAAA,CACd,MACA,EAAA,UAAA,EACA,QACkB,EAAA;AAClB,EAAA,MAAM,IAAO,GAAAA,qBAAA,CAAgB,UAAU,CAAA,CAAE,UAAU,YAAY,CAAA;AAE/D,EAAM,MAAA,OAAA,GAAU,MAAO,CAAA,GAAA,CAAI,IAAI,CAAA;AAC/B,EAAA,IAAI,CAAC,OAAS,EAAA;AACZ,IAAA,MAAM,IAAI,KAAA,CAAM,CAAuC,oCAAA,EAAA,IAAI,CAAE,CAAA,CAAA;AAAA;AAG/D,EAAA,OAAO,QAAQ,QAAQ,CAAA;AACzB;;;;"}
1
+ {"version":3,"file":"factory.cjs.js","sources":["../../src/queue/factory.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport { getPluginConfig } from '../config';\nimport {\n QueueFactory,\n RenovateQueue,\n Runnable,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport function createQueue<T extends object>(\n queues: Map<string, QueueFactory<T>>,\n rootConfig: Config,\n runnable: Runnable<T>,\n): RenovateQueue<T> {\n const type = getPluginConfig(rootConfig).getString('queue.type');\n\n const factory = queues.get(type);\n if (!factory) {\n throw new Error(`Could not find Queue implementation ${type}`);\n }\n\n return factory(runnable);\n}\n"],"names":["getPluginConfig"],"mappings":";;;;AAQO,SAAS,WAAA,CACd,MAAA,EACA,UAAA,EACA,QAAA,EACkB;AAClB,EAAA,MAAM,IAAA,GAAOA,qBAAA,CAAgB,UAAU,CAAA,CAAE,UAAU,YAAY,CAAA;AAE/D,EAAA,MAAM,OAAA,GAAU,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAC/B,EAAA,IAAI,CAAC,OAAA,EAAS;AACZ,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,oCAAA,EAAuC,IAAI,CAAA,CAAE,CAAA;AAAA,EAC/D;AAEA,EAAA,OAAO,QAAQ,QAAQ,CAAA;AACzB;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"router.cjs.js","sources":["../../../../src/schema/openapi/generated/router.ts"],"sourcesContent":["//\n\n// ******************************************************************\n// * THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. *\n// ******************************************************************\nimport { createValidatedOpenApiRouterFromGeneratedEndpointMap } from '@backstage/backend-openapi-utils';\nimport { EndpointMap } from './';\n\nexport const spec = {\n openapi: '3.0.0',\n info: {\n title: 'renovate',\n description: 'Backstage Renovate API',\n version: '0.2.0',\n },\n servers: [\n {\n description: 'local test setup',\n url: 'http://localhost:7007',\n },\n ],\n paths: {\n '/reports': {\n get: {\n summary: 'Get all reports',\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/reports/{host}': {\n get: {\n summary: 'Get reports for host',\n parameters: [\n {\n name: 'host',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'github.com',\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n '404': {\n description: 'unknown host',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/reports/{host}/{repository}': {\n get: {\n summary: 'Get reports for repository',\n parameters: [\n {\n name: 'host',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'github.com',\n },\n },\n {\n name: 'repository',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'myOrg/myRepository',\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n '404': {\n description: 'unknown repository',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/dependencies': {\n get: {\n summary: 'Get dependencies for host',\n parameters: [\n {\n name: 'pageSize',\n in: 'query',\n description: 'size of the page',\n schema: {\n type: 'number',\n default: 100,\n },\n },\n {\n name: 'page',\n in: 'query',\n description: 'page number. starting with 0',\n schema: {\n type: 'number',\n },\n },\n {\n name: 'availableValues',\n in: 'query',\n description:\n 'if set to true, the response will include all available values for the filters',\n schema: {\n type: 'boolean',\n },\n },\n {\n name: 'datasource',\n in: 'query',\n description: 'filter by datasource',\n schema: {\n type: 'array',\n items: {\n example: 'npm,pypi',\n type: 'string',\n },\n },\n },\n {\n name: 'depName',\n in: 'query',\n description: 'filter by dependency name',\n schema: {\n type: 'array',\n items: {\n example: 'pdm,react',\n type: 'string',\n },\n },\n },\n {\n name: 'depType',\n in: 'query',\n description: 'filter by dependency type',\n schema: {\n type: 'array',\n items: {\n example: 'dev,prod',\n type: 'string',\n },\n },\n },\n {\n name: 'host',\n in: 'query',\n schema: {\n type: 'array',\n example: 'github.com,gitlab.example.com',\n items: {\n type: 'string',\n },\n },\n },\n {\n name: 'latestOnly',\n in: 'query',\n description:\n 'include only dependencies which have been found in the last extraction',\n schema: {\n type: 'boolean',\n },\n },\n {\n name: 'manager',\n in: 'query',\n description: 'filter by manager',\n schema: {\n type: 'array',\n items: {\n example: 'npm,composer',\n type: 'string',\n },\n },\n },\n {\n name: 'packageFile',\n in: 'query',\n description: 'filter by package file',\n schema: {\n type: 'array',\n items: {\n example: 'package.json,composer.json',\n type: 'string',\n },\n },\n },\n {\n name: 'repository',\n in: 'query',\n schema: {\n type: 'array',\n example: 'myOrg/myRepository,myOrg/myOtherRepository',\n items: {\n type: 'string',\n },\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/dependencies',\n },\n '404': {\n description: 'unknown host',\n },\n },\n },\n },\n '/runs': {\n post: {\n summary: 'Start or get Renovate runs',\n requestBody: {\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n required: ['target'],\n properties: {\n target: {\n $ref: '#/components/schemas/target',\n },\n },\n },\n },\n },\n },\n responses: {\n '202': {\n description: 'Run has been scheduled',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n taskID: {\n description: 'id of the scheduler task',\n type: 'string',\n example: '9-d_CO9JlaEmd-OM9QfkI',\n },\n },\n },\n },\n },\n },\n '400': {\n description: 'Unexpected incoming data',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n error: {\n $ref: '#/components/schemas/error',\n },\n },\n },\n },\n },\n },\n },\n },\n },\n },\n components: {\n parameters: {\n keepLatest: {\n name: 'keepLatest',\n description: 'how many reports of all targets should be kept',\n in: 'query',\n required: false,\n example: 3,\n schema: {\n type: 'number',\n },\n },\n },\n responses: {\n dependencies: {\n description: 'Returns dependencies',\n headers: {\n 'X-Total-Count': {\n schema: {\n type: 'integer',\n description: 'Total number of entries',\n },\n },\n 'X-Page-Count': {\n schema: {\n type: 'integer',\n description: 'Total number of pages',\n },\n },\n 'X-Current-Page': {\n schema: {\n type: 'integer',\n description: 'Current page',\n },\n },\n 'X-Page-Size': {\n schema: {\n type: 'integer',\n description: 'Number of entries per page',\n },\n },\n },\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n required: ['dependencies'],\n properties: {\n dependencies: {\n type: 'array',\n items: {\n $ref: '#/components/schemas/dependency',\n },\n },\n availableValues: {\n type: 'object',\n description:\n 'Will only be part of the response if `availableValues` is true. Returns all available values for the applied filters\\n',\n properties: {\n datasource: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n depName: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n depType: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n host: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n manager: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n packageFile: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n repository: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n },\n },\n },\n },\n },\n },\n },\n 'deleted-successful': {\n description: 'Successful deleted',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n modified: {\n type: 'number',\n example: 15,\n description: 'Numbers of reports deleted',\n },\n },\n },\n },\n },\n },\n reports: {\n description: 'Returns reports',\n content: {\n 'application/json': {\n schema: {\n type: 'array',\n items: {\n type: 'object',\n additionalProperties: false,\n required: [\n 'taskID',\n 'repository',\n 'host',\n 'timestamp',\n 'report',\n ],\n properties: {\n taskID: {\n type: 'string',\n },\n timestamp: {\n type: 'string',\n format: 'date-time',\n },\n host: {\n type: 'string',\n },\n repository: {\n type: 'string',\n },\n report: {\n $ref: '#/components/schemas/repositoryReport',\n },\n },\n },\n },\n },\n },\n },\n },\n schemas: {\n error: {\n anyOf: [\n {\n type: 'object',\n example: {\n message: \"I'm an error\",\n code: 1111,\n },\n },\n {\n type: 'string',\n example: \"I'm an error\",\n },\n ],\n },\n target: {\n anyOf: [\n {\n type: 'string',\n description: 'URL to an repository',\n example: 'https://github.com/secustor/renovate-test',\n },\n {\n type: 'string',\n description:\n 'stringified Entity with SourceLocation URL annotation',\n example: 'component:default/backstage-plugins-example',\n },\n {\n type: 'string',\n description: 'host and path',\n example: 'secustor/backstage-plugins',\n },\n ],\n },\n repositoryReportList: {\n type: 'array',\n items: {\n $ref: '#/components/schemas/repositoryReport',\n },\n },\n repositoryReport: {\n description: 'report for a specific repository',\n type: 'object',\n additionalProperties: false,\n required: ['branches', 'packageFiles', 'problems'],\n properties: {\n branches: {\n type: 'array',\n items: {\n type: 'object',\n },\n },\n packageFiles: {\n type: 'object',\n },\n problems: {\n type: 'array',\n items: {\n type: 'object',\n },\n },\n },\n },\n dependency: {\n type: 'object',\n additionalProperties: false,\n required: [\n 'id',\n 'runID',\n 'host',\n 'repository',\n 'extractionTimestamp',\n 'manager',\n 'datasource',\n 'packageFile',\n 'depName',\n ],\n properties: {\n id: {\n type: 'string',\n },\n runID: {\n type: 'string',\n },\n host: {\n type: 'string',\n },\n repository: {\n type: 'string',\n },\n extractionTimestamp: {\n type: 'string',\n format: 'date-time',\n },\n manager: {\n type: 'string',\n },\n datasource: {\n type: 'string',\n },\n packageFile: {\n type: 'string',\n },\n packageFileUrl: {\n type: 'string',\n },\n depName: {\n type: 'string',\n },\n packageName: {\n type: 'string',\n },\n depType: {\n type: 'string',\n },\n currentValue: {\n type: 'string',\n },\n currentVersion: {\n type: 'string',\n },\n currentVersionTimestamp: {\n type: 'string',\n format: 'date-time',\n },\n skipReason: {\n type: 'string',\n },\n registryUrl: {\n type: 'string',\n },\n sourceUrl: {\n type: 'string',\n },\n },\n },\n },\n },\n} as const;\nexport const createOpenApiRouter = async (\n options?: Parameters<\n typeof createValidatedOpenApiRouterFromGeneratedEndpointMap\n >['1'],\n) =>\n createValidatedOpenApiRouterFromGeneratedEndpointMap<EndpointMap>(\n spec,\n options,\n );\n"],"names":["createValidatedOpenApiRouterFromGeneratedEndpointMap"],"mappings":"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"}
1
+ {"version":3,"file":"router.cjs.js","sources":["../../../../src/schema/openapi/generated/router.ts"],"sourcesContent":["//\n\n// ******************************************************************\n// * THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. *\n// ******************************************************************\nimport { createValidatedOpenApiRouterFromGeneratedEndpointMap } from '@backstage/backend-openapi-utils';\nimport { EndpointMap } from './';\n\nexport const spec = {\n openapi: '3.0.0',\n info: {\n title: 'renovate',\n description: 'Backstage Renovate API',\n version: '0.2.0',\n },\n servers: [\n {\n description: 'local test setup',\n url: 'http://localhost:7007',\n },\n ],\n paths: {\n '/reports': {\n get: {\n summary: 'Get all reports',\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/reports/{host}': {\n get: {\n summary: 'Get reports for host',\n parameters: [\n {\n name: 'host',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'github.com',\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n '404': {\n description: 'unknown host',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/reports/{host}/{repository}': {\n get: {\n summary: 'Get reports for repository',\n parameters: [\n {\n name: 'host',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'github.com',\n },\n },\n {\n name: 'repository',\n in: 'path',\n required: true,\n schema: {\n type: 'string',\n example: 'myOrg/myRepository',\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/reports',\n },\n '404': {\n description: 'unknown repository',\n },\n },\n },\n delete: {\n summary: 'Delete reports based on parameters',\n parameters: [\n {\n $ref: '#/components/parameters/keepLatest',\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/deleted-successful',\n },\n },\n },\n },\n '/dependencies': {\n get: {\n summary: 'Get dependencies for host',\n parameters: [\n {\n name: 'pageSize',\n in: 'query',\n description: 'size of the page',\n schema: {\n type: 'number',\n default: 100,\n },\n },\n {\n name: 'page',\n in: 'query',\n description: 'page number. starting with 0',\n schema: {\n type: 'number',\n },\n },\n {\n name: 'availableValues',\n in: 'query',\n description:\n 'if set to true, the response will include all available values for the filters',\n schema: {\n type: 'boolean',\n },\n },\n {\n name: 'datasource',\n in: 'query',\n description: 'filter by datasource',\n schema: {\n type: 'array',\n items: {\n example: 'npm,pypi',\n type: 'string',\n },\n },\n },\n {\n name: 'depName',\n in: 'query',\n description: 'filter by dependency name',\n schema: {\n type: 'array',\n items: {\n example: 'pdm,react',\n type: 'string',\n },\n },\n },\n {\n name: 'depType',\n in: 'query',\n description: 'filter by dependency type',\n schema: {\n type: 'array',\n items: {\n example: 'dev,prod',\n type: 'string',\n },\n },\n },\n {\n name: 'host',\n in: 'query',\n schema: {\n type: 'array',\n example: 'github.com,gitlab.example.com',\n items: {\n type: 'string',\n },\n },\n },\n {\n name: 'latestOnly',\n in: 'query',\n description:\n 'include only dependencies which have been found in the last extraction',\n schema: {\n type: 'boolean',\n },\n },\n {\n name: 'manager',\n in: 'query',\n description: 'filter by manager',\n schema: {\n type: 'array',\n items: {\n example: 'npm,composer',\n type: 'string',\n },\n },\n },\n {\n name: 'packageFile',\n in: 'query',\n description: 'filter by package file',\n schema: {\n type: 'array',\n items: {\n example: 'package.json,composer.json',\n type: 'string',\n },\n },\n },\n {\n name: 'repository',\n in: 'query',\n schema: {\n type: 'array',\n example: 'myOrg/myRepository,myOrg/myOtherRepository',\n items: {\n type: 'string',\n },\n },\n },\n ],\n responses: {\n '200': {\n $ref: '#/components/responses/dependencies',\n },\n '404': {\n description: 'unknown host',\n },\n },\n },\n },\n '/runs': {\n post: {\n summary: 'Start or get Renovate runs',\n requestBody: {\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n required: ['target'],\n properties: {\n target: {\n $ref: '#/components/schemas/target',\n },\n },\n },\n },\n },\n },\n responses: {\n '202': {\n description: 'Run has been scheduled',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n taskID: {\n description: 'id of the scheduler task',\n type: 'string',\n example: '9-d_CO9JlaEmd-OM9QfkI',\n },\n },\n },\n },\n },\n },\n '400': {\n description: 'Unexpected incoming data',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n error: {\n $ref: '#/components/schemas/error',\n },\n },\n },\n },\n },\n },\n },\n },\n },\n },\n components: {\n parameters: {\n keepLatest: {\n name: 'keepLatest',\n description: 'how many reports of all targets should be kept',\n in: 'query',\n required: false,\n example: 3,\n schema: {\n type: 'number',\n },\n },\n },\n responses: {\n dependencies: {\n description: 'Returns dependencies',\n headers: {\n 'X-Total-Count': {\n schema: {\n type: 'integer',\n description: 'Total number of entries',\n },\n },\n 'X-Page-Count': {\n schema: {\n type: 'integer',\n description: 'Total number of pages',\n },\n },\n 'X-Current-Page': {\n schema: {\n type: 'integer',\n description: 'Current page',\n },\n },\n 'X-Page-Size': {\n schema: {\n type: 'integer',\n description: 'Number of entries per page',\n },\n },\n },\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n required: ['dependencies'],\n properties: {\n dependencies: {\n type: 'array',\n items: {\n $ref: '#/components/schemas/dependency',\n },\n },\n availableValues: {\n type: 'object',\n description:\n 'Will only be part of the response if `availableValues` is true. Returns all available values for the applied filters\\n',\n properties: {\n datasource: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n depName: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n depType: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n host: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n manager: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n packageFile: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n repository: {\n type: 'array',\n items: {\n type: 'string',\n },\n },\n },\n },\n },\n },\n },\n },\n },\n 'deleted-successful': {\n description: 'Successful deleted',\n content: {\n 'application/json': {\n schema: {\n type: 'object',\n properties: {\n modified: {\n type: 'number',\n example: 15,\n description: 'Numbers of reports deleted',\n },\n },\n },\n },\n },\n },\n reports: {\n description: 'Returns reports',\n content: {\n 'application/json': {\n schema: {\n type: 'array',\n items: {\n type: 'object',\n additionalProperties: false,\n required: [\n 'taskID',\n 'repository',\n 'host',\n 'timestamp',\n 'report',\n ],\n properties: {\n taskID: {\n type: 'string',\n },\n timestamp: {\n type: 'string',\n format: 'date-time',\n },\n host: {\n type: 'string',\n },\n repository: {\n type: 'string',\n },\n report: {\n $ref: '#/components/schemas/repositoryReport',\n },\n },\n },\n },\n },\n },\n },\n },\n schemas: {\n error: {\n anyOf: [\n {\n type: 'object',\n example: {\n message: \"I'm an error\",\n code: 1111,\n },\n },\n {\n type: 'string',\n example: \"I'm an error\",\n },\n ],\n },\n target: {\n anyOf: [\n {\n type: 'string',\n description: 'URL to an repository',\n example: 'https://github.com/secustor/renovate-test',\n },\n {\n type: 'string',\n description:\n 'stringified Entity with SourceLocation URL annotation',\n example: 'component:default/backstage-plugins-example',\n },\n {\n type: 'string',\n description: 'host and path',\n example: 'secustor/backstage-plugins',\n },\n ],\n },\n repositoryReportList: {\n type: 'array',\n items: {\n $ref: '#/components/schemas/repositoryReport',\n },\n },\n repositoryReport: {\n description: 'report for a specific repository',\n type: 'object',\n additionalProperties: false,\n required: ['branches', 'packageFiles', 'problems'],\n properties: {\n branches: {\n type: 'array',\n items: {\n type: 'object',\n },\n },\n packageFiles: {\n type: 'object',\n },\n problems: {\n type: 'array',\n items: {\n type: 'object',\n },\n },\n },\n },\n dependency: {\n type: 'object',\n additionalProperties: false,\n required: [\n 'id',\n 'runID',\n 'host',\n 'repository',\n 'extractionTimestamp',\n 'manager',\n 'datasource',\n 'packageFile',\n 'depName',\n ],\n properties: {\n id: {\n type: 'string',\n },\n runID: {\n type: 'string',\n },\n host: {\n type: 'string',\n },\n repository: {\n type: 'string',\n },\n extractionTimestamp: {\n type: 'string',\n format: 'date-time',\n },\n manager: {\n type: 'string',\n },\n datasource: {\n type: 'string',\n },\n packageFile: {\n type: 'string',\n },\n packageFileUrl: {\n type: 'string',\n },\n depName: {\n type: 'string',\n },\n packageName: {\n type: 'string',\n },\n depType: {\n type: 'string',\n },\n currentValue: {\n type: 'string',\n },\n currentVersion: {\n type: 'string',\n },\n currentVersionTimestamp: {\n type: 'string',\n format: 'date-time',\n },\n skipReason: {\n type: 'string',\n },\n registryUrl: {\n type: 'string',\n },\n sourceUrl: {\n type: 'string',\n },\n },\n },\n },\n },\n} as const;\nexport const createOpenApiRouter = async (\n options?: Parameters<\n typeof createValidatedOpenApiRouterFromGeneratedEndpointMap\n >['1'],\n) =>\n createValidatedOpenApiRouterFromGeneratedEndpointMap<EndpointMap>(\n spec,\n options,\n );\n"],"names":["createValidatedOpenApiRouterFromGeneratedEndpointMap"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"cleanupTask.cjs.js","sources":["../../src/service/cleanupTask.ts"],"sourcesContent":["import { RouterOptions } from './types';\nimport { getPluginConfig, getScheduleDefinition } from '../config';\n\nexport async function scheduleCleanupTask(routerOptions: RouterOptions) {\n const { scheduler, rootConfig, databaseHandler, logger } = routerOptions;\n const pluginConfig = getPluginConfig(rootConfig);\n const schedule = getScheduleDefinition(pluginConfig, 'cleanup');\n if (!schedule.enabled) {\n return Promise.resolve();\n }\n\n const reportsToKeep =\n pluginConfig.getOptionalNumber('cleanup.minimumReports') ?? -1;\n\n const dependencyHistoryKeep =\n pluginConfig.getOptionalNumber('cleanup.dependencyHistory') ?? -1;\n\n return scheduler.scheduleTask({\n id: `renovate_report_cleanup`,\n ...schedule,\n fn: async () => {\n if (reportsToKeep >= 0) {\n logger.debug('Running report cleanup');\n const modified = await databaseHandler.deleteReports({\n keepLatest: reportsToKeep,\n });\n logger.debug(`Report cleanup completed. ${modified} reports deleted`);\n }\n if (dependencyHistoryKeep >= 0) {\n logger.debug('Running dependency history cleanup');\n const modified = await databaseHandler.deleteDependencies({\n keepLatest: dependencyHistoryKeep,\n });\n logger.debug(\n `Dependency history cleanup completed. ${modified} dependencies deleted`,\n );\n }\n },\n });\n}\n"],"names":["getPluginConfig","getScheduleDefinition"],"mappings":";;;;AAGA,eAAsB,oBAAoB,aAA8B,EAAA;AACtE,EAAA,MAAM,EAAE,SAAA,EAAW,UAAY,EAAA,eAAA,EAAiB,QAAW,GAAA,aAAA;AAC3D,EAAM,MAAA,YAAA,GAAeA,sBAAgB,UAAU,CAAA;AAC/C,EAAM,MAAA,QAAA,GAAWC,2BAAsB,CAAA,YAAA,EAAc,SAAS,CAAA;AAC9D,EAAI,IAAA,CAAC,SAAS,OAAS,EAAA;AACrB,IAAA,OAAO,QAAQ,OAAQ,EAAA;AAAA;AAGzB,EAAA,MAAM,aACJ,GAAA,YAAA,CAAa,iBAAkB,CAAA,wBAAwB,CAAK,IAAA,EAAA;AAE9D,EAAA,MAAM,qBACJ,GAAA,YAAA,CAAa,iBAAkB,CAAA,2BAA2B,CAAK,IAAA,EAAA;AAEjE,EAAA,OAAO,UAAU,YAAa,CAAA;AAAA,IAC5B,EAAI,EAAA,CAAA,uBAAA,CAAA;AAAA,IACJ,GAAG,QAAA;AAAA,IACH,IAAI,YAAY;AACd,MAAA,IAAI,iBAAiB,CAAG,EAAA;AACtB,QAAA,MAAA,CAAO,MAAM,wBAAwB,CAAA;AACrC,QAAM,MAAA,QAAA,GAAW,MAAM,eAAA,CAAgB,aAAc,CAAA;AAAA,UACnD,UAAY,EAAA;AAAA,SACb,CAAA;AACD,QAAO,MAAA,CAAA,KAAA,CAAM,CAA6B,0BAAA,EAAA,QAAQ,CAAkB,gBAAA,CAAA,CAAA;AAAA;AAEtE,MAAA,IAAI,yBAAyB,CAAG,EAAA;AAC9B,QAAA,MAAA,CAAO,MAAM,oCAAoC,CAAA;AACjD,QAAM,MAAA,QAAA,GAAW,MAAM,eAAA,CAAgB,kBAAmB,CAAA;AAAA,UACxD,UAAY,EAAA;AAAA,SACb,CAAA;AACD,QAAO,MAAA,CAAA,KAAA;AAAA,UACL,yCAAyC,QAAQ,CAAA,qBAAA;AAAA,SACnD;AAAA;AACF;AACF,GACD,CAAA;AACH;;;;"}
1
+ {"version":3,"file":"cleanupTask.cjs.js","sources":["../../src/service/cleanupTask.ts"],"sourcesContent":["import { RouterOptions } from './types';\nimport { getPluginConfig, getScheduleDefinition } from '../config';\n\nexport async function scheduleCleanupTask(routerOptions: RouterOptions) {\n const { scheduler, rootConfig, databaseHandler, logger } = routerOptions;\n const pluginConfig = getPluginConfig(rootConfig);\n const schedule = getScheduleDefinition(pluginConfig, 'cleanup');\n if (!schedule.enabled) {\n return Promise.resolve();\n }\n\n const reportsToKeep =\n pluginConfig.getOptionalNumber('cleanup.minimumReports') ?? -1;\n\n const dependencyHistoryKeep =\n pluginConfig.getOptionalNumber('cleanup.dependencyHistory') ?? -1;\n\n return scheduler.scheduleTask({\n id: `renovate_report_cleanup`,\n ...schedule,\n fn: async () => {\n if (reportsToKeep >= 0) {\n logger.debug('Running report cleanup');\n const modified = await databaseHandler.deleteReports({\n keepLatest: reportsToKeep,\n });\n logger.debug(`Report cleanup completed. ${modified} reports deleted`);\n }\n if (dependencyHistoryKeep >= 0) {\n logger.debug('Running dependency history cleanup');\n const modified = await databaseHandler.deleteDependencies({\n keepLatest: dependencyHistoryKeep,\n });\n logger.debug(\n `Dependency history cleanup completed. ${modified} dependencies deleted`,\n );\n }\n },\n });\n}\n"],"names":["getPluginConfig","getScheduleDefinition"],"mappings":";;;;AAGA,eAAsB,oBAAoB,aAAA,EAA8B;AACtE,EAAA,MAAM,EAAE,SAAA,EAAW,UAAA,EAAY,eAAA,EAAiB,QAAO,GAAI,aAAA;AAC3D,EAAA,MAAM,YAAA,GAAeA,sBAAgB,UAAU,CAAA;AAC/C,EAAA,MAAM,QAAA,GAAWC,2BAAA,CAAsB,YAAA,EAAc,SAAS,CAAA;AAC9D,EAAA,IAAI,CAAC,SAAS,OAAA,EAAS;AACrB,IAAA,OAAO,QAAQ,OAAA,EAAQ;AAAA,EACzB;AAEA,EAAA,MAAM,aAAA,GACJ,YAAA,CAAa,iBAAA,CAAkB,wBAAwB,CAAA,IAAK,EAAA;AAE9D,EAAA,MAAM,qBAAA,GACJ,YAAA,CAAa,iBAAA,CAAkB,2BAA2B,CAAA,IAAK,EAAA;AAEjE,EAAA,OAAO,UAAU,YAAA,CAAa;AAAA,IAC5B,EAAA,EAAI,CAAA,uBAAA,CAAA;AAAA,IACJ,GAAG,QAAA;AAAA,IACH,IAAI,YAAY;AACd,MAAA,IAAI,iBAAiB,CAAA,EAAG;AACtB,QAAA,MAAA,CAAO,MAAM,wBAAwB,CAAA;AACrC,QAAA,MAAM,QAAA,GAAW,MAAM,eAAA,CAAgB,aAAA,CAAc;AAAA,UACnD,UAAA,EAAY;AAAA,SACb,CAAA;AACD,QAAA,MAAA,CAAO,KAAA,CAAM,CAAA,0BAAA,EAA6B,QAAQ,CAAA,gBAAA,CAAkB,CAAA;AAAA,MACtE;AACA,MAAA,IAAI,yBAAyB,CAAA,EAAG;AAC9B,QAAA,MAAA,CAAO,MAAM,oCAAoC,CAAA;AACjD,QAAA,MAAM,QAAA,GAAW,MAAM,eAAA,CAAgB,kBAAA,CAAmB;AAAA,UACxD,UAAA,EAAY;AAAA,SACb,CAAA;AACD,QAAA,MAAA,CAAO,KAAA;AAAA,UACL,yCAAyC,QAAQ,CAAA,qBAAA;AAAA,SACnD;AAAA,MACF;AAAA,IACF;AAAA,GACD,CAAA;AACH;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"databaseHandler.cjs.js","sources":["../../src/service/databaseHandler.ts"],"sourcesContent":["import {\n LoggerService,\n resolvePackagePath,\n} from '@backstage/backend-plugin-api';\nimport { Knex } from 'knex';\nimport {\n AddReportParameters,\n DatabaseCreationParameters,\n DeleteOptions,\n DependenciesFilter,\n DependencyRow,\n DependencyValueFilters,\n DependencyValueFiltersKey,\n DependencyValueFiltersKeys,\n DependencyValues,\n Pagination,\n PaginationOptions,\n ReportQueryParameters,\n ReportsRow,\n ReportTargetQuery,\n} from './types';\nimport is from '@sindresorhus/is';\nimport { RepositoryReportResponse } from '@secustor/backstage-plugin-renovate-common';\n\nconst migrationsDir = resolvePackagePath(\n '@secustor/backstage-plugin-renovate-backend',\n 'migrations',\n);\n\nexport class DatabaseHandler {\n static async create(\n options: DatabaseCreationParameters,\n ): Promise<DatabaseHandler> {\n const { database, logger } = options;\n const client = await database.getClient();\n\n if (!database.migrations?.skip) {\n await client.migrate.latest({\n directory: migrationsDir,\n });\n }\n\n return new DatabaseHandler(client, logger);\n }\n\n private constructor(\n private client: Knex,\n private logger: LoggerService,\n ) {}\n\n async addReport(options: AddReportParameters): Promise<void> {\n const { runID, taskID, report, target } = options;\n const logger = options.logger ?? this.logger;\n\n const timestamp = new Date();\n\n const inserts: ReportsRow[] = [];\n for (const [repository, value] of Object.entries(report.repositories)) {\n inserts.push({\n run_id: runID,\n task_id: taskID,\n timestamp,\n host: target.host,\n repository,\n report: value,\n });\n }\n // this.client.batchInsert<ReportsRow>('reports', inserts);\n await this.client('reports')\n .insert(inserts)\n .catch(reason => logger.error('Failed insert data', reason));\n\n await this.updateDependencies(timestamp, options);\n }\n\n async getReports(\n query?: ReportQueryParameters,\n ): Promise<RepositoryReportResponse> {\n const builder = this.client.select<ReportsRow[]>();\n if (query) {\n builder.where(query);\n }\n const rows = await builder.from<ReportsRow[]>('reports');\n return rows.map(row => {\n return {\n runID: row.run_id,\n taskID: row.task_id,\n timestamp: row.timestamp,\n host: row.host,\n repository: row.repository,\n // if the JSON field has not been auto-parsed do it manually\n report: is.string(row.report) ? JSON.parse(row.report) : row.report,\n };\n });\n }\n\n async getTargets(\n table: 'reports' | 'dependencies' = 'reports',\n ): Promise<ReportTargetQuery[]> {\n return this.client\n .select()\n .distinct<ReportsRow[]>('host', 'repository')\n .from(table);\n }\n\n async deleteReportsByTarget(\n { host, repository }: ReportTargetQuery,\n options?: DeleteOptions,\n ): Promise<number> {\n const offset = getOffset(options);\n\n const toBeDeletedIDs = this.client('reports')\n .select('run_id')\n .where('host', host)\n .andWhere('repository', repository)\n .orderBy('timestamp', 'DESC')\n .offset(offset);\n\n return this.client('reports').delete().whereIn('run_id', [toBeDeletedIDs]);\n }\n\n async deleteReports(options?: DeleteOptions): Promise<number> {\n const targets = await this.getTargets();\n const modified = await Promise.all(\n targets.map(target => this.deleteReportsByTarget(target, options)),\n );\n // sum up\n return modified.reduce((a, b) => a + b, 0);\n }\n\n private async updateDependencies(\n timestamp: Date,\n options: AddReportParameters,\n ): Promise<void> {\n const { runID, report, target } = options;\n const dependencies: DependencyRow[] = [];\n for (const [repository, repositoryContent] of Object.entries(\n report.repositories,\n )) {\n for (const [manager, packageFiles] of Object.entries(\n repositoryContent.packageFiles,\n )) {\n for (const packageFile of packageFiles) {\n const packageFilePath = packageFile.packageFile;\n for (const dependency of packageFile.deps) {\n const {\n packageName,\n depName,\n depType,\n datasource,\n currentValue,\n currentVersion,\n skipReason,\n registryUrl,\n sourceUrl,\n currentVersionTimestamp,\n } = dependency;\n\n // TODO remove this once Renovate enforces packageName\n const massagedDepName = depName ?? packageName;\n if (!massagedDepName) {\n continue;\n }\n\n dependencies.push({\n run_id: runID,\n host: target.host,\n extractionTimestamp: timestamp,\n repository,\n manager,\n datasource:\n datasource ?? packageFile.datasource ?? 'no-datasource',\n depName: massagedDepName,\n packageName,\n packageFile: packageFilePath,\n depType,\n currentValue,\n currentVersion,\n currentVersionTimestamp,\n skipReason,\n registryUrl,\n sourceUrl,\n });\n }\n }\n }\n }\n await this.client('dependencies').insert(dependencies);\n }\n\n async getDependencies(\n filters: DependenciesFilter,\n pagination?: Partial<PaginationOptions>,\n ): Promise<Pagination<DependencyRow[]>> {\n const page = pagination?.page ?? 0;\n const pageSize = pagination?.pageSize ?? 500;\n const builder = this.client('dependencies').select<DependencyRow[]>();\n\n this.applyDependencyFilters(builder, filters);\n\n const total = await this.getDependenciesCount(filters);\n\n const offset = page * pageSize;\n return {\n result: await builder.offset(offset).limit(pageSize),\n total,\n page,\n pageSize,\n pageCount: Math.ceil(total / pageSize),\n };\n }\n\n async getDependenciesCount(filters: DependenciesFilter): Promise<number> {\n const builder = this.client('dependencies').count({ count: '*' });\n\n this.applyDependencyFilters(builder, filters);\n\n const count = await builder.first().then(result => result?.count);\n if (is.string(count)) {\n return Number.parseInt(count, 10);\n }\n return count ?? 0;\n }\n\n private applyDependencyFilters(\n builder: Knex.QueryBuilder,\n filters: DependenciesFilter,\n ): void {\n if (filters.host) {\n builder.whereIn('host', filters.host);\n }\n if (filters.repository) {\n builder.whereIn('repository', filters.repository);\n }\n if (filters.manager) {\n builder.whereIn('manager', filters.manager);\n }\n if (filters.datasource) {\n builder.whereIn('datasource', filters.datasource);\n }\n if (filters.depName) {\n builder.whereIn('depName', filters.depName);\n }\n if (filters.depType) {\n builder.whereIn('depType', filters.depType);\n }\n\n if (filters.latestOnly) {\n const runIDs = this.client('dependencies')\n .select('d.run_id')\n .from('dependencies as d')\n .join(\n this.client('dependencies')\n .select('host', 'repository')\n .max('extractionTimestamp as max_timestamp')\n .groupBy('host', 'repository')\n .as('max_d'),\n // eslint-disable-next-line func-names\n function () {\n this.on('d.host', '=', 'max_d.host')\n .andOn('d.repository', '=', 'max_d.repository')\n .andOn('d.extractionTimestamp', '=', 'max_d.max_timestamp');\n },\n )\n .distinct();\n\n builder.whereIn('run_id', runIDs);\n }\n }\n\n /**\n * Gets the available values for the dependencies stored in the database.\n * If filters are supplied, OTHER values are filtered accordingly, if a filter is supplied, all values are returned\n * @param filters\n */\n async getDependenciesValues(\n filters?: DependencyValueFilters,\n ): Promise<DependencyValues> {\n const baseBuilder = this.client<DependencyRow, DependencyValueFilters>(\n 'dependencies',\n );\n const limitedValuesBuilder = baseBuilder.clone();\n\n const allValuesKeys: DependencyValueFiltersKey[] = [];\n const limitedValuesKeys: DependencyValueFiltersKey[] = [];\n for (const filterKey of DependencyValueFiltersKeys) {\n const suppliedFilter = filters?.[filterKey];\n // if no filter is supplied, return all values\n if (suppliedFilter) {\n limitedValuesBuilder.whereIn(filterKey, suppliedFilter);\n limitedValuesKeys.push(filterKey);\n continue;\n }\n\n allValuesKeys.push(filterKey);\n }\n\n const result: DependencyValues = {\n datasource: [],\n manager: [],\n depType: [],\n depName: [],\n host: [],\n packageFile: [],\n repository: [],\n };\n\n const allValues = allValuesKeys.map(\n async (filterKey: DependencyValueFiltersKey) => {\n // get all unique values for the column and do not return as object but list\n const values = await limitedValuesBuilder\n .clone()\n .select(filterKey)\n .distinct()\n .pluck(filterKey);\n result[filterKey] = values.filter(is.string);\n },\n );\n const limitedValues = limitedValuesKeys.map(async filterKey => {\n const values = await baseBuilder\n .clone()\n .select(filterKey)\n .distinct()\n .pluck(filterKey);\n\n result[filterKey] = values.filter(is.string);\n });\n await Promise.all([...allValues, ...limitedValues]);\n return result;\n }\n\n async deleteDependencies(options: DeleteOptions): Promise<number> {\n const targets = await this.getTargets('dependencies');\n const modified = await Promise.all(\n targets.map(target => this.deleteDependenciesByTarget(target, options)),\n );\n // sum up\n return modified.reduce((a, b) => a + b, 0);\n }\n\n async deleteDependenciesByTarget(\n { host, repository }: ReportTargetQuery,\n options?: DeleteOptions,\n ): Promise<number> {\n const offset = getOffset(options);\n\n const dependencies = this.client('dependencies')\n .select('run_id', 'extractionTimestamp')\n .distinct('host', 'repository')\n .where('host', host)\n .andWhere('repository', repository)\n .as('runs');\n\n const toBeDeletedIDs = this.client(dependencies)\n .select('run_id')\n .orderBy('extractionTimestamp', 'DESC')\n .offset(offset);\n\n return this.client('dependencies')\n .delete()\n .whereIn('run_id', [toBeDeletedIDs]);\n }\n}\n\nfunction getOffset(options?: DeleteOptions): number {\n let offset = 0;\n if (\n is.nullOrUndefined(options?.keepLatest) ||\n is.boolean(options?.keepLatest)\n ) {\n offset = options?.keepLatest ? 1 : 0;\n } else {\n offset = options.keepLatest;\n }\n return offset;\n}\n"],"names":["resolvePackagePath","is","DependencyValueFiltersKeys"],"mappings":"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"}
1
+ {"version":3,"file":"databaseHandler.cjs.js","sources":["../../src/service/databaseHandler.ts"],"sourcesContent":["import {\n LoggerService,\n resolvePackagePath,\n} from '@backstage/backend-plugin-api';\nimport { Knex } from 'knex';\nimport {\n AddReportParameters,\n DatabaseCreationParameters,\n DeleteOptions,\n DependenciesFilter,\n DependencyRow,\n DependencyValueFilters,\n DependencyValueFiltersKey,\n DependencyValueFiltersKeys,\n DependencyValues,\n Pagination,\n PaginationOptions,\n ReportQueryParameters,\n ReportsRow,\n ReportTargetQuery,\n} from './types';\nimport is from '@sindresorhus/is';\nimport { RepositoryReportResponse } from '@secustor/backstage-plugin-renovate-common';\n\nconst migrationsDir = resolvePackagePath(\n '@secustor/backstage-plugin-renovate-backend',\n 'migrations',\n);\n\nexport class DatabaseHandler {\n static async create(\n options: DatabaseCreationParameters,\n ): Promise<DatabaseHandler> {\n const { database, logger } = options;\n const client = await database.getClient();\n\n if (!database.migrations?.skip) {\n await client.migrate.latest({\n directory: migrationsDir,\n });\n }\n\n return new DatabaseHandler(client, logger);\n }\n\n private constructor(\n private client: Knex,\n private logger: LoggerService,\n ) {}\n\n async addReport(options: AddReportParameters): Promise<void> {\n const { runID, taskID, report, target } = options;\n const logger = options.logger ?? this.logger;\n\n const timestamp = new Date();\n\n const inserts: ReportsRow[] = [];\n for (const [repository, value] of Object.entries(report.repositories)) {\n inserts.push({\n run_id: runID,\n task_id: taskID,\n timestamp,\n host: target.host,\n repository,\n report: value,\n });\n }\n // this.client.batchInsert<ReportsRow>('reports', inserts);\n await this.client('reports')\n .insert(inserts)\n .catch(reason => logger.error('Failed insert data', reason));\n\n await this.updateDependencies(timestamp, options);\n }\n\n async getReports(\n query?: ReportQueryParameters,\n ): Promise<RepositoryReportResponse> {\n const builder = this.client.select<ReportsRow[]>();\n if (query) {\n builder.where(query);\n }\n const rows = await builder.from<ReportsRow[]>('reports');\n return rows.map(row => {\n return {\n runID: row.run_id,\n taskID: row.task_id,\n timestamp: row.timestamp,\n host: row.host,\n repository: row.repository,\n // if the JSON field has not been auto-parsed do it manually\n report: is.string(row.report) ? JSON.parse(row.report) : row.report,\n };\n });\n }\n\n async getTargets(\n table: 'reports' | 'dependencies' = 'reports',\n ): Promise<ReportTargetQuery[]> {\n return this.client\n .select()\n .distinct<ReportsRow[]>('host', 'repository')\n .from(table);\n }\n\n async deleteReportsByTarget(\n { host, repository }: ReportTargetQuery,\n options?: DeleteOptions,\n ): Promise<number> {\n const offset = getOffset(options);\n\n const toBeDeletedIDs = this.client('reports')\n .select('run_id')\n .where('host', host)\n .andWhere('repository', repository)\n .orderBy('timestamp', 'DESC')\n .offset(offset);\n\n return this.client('reports').delete().whereIn('run_id', [toBeDeletedIDs]);\n }\n\n async deleteReports(options?: DeleteOptions): Promise<number> {\n const targets = await this.getTargets();\n const modified = await Promise.all(\n targets.map(target => this.deleteReportsByTarget(target, options)),\n );\n // sum up\n return modified.reduce((a, b) => a + b, 0);\n }\n\n private async updateDependencies(\n timestamp: Date,\n options: AddReportParameters,\n ): Promise<void> {\n const { runID, report, target } = options;\n const dependencies: DependencyRow[] = [];\n for (const [repository, repositoryContent] of Object.entries(\n report.repositories,\n )) {\n for (const [manager, packageFiles] of Object.entries(\n repositoryContent.packageFiles,\n )) {\n for (const packageFile of packageFiles) {\n const packageFilePath = packageFile.packageFile;\n for (const dependency of packageFile.deps) {\n const {\n packageName,\n depName,\n depType,\n datasource,\n currentValue,\n currentVersion,\n skipReason,\n registryUrl,\n sourceUrl,\n currentVersionTimestamp,\n } = dependency;\n\n // TODO remove this once Renovate enforces packageName\n const massagedDepName = depName ?? packageName;\n if (!massagedDepName) {\n continue;\n }\n\n dependencies.push({\n run_id: runID,\n host: target.host,\n extractionTimestamp: timestamp,\n repository,\n manager,\n datasource:\n datasource ?? packageFile.datasource ?? 'no-datasource',\n depName: massagedDepName,\n packageName,\n packageFile: packageFilePath,\n depType,\n currentValue,\n currentVersion,\n currentVersionTimestamp,\n skipReason,\n registryUrl,\n sourceUrl,\n });\n }\n }\n }\n }\n await this.client('dependencies').insert(dependencies);\n }\n\n async getDependencies(\n filters: DependenciesFilter,\n pagination?: Partial<PaginationOptions>,\n ): Promise<Pagination<DependencyRow[]>> {\n const page = pagination?.page ?? 0;\n const pageSize = pagination?.pageSize ?? 500;\n const builder = this.client('dependencies').select<DependencyRow[]>();\n\n this.applyDependencyFilters(builder, filters);\n\n const total = await this.getDependenciesCount(filters);\n\n const offset = page * pageSize;\n return {\n result: await builder.offset(offset).limit(pageSize),\n total,\n page,\n pageSize,\n pageCount: Math.ceil(total / pageSize),\n };\n }\n\n async getDependenciesCount(filters: DependenciesFilter): Promise<number> {\n const builder = this.client('dependencies').count({ count: '*' });\n\n this.applyDependencyFilters(builder, filters);\n\n const count = await builder.first().then(result => result?.count);\n if (is.string(count)) {\n return Number.parseInt(count, 10);\n }\n return count ?? 0;\n }\n\n private applyDependencyFilters(\n builder: Knex.QueryBuilder,\n filters: DependenciesFilter,\n ): void {\n if (filters.host) {\n builder.whereIn('host', filters.host);\n }\n if (filters.repository) {\n builder.whereIn('repository', filters.repository);\n }\n if (filters.manager) {\n builder.whereIn('manager', filters.manager);\n }\n if (filters.datasource) {\n builder.whereIn('datasource', filters.datasource);\n }\n if (filters.depName) {\n builder.whereIn('depName', filters.depName);\n }\n if (filters.depType) {\n builder.whereIn('depType', filters.depType);\n }\n\n if (filters.latestOnly) {\n const runIDs = this.client('dependencies')\n .select('d.run_id')\n .from('dependencies as d')\n .join(\n this.client('dependencies')\n .select('host', 'repository')\n .max('extractionTimestamp as max_timestamp')\n .groupBy('host', 'repository')\n .as('max_d'),\n // eslint-disable-next-line func-names\n function () {\n this.on('d.host', '=', 'max_d.host')\n .andOn('d.repository', '=', 'max_d.repository')\n .andOn('d.extractionTimestamp', '=', 'max_d.max_timestamp');\n },\n )\n .distinct();\n\n builder.whereIn('run_id', runIDs);\n }\n }\n\n /**\n * Gets the available values for the dependencies stored in the database.\n * If filters are supplied, OTHER values are filtered accordingly, if a filter is supplied, all values are returned\n * @param filters\n */\n async getDependenciesValues(\n filters?: DependencyValueFilters,\n ): Promise<DependencyValues> {\n const baseBuilder = this.client<DependencyRow, DependencyValueFilters>(\n 'dependencies',\n );\n const limitedValuesBuilder = baseBuilder.clone();\n\n const allValuesKeys: DependencyValueFiltersKey[] = [];\n const limitedValuesKeys: DependencyValueFiltersKey[] = [];\n for (const filterKey of DependencyValueFiltersKeys) {\n const suppliedFilter = filters?.[filterKey];\n // if no filter is supplied, return all values\n if (suppliedFilter) {\n limitedValuesBuilder.whereIn(filterKey, suppliedFilter);\n limitedValuesKeys.push(filterKey);\n continue;\n }\n\n allValuesKeys.push(filterKey);\n }\n\n const result: DependencyValues = {\n datasource: [],\n manager: [],\n depType: [],\n depName: [],\n host: [],\n packageFile: [],\n repository: [],\n };\n\n const allValues = allValuesKeys.map(\n async (filterKey: DependencyValueFiltersKey) => {\n // get all unique values for the column and do not return as object but list\n const values = await limitedValuesBuilder\n .clone()\n .select(filterKey)\n .distinct()\n .pluck(filterKey);\n result[filterKey] = values.filter(is.string);\n },\n );\n const limitedValues = limitedValuesKeys.map(async filterKey => {\n const values = await baseBuilder\n .clone()\n .select(filterKey)\n .distinct()\n .pluck(filterKey);\n\n result[filterKey] = values.filter(is.string);\n });\n await Promise.all([...allValues, ...limitedValues]);\n return result;\n }\n\n async deleteDependencies(options: DeleteOptions): Promise<number> {\n const targets = await this.getTargets('dependencies');\n const modified = await Promise.all(\n targets.map(target => this.deleteDependenciesByTarget(target, options)),\n );\n // sum up\n return modified.reduce((a, b) => a + b, 0);\n }\n\n async deleteDependenciesByTarget(\n { host, repository }: ReportTargetQuery,\n options?: DeleteOptions,\n ): Promise<number> {\n const offset = getOffset(options);\n\n const dependencies = this.client('dependencies')\n .select('run_id', 'extractionTimestamp')\n .distinct('host', 'repository')\n .where('host', host)\n .andWhere('repository', repository)\n .as('runs');\n\n const toBeDeletedIDs = this.client(dependencies)\n .select('run_id')\n .orderBy('extractionTimestamp', 'DESC')\n .offset(offset);\n\n return this.client('dependencies')\n .delete()\n .whereIn('run_id', [toBeDeletedIDs]);\n }\n}\n\nfunction getOffset(options?: DeleteOptions): number {\n let offset = 0;\n if (\n is.nullOrUndefined(options?.keepLatest) ||\n is.boolean(options?.keepLatest)\n ) {\n offset = options?.keepLatest ? 1 : 0;\n } else {\n offset = options.keepLatest;\n }\n return offset;\n}\n"],"names":["resolvePackagePath","is","DependencyValueFiltersKeys"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"jobSync.cjs.js","sources":["../../src/service/jobSync.ts"],"sourcesContent":["import {\n CATALOG_FILTER_EXISTS,\n CatalogClient,\n} from '@backstage/catalog-client';\nimport { ANNOTATION_SOURCE_LOCATION } from '@backstage/catalog-model';\nimport { RouterOptions } from './types';\nimport {\n getPluginConfig,\n getScheduleDefinition,\n RENOVATE_ANNOTATION_KEEP_UPDATED,\n} from '../config';\nimport { RenovateRunner } from '../wrapper';\n\nexport async function scheduleJobSync(\n renovateRunner: RenovateRunner,\n routerOptions: RouterOptions,\n): Promise<void> {\n const { scheduler, auth, rootConfig, discovery } = routerOptions;\n\n const client = new CatalogClient({ discoveryApi: discovery });\n\n const pluginConfig = getPluginConfig(rootConfig);\n const schedule = getScheduleDefinition(pluginConfig, 'renovation');\n if (!schedule.enabled) {\n return Promise.resolve();\n }\n\n return scheduler.scheduleTask({\n id: `renovate_scheduled_runs`,\n ...schedule,\n\n fn: async () => {\n const { token } = await auth.getPluginRequestToken({\n onBehalfOf: await auth.getOwnServiceCredentials(),\n targetPluginId: 'catalog',\n });\n const { items: entities } = await client.getEntities(\n {\n filter: {\n [`metadata.annotations.${RENOVATE_ANNOTATION_KEEP_UPDATED}`]:\n CATALOG_FILTER_EXISTS,\n [`metadata.annotations.${ANNOTATION_SOURCE_LOCATION}`]:\n CATALOG_FILTER_EXISTS,\n },\n fields: [\n 'kind',\n 'metadata.annotations',\n 'metadata.name',\n 'metadata.namespace',\n 'metadata.title',\n ],\n },\n { token },\n );\n\n await renovateRunner.addToQueue(...entities);\n },\n });\n}\n"],"names":["CatalogClient","getPluginConfig","getScheduleDefinition","RENOVATE_ANNOTATION_KEEP_UPDATED","CATALOG_FILTER_EXISTS","ANNOTATION_SOURCE_LOCATION"],"mappings":";;;;;;AAasB,eAAA,eAAA,CACpB,gBACA,aACe,EAAA;AACf,EAAA,MAAM,EAAE,SAAA,EAAW,IAAM,EAAA,UAAA,EAAY,WAAc,GAAA,aAAA;AAEnD,EAAA,MAAM,SAAS,IAAIA,2BAAA,CAAc,EAAE,YAAA,EAAc,WAAW,CAAA;AAE5D,EAAM,MAAA,YAAA,GAAeC,sBAAgB,UAAU,CAAA;AAC/C,EAAM,MAAA,QAAA,GAAWC,2BAAsB,CAAA,YAAA,EAAc,YAAY,CAAA;AACjE,EAAI,IAAA,CAAC,SAAS,OAAS,EAAA;AACrB,IAAA,OAAO,QAAQ,OAAQ,EAAA;AAAA;AAGzB,EAAA,OAAO,UAAU,YAAa,CAAA;AAAA,IAC5B,EAAI,EAAA,CAAA,uBAAA,CAAA;AAAA,IACJ,GAAG,QAAA;AAAA,IAEH,IAAI,YAAY;AACd,MAAA,MAAM,EAAE,KAAA,EAAU,GAAA,MAAM,KAAK,qBAAsB,CAAA;AAAA,QACjD,UAAA,EAAY,MAAM,IAAA,CAAK,wBAAyB,EAAA;AAAA,QAChD,cAAgB,EAAA;AAAA,OACjB,CAAA;AACD,MAAA,MAAM,EAAE,KAAA,EAAO,QAAS,EAAA,GAAI,MAAM,MAAO,CAAA,WAAA;AAAA,QACvC;AAAA,UACE,MAAQ,EAAA;AAAA,YACN,CAAC,CAAA,qBAAA,EAAwBC,sCAAgC,CAAA,CAAE,GACzDC,mCAAA;AAAA,YACF,CAAC,CAAA,qBAAA,EAAwBC,uCAA0B,CAAA,CAAE,GACnDD;AAAA,WACJ;AAAA,UACA,MAAQ,EAAA;AAAA,YACN,MAAA;AAAA,YACA,sBAAA;AAAA,YACA,eAAA;AAAA,YACA,oBAAA;AAAA,YACA;AAAA;AACF,SACF;AAAA,QACA,EAAE,KAAM;AAAA,OACV;AAEA,MAAM,MAAA,cAAA,CAAe,UAAW,CAAA,GAAG,QAAQ,CAAA;AAAA;AAC7C,GACD,CAAA;AACH;;;;"}
1
+ {"version":3,"file":"jobSync.cjs.js","sources":["../../src/service/jobSync.ts"],"sourcesContent":["import {\n CATALOG_FILTER_EXISTS,\n CatalogClient,\n} from '@backstage/catalog-client';\nimport { ANNOTATION_SOURCE_LOCATION } from '@backstage/catalog-model';\nimport { RouterOptions } from './types';\nimport {\n getPluginConfig,\n getScheduleDefinition,\n RENOVATE_ANNOTATION_KEEP_UPDATED,\n} from '../config';\nimport { RenovateRunner } from '../wrapper';\n\nexport async function scheduleJobSync(\n renovateRunner: RenovateRunner,\n routerOptions: RouterOptions,\n): Promise<void> {\n const { scheduler, auth, rootConfig, discovery } = routerOptions;\n\n const client = new CatalogClient({ discoveryApi: discovery });\n\n const pluginConfig = getPluginConfig(rootConfig);\n const schedule = getScheduleDefinition(pluginConfig, 'renovation');\n if (!schedule.enabled) {\n return Promise.resolve();\n }\n\n return scheduler.scheduleTask({\n id: `renovate_scheduled_runs`,\n ...schedule,\n\n fn: async () => {\n const { token } = await auth.getPluginRequestToken({\n onBehalfOf: await auth.getOwnServiceCredentials(),\n targetPluginId: 'catalog',\n });\n const { items: entities } = await client.getEntities(\n {\n filter: {\n [`metadata.annotations.${RENOVATE_ANNOTATION_KEEP_UPDATED}`]:\n CATALOG_FILTER_EXISTS,\n [`metadata.annotations.${ANNOTATION_SOURCE_LOCATION}`]:\n CATALOG_FILTER_EXISTS,\n },\n fields: [\n 'kind',\n 'metadata.annotations',\n 'metadata.name',\n 'metadata.namespace',\n 'metadata.title',\n ],\n },\n { token },\n );\n\n await renovateRunner.addToQueue(...entities);\n },\n });\n}\n"],"names":["CatalogClient","getPluginConfig","getScheduleDefinition","RENOVATE_ANNOTATION_KEEP_UPDATED","CATALOG_FILTER_EXISTS","ANNOTATION_SOURCE_LOCATION"],"mappings":";;;;;;AAaA,eAAsB,eAAA,CACpB,gBACA,aAAA,EACe;AACf,EAAA,MAAM,EAAE,SAAA,EAAW,IAAA,EAAM,UAAA,EAAY,WAAU,GAAI,aAAA;AAEnD,EAAA,MAAM,SAAS,IAAIA,2BAAA,CAAc,EAAE,YAAA,EAAc,WAAW,CAAA;AAE5D,EAAA,MAAM,YAAA,GAAeC,sBAAgB,UAAU,CAAA;AAC/C,EAAA,MAAM,QAAA,GAAWC,2BAAA,CAAsB,YAAA,EAAc,YAAY,CAAA;AACjE,EAAA,IAAI,CAAC,SAAS,OAAA,EAAS;AACrB,IAAA,OAAO,QAAQ,OAAA,EAAQ;AAAA,EACzB;AAEA,EAAA,OAAO,UAAU,YAAA,CAAa;AAAA,IAC5B,EAAA,EAAI,CAAA,uBAAA,CAAA;AAAA,IACJ,GAAG,QAAA;AAAA,IAEH,IAAI,YAAY;AACd,MAAA,MAAM,EAAE,KAAA,EAAM,GAAI,MAAM,KAAK,qBAAA,CAAsB;AAAA,QACjD,UAAA,EAAY,MAAM,IAAA,CAAK,wBAAA,EAAyB;AAAA,QAChD,cAAA,EAAgB;AAAA,OACjB,CAAA;AACD,MAAA,MAAM,EAAE,KAAA,EAAO,QAAA,EAAS,GAAI,MAAM,MAAA,CAAO,WAAA;AAAA,QACvC;AAAA,UACE,MAAA,EAAQ;AAAA,YACN,CAAC,CAAA,qBAAA,EAAwBC,sCAAgC,CAAA,CAAE,GACzDC,mCAAA;AAAA,YACF,CAAC,CAAA,qBAAA,EAAwBC,uCAA0B,CAAA,CAAE,GACnDD;AAAA,WACJ;AAAA,UACA,MAAA,EAAQ;AAAA,YACN,MAAA;AAAA,YACA,sBAAA;AAAA,YACA,eAAA;AAAA,YACA,oBAAA;AAAA,YACA;AAAA;AACF,SACF;AAAA,QACA,EAAE,KAAA;AAAM,OACV;AAEA,MAAA,MAAM,cAAA,CAAe,UAAA,CAAW,GAAG,QAAQ,CAAA;AAAA,IAC7C;AAAA,GACD,CAAA;AACH;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"router.cjs.js","sources":["../../src/service/router.ts"],"sourcesContent":["import { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport express from 'express';\nimport { createOpenApiRouter } from '../schema/openapi';\nimport { runRequestBody } from './schema';\nimport { RouterOptions } from './types';\nimport {\n getTargetRepo,\n getTaskID,\n isEntityRef,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { RenovateRunner } from '../wrapper';\nimport { CatalogClient } from '@backstage/catalog-client';\nimport type { Entity } from '@backstage/catalog-model';\nimport is from '@sindresorhus/is';\nimport { getFileUrl } from '../wrapper/platforms';\n\nexport async function createRouter(\n runner: RenovateRunner,\n options: RouterOptions,\n): Promise<express.Router> {\n const {\n auth,\n rootConfig: config,\n logger,\n databaseHandler,\n discovery,\n } = options;\n\n const middlewareFactory = MiddlewareFactory.create({ logger, config });\n\n const client = new CatalogClient({ discoveryApi: discovery });\n\n const router = await createOpenApiRouter();\n router.use(express.json());\n\n router.get('/reports', async (_request, response) => {\n const reports = await databaseHandler.getReports();\n response.status(200).json(reports);\n });\n\n router.delete('/reports', async (request, response) => {\n const modified = await databaseHandler.deleteReports({\n keepLatest: request.query.keepLatest,\n });\n response.status(200).json({ modified });\n });\n\n router.get('/reports/:host', async (request, response) => {\n const reports = await databaseHandler.getReports({\n ...request.params,\n });\n response.status(200).json(reports);\n });\n\n router.delete('/reports/:host', async (request, response) => {\n const modified = await databaseHandler.deleteReportsByTarget(\n request.params,\n { keepLatest: request.query.keepLatest },\n );\n response.status(200).json({ modified });\n });\n\n router.get('/reports/:host/:repository', async (request, response) => {\n const reports = await databaseHandler.getReports({\n ...request.params,\n });\n response.status(200).json(reports);\n });\n\n router.delete('/reports/:host/:repository', async (request, response) => {\n const modified = await databaseHandler.deleteReportsByTarget(\n request.params,\n { keepLatest: request.query.keepLatest },\n );\n response.status(200).json({ modified });\n });\n\n router.get('/dependencies', async (request, response) => {\n const filter = request.query;\n const { result, total, pageCount, page, pageSize } =\n await databaseHandler.getDependencies(filter, filter);\n\n const massaged = result.map(dep => {\n return {\n ...dep,\n id: dep.id!,\n runID: dep.run_id,\n packageFileUrl: getFileUrl(dep) ?? undefined,\n };\n });\n\n let availableValues: Record<string, string[]> | undefined;\n if (request.query.availableValues) {\n availableValues = await databaseHandler.getDependenciesValues(filter);\n }\n\n response.setHeader('X-Total-Count', total);\n response.setHeader('X-Page-Count', pageCount);\n response.setHeader('X-Page', page);\n response.setHeader('X-Page-Size', pageSize);\n // openapi gen expects an empty array\n response.json({\n dependencies: massaged,\n availableValues,\n });\n });\n\n router.post('/runs', async (request, response) => {\n const body = runRequestBody.safeParse(request.body);\n if (!body.success) {\n response.status(400).json({ error: body.error.toString() });\n return;\n }\n let target: string | TargetRepo | Entity = body.data.target;\n\n // check if we got an entity ref and if yes get the entity\n if (is.string(target) && isEntityRef(target)) {\n const { token } = await auth.getPluginRequestToken({\n onBehalfOf: await auth.getOwnServiceCredentials(),\n targetPluginId: 'catalog',\n });\n const result = await client.getEntityByRef(target, { token });\n if (result) {\n target = result;\n }\n }\n\n // trigger Renovate run\n const targetRepo = getTargetRepo(target);\n const id = getTaskID(targetRepo);\n const result = await runner.runNext(targetRepo);\n if (result.status === 'already-running') {\n logger.debug('Task already running', { taskID: id });\n response.status(423).json({ error: 'Task is already running' });\n return;\n }\n response.status(202).json({ taskID: id });\n });\n router.use(middlewareFactory.error());\n return router;\n}\n"],"names":["MiddlewareFactory","CatalogClient","router","createOpenApiRouter","express","getFileUrl","runRequestBody","is","isEntityRef","result","getTargetRepo","getTaskID"],"mappings":"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"}
1
+ {"version":3,"file":"router.cjs.js","sources":["../../src/service/router.ts"],"sourcesContent":["import { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport express from 'express';\nimport { createOpenApiRouter } from '../schema/openapi';\nimport { runRequestBody } from './schema';\nimport { RouterOptions } from './types';\nimport {\n getTargetRepo,\n getTaskID,\n isEntityRef,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { RenovateRunner } from '../wrapper';\nimport { CatalogClient } from '@backstage/catalog-client';\nimport type { Entity } from '@backstage/catalog-model';\nimport is from '@sindresorhus/is';\nimport { getFileUrl } from '../wrapper/platforms';\n\nexport async function createRouter(\n runner: RenovateRunner,\n options: RouterOptions,\n): Promise<express.Router> {\n const {\n auth,\n rootConfig: config,\n logger,\n databaseHandler,\n discovery,\n } = options;\n\n const middlewareFactory = MiddlewareFactory.create({ logger, config });\n\n const client = new CatalogClient({ discoveryApi: discovery });\n\n const router = await createOpenApiRouter();\n router.use(express.json());\n\n router.get('/reports', async (_request, response) => {\n const reports = await databaseHandler.getReports();\n response.status(200).json(reports);\n });\n\n router.delete('/reports', async (request, response) => {\n const modified = await databaseHandler.deleteReports({\n keepLatest: request.query.keepLatest,\n });\n response.status(200).json({ modified });\n });\n\n router.get('/reports/:host', async (request, response) => {\n const reports = await databaseHandler.getReports({\n ...request.params,\n });\n response.status(200).json(reports);\n });\n\n router.delete('/reports/:host', async (request, response) => {\n const modified = await databaseHandler.deleteReportsByTarget(\n request.params,\n { keepLatest: request.query.keepLatest },\n );\n response.status(200).json({ modified });\n });\n\n router.get('/reports/:host/:repository', async (request, response) => {\n const reports = await databaseHandler.getReports({\n ...request.params,\n });\n response.status(200).json(reports);\n });\n\n router.delete('/reports/:host/:repository', async (request, response) => {\n const modified = await databaseHandler.deleteReportsByTarget(\n request.params,\n { keepLatest: request.query.keepLatest },\n );\n response.status(200).json({ modified });\n });\n\n router.get('/dependencies', async (request, response) => {\n const filter = request.query;\n const { result, total, pageCount, page, pageSize } =\n await databaseHandler.getDependencies(filter, filter);\n\n const massaged = result.map(dep => {\n return {\n ...dep,\n id: dep.id!,\n runID: dep.run_id,\n packageFileUrl: getFileUrl(dep) ?? undefined,\n };\n });\n\n let availableValues: Record<string, string[]> | undefined;\n if (request.query.availableValues) {\n availableValues = await databaseHandler.getDependenciesValues(filter);\n }\n\n response.setHeader('X-Total-Count', total);\n response.setHeader('X-Page-Count', pageCount);\n response.setHeader('X-Page', page);\n response.setHeader('X-Page-Size', pageSize);\n // openapi gen expects an empty array\n response.json({\n dependencies: massaged,\n availableValues,\n });\n });\n\n router.post('/runs', async (request, response) => {\n const body = runRequestBody.safeParse(request.body);\n if (!body.success) {\n response.status(400).json({ error: body.error.toString() });\n return;\n }\n let target: string | TargetRepo | Entity = body.data.target;\n\n // check if we got an entity ref and if yes get the entity\n if (is.string(target) && isEntityRef(target)) {\n const { token } = await auth.getPluginRequestToken({\n onBehalfOf: await auth.getOwnServiceCredentials(),\n targetPluginId: 'catalog',\n });\n const result = await client.getEntityByRef(target, { token });\n if (result) {\n target = result;\n }\n }\n\n // trigger Renovate run\n const targetRepo = getTargetRepo(target);\n const id = getTaskID(targetRepo);\n const result = await runner.runNext(targetRepo);\n if (result.status === 'already-running') {\n logger.debug('Task already running', { taskID: id });\n response.status(423).json({ error: 'Task is already running' });\n return;\n }\n response.status(202).json({ taskID: id });\n });\n router.use(middlewareFactory.error());\n return router;\n}\n"],"names":["MiddlewareFactory","CatalogClient","router","createOpenApiRouter","express","getFileUrl","runRequestBody","is","isEntityRef","result","getTargetRepo","getTaskID"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"schema.cjs.js","sources":["../../src/service/schema.ts"],"sourcesContent":["import { z } from 'zod';\nimport { targetRepo } from '@secustor/backstage-plugin-renovate-common';\n\nexport const target = z.string().or(targetRepo);\n\nexport const runRequestBody = z.object({\n target,\n});\n"],"names":["z","targetRepo"],"mappings":";;;;;AAGO,MAAM,MAAS,GAAAA,KAAA,CAAE,MAAO,EAAA,CAAE,GAAGC,wCAAU;AAEjC,MAAA,cAAA,GAAiBD,MAAE,MAAO,CAAA;AAAA,EACrC;AACF,CAAC;;;;;"}
1
+ {"version":3,"file":"schema.cjs.js","sources":["../../src/service/schema.ts"],"sourcesContent":["import { z } from 'zod';\nimport { targetRepo } from '@secustor/backstage-plugin-renovate-common';\n\nexport const target = z.string().or(targetRepo);\n\nexport const runRequestBody = z.object({\n target,\n});\n"],"names":["z","targetRepo"],"mappings":";;;;;AAGO,MAAM,MAAA,GAASA,KAAA,CAAE,MAAA,EAAO,CAAE,GAAGC,wCAAU;AAEvC,MAAM,cAAA,GAAiBD,MAAE,MAAA,CAAO;AAAA,EACrC;AACF,CAAC;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"types.cjs.js","sources":["../../src/service/types.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport {\n AuthService,\n DatabaseService,\n DiscoveryService,\n LoggerService,\n SchedulerService,\n} from '@backstage/backend-plugin-api';\nimport {\n RenovateReport,\n RenovateWrapper,\n RepositoryReport,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { DatabaseHandler } from './databaseHandler';\nimport {\n QueueFactory,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport interface RouterOptions {\n auth: AuthService;\n rootConfig: Config;\n logger: LoggerService;\n databaseHandler: DatabaseHandler;\n runtimes: Map<string, RenovateWrapper>;\n queueFactories: Map<string, QueueFactory<RunOptions>>;\n scheduler: SchedulerService;\n discovery: DiscoveryService;\n}\n\nexport interface ReportsRow {\n run_id: string;\n task_id: string;\n timestamp: Date;\n host: string;\n repository: string;\n report: RepositoryReport;\n}\n\nexport interface DependencyRow {\n id?: string;\n run_id: string;\n host: string;\n repository: string;\n extractionTimestamp: Date;\n manager: string;\n datasource: string;\n packageFile: string;\n depName: string;\n packageName?: string;\n depType?: string;\n currentValue?: string;\n currentVersion?: string;\n currentVersionTimestamp?: Date;\n skipReason?: string;\n registryUrl?: string;\n sourceUrl?: string;\n currentVersionReleased?: Date;\n}\n\nexport interface ReportTargetQuery {\n host?: string;\n repository?: string;\n}\n\nexport interface DeleteOptions {\n /**\n * If falsely (0, false or undefined) delete all reports\n * If keepLatest is a number keep this number of records.\n * In case it is boolean true, the behaviour is identical to 1\n */\n keepLatest?: boolean | number;\n}\n\nexport interface DatabaseCreationParameters {\n database: DatabaseService;\n logger: LoggerService;\n}\n\nexport interface ReportQueryParameters {\n host?: string;\n repository?: string;\n}\n\nexport interface AddReportParameters {\n runID: string;\n taskID: string;\n report: RenovateReport;\n target: TargetRepo;\n logger?: LoggerService;\n}\n\nexport interface DependenciesFilter extends DependencyValueFilters {\n latestOnly?: boolean;\n}\n\nexport const DependencyValueFiltersKeys = [\n 'datasource',\n 'depName',\n 'depType',\n 'host',\n 'manager',\n 'packageFile',\n 'repository',\n] as const;\nexport type DependencyValueFiltersKey =\n (typeof DependencyValueFiltersKeys)[number];\n\nexport type DependencyValueFilters = Partial<\n Record<DependencyValueFiltersKey, string[]>\n>;\n\nexport type DependencyValues = Record<DependencyValueFiltersKey, string[]>;\n\nexport interface PaginationOptions {\n page: number;\n pageSize: number;\n}\n\nexport interface Pagination<T> {\n result: T;\n page: number;\n pageSize: number;\n pageCount: number;\n total: number;\n}\n"],"names":[],"mappings":";;AAiGO,MAAM,0BAA6B,GAAA;AAAA,EACxC,YAAA;AAAA,EACA,SAAA;AAAA,EACA,SAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,aAAA;AAAA,EACA;AACF;;;;"}
1
+ {"version":3,"file":"types.cjs.js","sources":["../../src/service/types.ts"],"sourcesContent":["import { Config } from '@backstage/config';\nimport {\n AuthService,\n DatabaseService,\n DiscoveryService,\n LoggerService,\n SchedulerService,\n} from '@backstage/backend-plugin-api';\nimport {\n RenovateReport,\n RenovateWrapper,\n RepositoryReport,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { DatabaseHandler } from './databaseHandler';\nimport {\n QueueFactory,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport interface RouterOptions {\n auth: AuthService;\n rootConfig: Config;\n logger: LoggerService;\n databaseHandler: DatabaseHandler;\n runtimes: Map<string, RenovateWrapper>;\n queueFactories: Map<string, QueueFactory<RunOptions>>;\n scheduler: SchedulerService;\n discovery: DiscoveryService;\n}\n\nexport interface ReportsRow {\n run_id: string;\n task_id: string;\n timestamp: Date;\n host: string;\n repository: string;\n report: RepositoryReport;\n}\n\nexport interface DependencyRow {\n id?: string;\n run_id: string;\n host: string;\n repository: string;\n extractionTimestamp: Date;\n manager: string;\n datasource: string;\n packageFile: string;\n depName: string;\n packageName?: string;\n depType?: string;\n currentValue?: string;\n currentVersion?: string;\n currentVersionTimestamp?: Date;\n skipReason?: string;\n registryUrl?: string;\n sourceUrl?: string;\n currentVersionReleased?: Date;\n}\n\nexport interface ReportTargetQuery {\n host?: string;\n repository?: string;\n}\n\nexport interface DeleteOptions {\n /**\n * If falsely (0, false or undefined) delete all reports\n * If keepLatest is a number keep this number of records.\n * In case it is boolean true, the behaviour is identical to 1\n */\n keepLatest?: boolean | number;\n}\n\nexport interface DatabaseCreationParameters {\n database: DatabaseService;\n logger: LoggerService;\n}\n\nexport interface ReportQueryParameters {\n host?: string;\n repository?: string;\n}\n\nexport interface AddReportParameters {\n runID: string;\n taskID: string;\n report: RenovateReport;\n target: TargetRepo;\n logger?: LoggerService;\n}\n\nexport interface DependenciesFilter extends DependencyValueFilters {\n latestOnly?: boolean;\n}\n\nexport const DependencyValueFiltersKeys = [\n 'datasource',\n 'depName',\n 'depType',\n 'host',\n 'manager',\n 'packageFile',\n 'repository',\n] as const;\nexport type DependencyValueFiltersKey =\n (typeof DependencyValueFiltersKeys)[number];\n\nexport type DependencyValueFilters = Partial<\n Record<DependencyValueFiltersKey, string[]>\n>;\n\nexport type DependencyValues = Record<DependencyValueFiltersKey, string[]>;\n\nexport interface PaginationOptions {\n page: number;\n pageSize: number;\n}\n\nexport interface Pagination<T> {\n result: T;\n page: number;\n pageSize: number;\n pageCount: number;\n total: number;\n}\n"],"names":[],"mappings":";;AAiGO,MAAM,0BAAA,GAA6B;AAAA,EACxC,YAAA;AAAA,EACA,SAAA;AAAA,EACA,SAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,aAAA;AAAA,EACA;AACF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"github.cjs.js","sources":["../../../src/wrapper/platforms/github.ts"],"sourcesContent":["import {\n DefaultGithubCredentialsProvider,\n ScmIntegrations,\n} from '@backstage/integration';\n\nexport async function getGithubToken(\n integrations: ScmIntegrations,\n url: string,\n): Promise<string | undefined> {\n const cred = await DefaultGithubCredentialsProvider.fromIntegrations(\n integrations,\n ).getCredentials({ url });\n return cred.token;\n}\n"],"names":["DefaultGithubCredentialsProvider"],"mappings":";;;;AAKsB,eAAA,cAAA,CACpB,cACA,GAC6B,EAAA;AAC7B,EAAM,MAAA,IAAA,GAAO,MAAMA,4CAAiC,CAAA,gBAAA;AAAA,IAClD;AAAA,GACA,CAAA,cAAA,CAAe,EAAE,GAAA,EAAK,CAAA;AACxB,EAAA,OAAO,IAAK,CAAA,KAAA;AACd;;;;"}
1
+ {"version":3,"file":"github.cjs.js","sources":["../../../src/wrapper/platforms/github.ts"],"sourcesContent":["import {\n DefaultGithubCredentialsProvider,\n ScmIntegrations,\n} from '@backstage/integration';\n\nexport async function getGithubToken(\n integrations: ScmIntegrations,\n url: string,\n): Promise<string | undefined> {\n const cred = await DefaultGithubCredentialsProvider.fromIntegrations(\n integrations,\n ).getCredentials({ url });\n return cred.token;\n}\n"],"names":["DefaultGithubCredentialsProvider"],"mappings":";;;;AAKA,eAAsB,cAAA,CACpB,cACA,GAAA,EAC6B;AAC7B,EAAA,MAAM,IAAA,GAAO,MAAMA,4CAAA,CAAiC,gBAAA;AAAA,IAClD;AAAA,GACF,CAAE,cAAA,CAAe,EAAE,GAAA,EAAK,CAAA;AACxB,EAAA,OAAO,IAAA,CAAK,KAAA;AACd;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../../../src/wrapper/platforms/index.ts"],"sourcesContent":["import {\n DefaultGitlabCredentialsProvider,\n ScmIntegrations,\n} from '@backstage/integration';\nimport is from '@sindresorhus/is';\nimport { PlatformEnvsOptions } from './types';\nimport { TargetRepo } from '@secustor/backstage-plugin-renovate-common';\nimport { getGithubToken } from './github';\n\n/*\n Returns record of Renovate environment variables specific for the platform of targetUrl\n */\nexport async function getPlatformEnvs(\n target: TargetRepo,\n context: PlatformEnvsOptions,\n): Promise<Record<string, string>> {\n const { rootConfig, logger } = context;\n\n const env: Record<string, string> = {};\n // add Renovate platform and tokens\n const integrations = ScmIntegrations.fromConfig(rootConfig);\n const integration = integrations.byHost(target.host);\n if (is.nullOrUndefined(integration)) {\n throw new Error(\n `Could not identify platform for target ${target.host}/${target.repository}`,\n );\n }\n\n const errMsg = `No credentials could be found for url and '${integration.type}' type for host ${target.host}`;\n const url = `https://${target.host}/${target.repository}`;\n switch (integration.type) {\n case 'github': {\n env.RENOVATE_PLATFORM = integration.type;\n const token = await getGithubToken(integrations, url);\n env.RENOVATE_TOKEN = requireConfigVariable(token, errMsg);\n env.RENOVATE_REPOSITORIES = target.repository;\n break;\n }\n case 'gitlab':\n {\n const cred = await DefaultGitlabCredentialsProvider.fromIntegrations(\n integrations,\n ).getCredentials({ url });\n const gitLabIntegrationConfig = requireConfigVariable(\n integrations.gitlab.byHost(target.host)?.config,\n errMsg,\n );\n env.RENOVATE_PLATFORM = integration.type;\n env.RENOVATE_ENDPOINT =\n gitLabIntegrationConfig.apiBaseUrl ?? `https://${target.host}/api/v4`;\n env.RENOVATE_TOKEN = requireConfigVariable(cred.token, errMsg);\n env.RENOVATE_REPOSITORIES = target.repository;\n }\n break;\n default:\n throw new Error(`Unsupported platform type ${integration.type}`);\n }\n\n const githubComURL = 'https://github.com';\n const githubComIntegration = integrations.github.byUrl(githubComURL);\n if (is.nullOrUndefined(githubComIntegration)) {\n logger.warn(`No Github.com integration has been found`);\n } else {\n const githubComToken = await getGithubToken(integrations, githubComURL);\n if (githubComToken) {\n env.GITHUB_COM_TOKEN = githubComToken;\n } else {\n logger.warn(\n `Could not get token for Github.com token in the defined integrations`,\n );\n }\n }\n\n return env;\n}\n\nfunction requireConfigVariable<T>(\n input: T | undefined | null,\n errMessage: string,\n): T {\n if (is.nullOrUndefined(input)) {\n throw new Error(errMessage);\n }\n return input;\n}\n\nexport function getFileUrl(options: {\n packageFile: string;\n host: string;\n repository: string;\n}): string | null {\n if (options.host.includes('github')) {\n return `https://${options.host}/${options.repository}/blob/HEAD/${options.packageFile}`;\n }\n return null;\n}\n"],"names":["ScmIntegrations","integration","is","getGithubToken","DefaultGitlabCredentialsProvider"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../../../src/wrapper/platforms/index.ts"],"sourcesContent":["import {\n DefaultGitlabCredentialsProvider,\n ScmIntegrations,\n} from '@backstage/integration';\nimport is from '@sindresorhus/is';\nimport { PlatformEnvsOptions } from './types';\nimport { TargetRepo } from '@secustor/backstage-plugin-renovate-common';\nimport { getGithubToken } from './github';\n\n/*\n Returns record of Renovate environment variables specific for the platform of targetUrl\n */\nexport async function getPlatformEnvs(\n target: TargetRepo,\n context: PlatformEnvsOptions,\n): Promise<Record<string, string>> {\n const { rootConfig, logger } = context;\n\n const env: Record<string, string> = {};\n // add Renovate platform and tokens\n const integrations = ScmIntegrations.fromConfig(rootConfig);\n const integration = integrations.byHost(target.host);\n if (is.nullOrUndefined(integration)) {\n throw new Error(\n `Could not identify platform for target ${target.host}/${target.repository}`,\n );\n }\n\n const errMsg = `No credentials could be found for url and '${integration.type}' type for host ${target.host}`;\n const url = `https://${target.host}/${target.repository}`;\n switch (integration.type) {\n case 'github': {\n env.RENOVATE_PLATFORM = integration.type;\n const token = await getGithubToken(integrations, url);\n env.RENOVATE_TOKEN = requireConfigVariable(token, errMsg);\n env.RENOVATE_REPOSITORIES = target.repository;\n break;\n }\n case 'gitlab':\n {\n const cred = await DefaultGitlabCredentialsProvider.fromIntegrations(\n integrations,\n ).getCredentials({ url });\n const gitLabIntegrationConfig = requireConfigVariable(\n integrations.gitlab.byHost(target.host)?.config,\n errMsg,\n );\n env.RENOVATE_PLATFORM = integration.type;\n env.RENOVATE_ENDPOINT =\n gitLabIntegrationConfig.apiBaseUrl ?? `https://${target.host}/api/v4`;\n env.RENOVATE_TOKEN = requireConfigVariable(cred.token, errMsg);\n env.RENOVATE_REPOSITORIES = target.repository;\n }\n break;\n default:\n throw new Error(`Unsupported platform type ${integration.type}`);\n }\n\n const githubComURL = 'https://github.com';\n const githubComIntegration = integrations.github.byUrl(githubComURL);\n if (is.nullOrUndefined(githubComIntegration)) {\n logger.warn(`No Github.com integration has been found`);\n } else {\n const githubComToken = await getGithubToken(integrations, githubComURL);\n if (githubComToken) {\n env.GITHUB_COM_TOKEN = githubComToken;\n } else {\n logger.warn(\n `Could not get token for Github.com token in the defined integrations`,\n );\n }\n }\n\n return env;\n}\n\nfunction requireConfigVariable<T>(\n input: T | undefined | null,\n errMessage: string,\n): T {\n if (is.nullOrUndefined(input)) {\n throw new Error(errMessage);\n }\n return input;\n}\n\nexport function getFileUrl(options: {\n packageFile: string;\n host: string;\n repository: string;\n}): string | null {\n if (options.host.includes('github')) {\n return `https://${options.host}/${options.repository}/blob/HEAD/${options.packageFile}`;\n }\n return null;\n}\n"],"names":["ScmIntegrations","integration","is","getGithubToken","DefaultGitlabCredentialsProvider"],"mappings":"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"}
@@ -96,7 +96,8 @@ class RenovateRunner {
96
96
  logger,
97
97
  rootConfig: this.rootConfig
98
98
  }),
99
- ...utils.getCacheEnvs(this.rootConfig, logger)
99
+ ...utils.getCacheEnvs(this.rootConfig, logger),
100
+ ...utils.getPassthroughEnvs(this.rootConfig, logger)
100
101
  };
101
102
  const renovateConfig = index.getRenovateConfig(this.rootConfig);
102
103
  const promise = wrapperRuntime.run({
@@ -1 +1 @@
1
- {"version":3,"file":"renovateRunner.cjs.js","sources":["../../src/wrapper/renovateRunner.ts"],"sourcesContent":["import is from '@sindresorhus/is';\nimport { getPlatformEnvs } from './platforms';\nimport { RouterOptions } from '../service/types';\nimport { extractReport, getCacheEnvs } from './utils';\nimport {\n getTargetRepo,\n getTaskID,\n RenovateReport,\n RenovateWrapper,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { Config } from '@backstage/config';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { getRenovateConfig, getRuntimeConfigs } from '../config';\nimport { DatabaseHandler } from '../service/databaseHandler';\nimport { isError } from '@backstage/errors';\nimport { Entity } from '@backstage/catalog-model';\nimport { nanoid } from 'nanoid';\nimport { createQueue } from '../queue';\nimport {\n AddResult,\n QueueFactory,\n RenovateQueue,\n Runnable,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport class RenovateRunner implements Runnable<RunOptions> {\n private readonly queue: RenovateQueue<RunOptions>;\n\n constructor(\n queueFactories: Map<string, QueueFactory<RunOptions>>,\n private readonly databaseHandler: DatabaseHandler,\n private readonly rootConfig: Config,\n readonly logger: LoggerService,\n private readonly runtimes: Map<string, RenovateWrapper>,\n ) {\n this.queue = createQueue(queueFactories, rootConfig, this);\n }\n\n static async from(options: RouterOptions): Promise<RenovateRunner> {\n const { databaseHandler, rootConfig, runtimes, logger, queueFactories } =\n options;\n\n return new RenovateRunner(\n queueFactories,\n databaseHandler,\n rootConfig,\n logger,\n runtimes,\n );\n }\n\n async addToQueue(\n ...targets: (string | Entity | TargetRepo)[]\n ): Promise<AddResult[]> {\n const props = targets.map(target => {\n const jobId = getTaskID(target);\n const targetRepo = getTargetRepo(target);\n return {\n jobId,\n data: {\n id: jobId,\n target: targetRepo,\n },\n };\n });\n\n return await this.queue.addBulk(props);\n }\n\n async runNext(target: string | Entity | TargetRepo): Promise<AddResult> {\n const jobId = getTaskID(target);\n const targetRepo = getTargetRepo(target);\n\n return await this.queue.add(\n jobId,\n { id: jobId, target: targetRepo },\n {\n force: true,\n insertInFront: true,\n },\n );\n }\n\n async run(props: RunOptions): Promise<void> {\n const { id, target } = props;\n const runID = nanoid();\n const logger = this.logger.child({ runID, jobID: id, ...target });\n try {\n logger.info('Renovate run starting');\n const report = await this.renovate(props, logger);\n await this.databaseHandler.addReport({\n runID,\n taskID: id,\n report,\n target,\n logger,\n });\n logger.info('Renovate run successfully finished');\n } catch (e) {\n logger.error('Renovate failed', isError(e) ? e : {});\n }\n }\n\n async renovate(\n { id, target }: RunOptions,\n logger: LoggerService,\n ): Promise<RenovateReport> {\n const { runtime, config: runtimeConfig } = getRuntimeConfigs(\n this.rootConfig,\n );\n const wrapperRuntime = this.runtimes.get(runtime);\n if (is.nullOrUndefined(wrapperRuntime)) {\n throw new Error(`Unknown runtime type '${runtime}'`);\n }\n\n const env: Record<string, string> = {\n // setup logging\n LOG_FORMAT: 'json',\n LOG_LEVEL: 'debug',\n LOG_CONTEXT: id,\n RENOVATE_REPORT_TYPE: 'logging',\n // setup platform specifics\n ...(await getPlatformEnvs(target, {\n logger,\n rootConfig: this.rootConfig,\n })),\n ...getCacheEnvs(this.rootConfig, logger),\n };\n\n // read out renovate.config and write out to json file for consumption by Renovate\n // we are reading it at this place to allow dynamic configuration changes\n const renovateConfig = getRenovateConfig(this.rootConfig);\n\n const promise = wrapperRuntime.run({\n runID: id,\n env,\n renovateConfig,\n runtimeConfig,\n logger,\n });\n\n return promise.then(result => {\n return extractReport({\n logger,\n logStream: result.stdout,\n });\n });\n }\n}\n"],"names":["createQueue","getTaskID","getTargetRepo","nanoid","isError","getRuntimeConfigs","is","getPlatformEnvs","getCacheEnvs","getRenovateConfig","extractReport"],"mappings":"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"}
1
+ {"version":3,"file":"renovateRunner.cjs.js","sources":["../../src/wrapper/renovateRunner.ts"],"sourcesContent":["import is from '@sindresorhus/is';\nimport { getPlatformEnvs } from './platforms';\nimport { RouterOptions } from '../service/types';\nimport { extractReport, getCacheEnvs, getPassthroughEnvs } from './utils';\nimport {\n getTargetRepo,\n getTaskID,\n RenovateReport,\n RenovateWrapper,\n TargetRepo,\n} from '@secustor/backstage-plugin-renovate-common';\nimport { Config } from '@backstage/config';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { getRenovateConfig, getRuntimeConfigs } from '../config';\nimport { DatabaseHandler } from '../service/databaseHandler';\nimport { isError } from '@backstage/errors';\nimport { Entity } from '@backstage/catalog-model';\nimport { nanoid } from 'nanoid';\nimport { createQueue } from '../queue';\nimport {\n AddResult,\n QueueFactory,\n RenovateQueue,\n Runnable,\n RunOptions,\n} from '@secustor/backstage-plugin-renovate-node';\n\nexport class RenovateRunner implements Runnable<RunOptions> {\n private readonly queue: RenovateQueue<RunOptions>;\n\n constructor(\n queueFactories: Map<string, QueueFactory<RunOptions>>,\n private readonly databaseHandler: DatabaseHandler,\n private readonly rootConfig: Config,\n readonly logger: LoggerService,\n private readonly runtimes: Map<string, RenovateWrapper>,\n ) {\n this.queue = createQueue(queueFactories, rootConfig, this);\n }\n\n static async from(options: RouterOptions): Promise<RenovateRunner> {\n const { databaseHandler, rootConfig, runtimes, logger, queueFactories } =\n options;\n\n return new RenovateRunner(\n queueFactories,\n databaseHandler,\n rootConfig,\n logger,\n runtimes,\n );\n }\n\n async addToQueue(\n ...targets: (string | Entity | TargetRepo)[]\n ): Promise<AddResult[]> {\n const props = targets.map(target => {\n const jobId = getTaskID(target);\n const targetRepo = getTargetRepo(target);\n return {\n jobId,\n data: {\n id: jobId,\n target: targetRepo,\n },\n };\n });\n\n return await this.queue.addBulk(props);\n }\n\n async runNext(target: string | Entity | TargetRepo): Promise<AddResult> {\n const jobId = getTaskID(target);\n const targetRepo = getTargetRepo(target);\n\n return await this.queue.add(\n jobId,\n { id: jobId, target: targetRepo },\n {\n force: true,\n insertInFront: true,\n },\n );\n }\n\n async run(props: RunOptions): Promise<void> {\n const { id, target } = props;\n const runID = nanoid();\n const logger = this.logger.child({ runID, jobID: id, ...target });\n try {\n logger.info('Renovate run starting');\n const report = await this.renovate(props, logger);\n await this.databaseHandler.addReport({\n runID,\n taskID: id,\n report,\n target,\n logger,\n });\n logger.info('Renovate run successfully finished');\n } catch (e) {\n logger.error('Renovate failed', isError(e) ? e : {});\n }\n }\n\n async renovate(\n { id, target }: RunOptions,\n logger: LoggerService,\n ): Promise<RenovateReport> {\n const { runtime, config: runtimeConfig } = getRuntimeConfigs(\n this.rootConfig,\n );\n const wrapperRuntime = this.runtimes.get(runtime);\n if (is.nullOrUndefined(wrapperRuntime)) {\n throw new Error(`Unknown runtime type '${runtime}'`);\n }\n\n const env: Record<string, string> = {\n // setup logging\n LOG_FORMAT: 'json',\n LOG_LEVEL: 'debug',\n LOG_CONTEXT: id,\n RENOVATE_REPORT_TYPE: 'logging',\n // setup platform specifics\n ...(await getPlatformEnvs(target, {\n logger,\n rootConfig: this.rootConfig,\n })),\n ...getCacheEnvs(this.rootConfig, logger),\n ...getPassthroughEnvs(this.rootConfig, logger),\n };\n\n // read out renovate.config and write out to json file for consumption by Renovate\n // we are reading it at this place to allow dynamic configuration changes\n const renovateConfig = getRenovateConfig(this.rootConfig);\n\n const promise = wrapperRuntime.run({\n runID: id,\n env,\n renovateConfig,\n runtimeConfig,\n logger,\n });\n\n return promise.then(result => {\n return extractReport({\n logger,\n logStream: result.stdout,\n });\n });\n }\n}\n"],"names":["createQueue","getTaskID","getTargetRepo","nanoid","isError","getRuntimeConfigs","is","getPlatformEnvs","getCacheEnvs","getPassthroughEnvs","getRenovateConfig","extractReport"],"mappings":"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"}
@@ -71,7 +71,24 @@ function getCacheEnvs(config, logger) {
71
71
  RENOVATE_REDIS_URL: connection
72
72
  };
73
73
  }
74
+ function getPassthroughEnvs(config, logger) {
75
+ const env = {};
76
+ const passthroughEnvs = index.getPluginConfig(config).getOptionalConfigArray("runtime.environment") ?? [];
77
+ for (const e of passthroughEnvs) {
78
+ const name = e.getString("name");
79
+ const value = e.getOptionalString("value") ?? process.env[name];
80
+ if (value) {
81
+ env[name] = value;
82
+ } else {
83
+ logger.debug(
84
+ `utils::getPassthroughEnvs - no value found for environment variable ${name}`
85
+ );
86
+ }
87
+ }
88
+ return env;
89
+ }
74
90
 
75
91
  exports.extractReport = extractReport;
76
92
  exports.getCacheEnvs = getCacheEnvs;
93
+ exports.getPassthroughEnvs = getPassthroughEnvs;
77
94
  //# sourceMappingURL=utils.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.cjs.js","sources":["../../src/wrapper/utils.ts"],"sourcesContent":["import { RenovateReport } from '@secustor/backstage-plugin-renovate-common';\nimport { ExtractReportOptions } from './types';\nimport { Config } from '@backstage/config';\nimport is from '@sindresorhus/is';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { getPluginConfig } from '../config';\nimport { JsonObject } from '@backstage/types';\n\nexport async function extractReport(\n opts: ExtractReportOptions,\n): Promise<RenovateReport> {\n const { logStream, logger } = opts;\n return new Promise((resolve, reject) => {\n let uncompletedText = '';\n logStream.on('data', (chunk: Buffer) => {\n const text = uncompletedText.concat(chunk.toString());\n const logLines = text.split('\\n');\n\n // if the last element is an empty string, then we have a complete json line so we reset it.\n // else we save it to\n uncompletedText = logLines.pop() ?? '';\n\n for (const logLine of logLines) {\n const log: JsonObject = JSON.parse(logLine);\n if (log.report) {\n // TODO use schema and reject if report does not fit expectation\n const report = log.report as RenovateReport;\n // do not forward the report to logging\n resolve(report);\n continue;\n }\n\n const meta: JsonObject = {};\n // unpack log object\n for (const [key, value] of Object.entries(log)) {\n // skip fields which are transported outside of the meta object\n if (['msg', 'logContext', 'report'].includes(key)) {\n continue;\n }\n\n meta[key] = JSON.stringify(value);\n }\n\n const msg = is.string(log.msg) ? log.msg : JSON.stringify(log.msg);\n logger.debug(msg, meta);\n }\n });\n\n logStream.on('end', () => {\n if (uncompletedText) {\n logger.warn('Uncompleted log line found', { uncompletedText });\n reject(\n 'Premature exit of Renovate. Uncompleted log line found in log stream after end of stream',\n );\n }\n reject('No report found in log stream');\n });\n });\n}\n\nexport function getCacheEnvs(\n config: Config,\n logger: LoggerService,\n): Record<string, string> {\n const cacheEnabled =\n getPluginConfig(config).getOptionalBoolean('cache.enabled') ?? true;\n if (!cacheEnabled) {\n logger.debug('Cache has been disabled in plugin configuration');\n return {};\n }\n\n const cacheConfig = config.getOptionalConfig('backend.cache');\n if (is.nullOrUndefined(cacheConfig)) {\n logger.debug('No cache configured');\n return {};\n }\n\n const store = cacheConfig.getString('store');\n if (store !== 'redis') {\n logger.debug(`Unsupported cache store '${store}' detected`);\n return {};\n }\n\n const connection = cacheConfig.getOptionalString('connection');\n if (is.nullOrUndefined(connection)) {\n logger.debug('No connection string for redis cache configured in backend');\n return {};\n }\n\n logger.debug('Injecting Redis cache into Renovate');\n return {\n RENOVATE_REDIS_PREFIX: 'renovate_',\n RENOVATE_REDIS_URL: connection,\n };\n}\n"],"names":["is","getPluginConfig"],"mappings":"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"}
1
+ {"version":3,"file":"utils.cjs.js","sources":["../../src/wrapper/utils.ts"],"sourcesContent":["import { RenovateReport } from '@secustor/backstage-plugin-renovate-common';\nimport { ExtractReportOptions } from './types';\nimport { Config } from '@backstage/config';\nimport is from '@sindresorhus/is';\nimport { LoggerService } from '@backstage/backend-plugin-api';\nimport { getPluginConfig } from '../config';\nimport { JsonObject } from '@backstage/types';\n\nexport async function extractReport(\n opts: ExtractReportOptions,\n): Promise<RenovateReport> {\n const { logStream, logger } = opts;\n return new Promise((resolve, reject) => {\n let uncompletedText = '';\n logStream.on('data', (chunk: Buffer) => {\n const text = uncompletedText.concat(chunk.toString());\n const logLines = text.split('\\n');\n\n // if the last element is an empty string, then we have a complete json line so we reset it.\n // else we save it to\n uncompletedText = logLines.pop() ?? '';\n\n for (const logLine of logLines) {\n const log: JsonObject = JSON.parse(logLine);\n if (log.report) {\n // TODO use schema and reject if report does not fit expectation\n const report = log.report as RenovateReport;\n // do not forward the report to logging\n resolve(report);\n continue;\n }\n\n const meta: JsonObject = {};\n // unpack log object\n for (const [key, value] of Object.entries(log)) {\n // skip fields which are transported outside of the meta object\n if (['msg', 'logContext', 'report'].includes(key)) {\n continue;\n }\n\n meta[key] = JSON.stringify(value);\n }\n\n const msg = is.string(log.msg) ? log.msg : JSON.stringify(log.msg);\n logger.debug(msg, meta);\n }\n });\n\n logStream.on('end', () => {\n if (uncompletedText) {\n logger.warn('Uncompleted log line found', { uncompletedText });\n reject(\n 'Premature exit of Renovate. Uncompleted log line found in log stream after end of stream',\n );\n }\n reject('No report found in log stream');\n });\n });\n}\n\nexport function getCacheEnvs(\n config: Config,\n logger: LoggerService,\n): Record<string, string> {\n const cacheEnabled =\n getPluginConfig(config).getOptionalBoolean('cache.enabled') ?? true;\n if (!cacheEnabled) {\n logger.debug('Cache has been disabled in plugin configuration');\n return {};\n }\n\n const cacheConfig = config.getOptionalConfig('backend.cache');\n if (is.nullOrUndefined(cacheConfig)) {\n logger.debug('No cache configured');\n return {};\n }\n\n const store = cacheConfig.getString('store');\n if (store !== 'redis') {\n logger.debug(`Unsupported cache store '${store}' detected`);\n return {};\n }\n\n const connection = cacheConfig.getOptionalString('connection');\n if (is.nullOrUndefined(connection)) {\n logger.debug('No connection string for redis cache configured in backend');\n return {};\n }\n\n logger.debug('Injecting Redis cache into Renovate');\n return {\n RENOVATE_REDIS_PREFIX: 'renovate_',\n RENOVATE_REDIS_URL: connection,\n };\n}\n\nexport function getPassthroughEnvs(\n config: Config,\n logger: LoggerService,\n): Record<string, string> {\n const env: Record<string, string> = {};\n const passthroughEnvs =\n getPluginConfig(config).getOptionalConfigArray('runtime.environment') ?? [];\n\n for (const e of passthroughEnvs) {\n const name = e.getString('name');\n const value = e.getOptionalString('value') ?? process.env[name];\n if (value) {\n env[name] = value;\n } else {\n logger.debug(\n `utils::getPassthroughEnvs - no value found for environment variable ${name}`,\n );\n }\n }\n\n return env;\n}\n"],"names":["is","getPluginConfig"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@secustor/backstage-plugin-renovate-backend",
3
- "version": "0.15.8",
3
+ "version": "0.16.1",
4
4
  "main": "dist/index.cjs.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "type": "commonjs",
@@ -51,18 +51,18 @@
51
51
  "postpack": "backstage-cli package postpack"
52
52
  },
53
53
  "dependencies": {
54
- "@backstage/backend-defaults": "^0.11.0",
55
- "@backstage/backend-openapi-utils": "^0.5.3",
56
- "@backstage/backend-plugin-api": "^1.3.1",
54
+ "@backstage/backend-defaults": "^0.12.0",
55
+ "@backstage/backend-openapi-utils": "^0.6.0",
56
+ "@backstage/backend-plugin-api": "^1.4.2",
57
57
  "@backstage/backend-tasks": "^0.6.1",
58
- "@backstage/catalog-client": "^1.10.0",
59
- "@backstage/catalog-model": "^1.7.4",
60
- "@backstage/config": "^1.3.2",
58
+ "@backstage/catalog-client": "^1.11.0",
59
+ "@backstage/catalog-model": "^1.7.5",
60
+ "@backstage/config": "^1.3.3",
61
61
  "@backstage/errors": "^1.2.7",
62
- "@backstage/integration": "^1.17.0",
62
+ "@backstage/integration": "^1.17.1",
63
63
  "@backstage/types": "^1.2.1",
64
- "@secustor/backstage-plugin-renovate-common": "^0.9.2",
65
- "@secustor/backstage-plugin-renovate-node": "^0.5.6",
64
+ "@secustor/backstage-plugin-renovate-common": "^0.9.3",
65
+ "@secustor/backstage-plugin-renovate-node": "^0.5.7",
66
66
  "@sindresorhus/is": "^4.6.0",
67
67
  "@types/express": "^4.17.21",
68
68
  "express": "^4.17.1",
@@ -75,10 +75,10 @@
75
75
  "zod": "^3.22.4"
76
76
  },
77
77
  "devDependencies": {
78
- "@backstage/backend-test-utils": "^1.5.0",
79
- "@backstage/cli": "^0.33.0",
80
- "@backstage/repo-tools": "^0.14.0",
81
- "@backstage/test-utils": "^1.7.8",
78
+ "@backstage/backend-test-utils": "^1.8.0",
79
+ "@backstage/cli": "^0.34.0",
80
+ "@backstage/repo-tools": "^0.15.1",
81
+ "@backstage/test-utils": "^1.7.11",
82
82
  "@types/supertest": "^6.0.0",
83
83
  "jest-mock-extended": "^4.0.0",
84
84
  "msw": "^2.0.0",