@secustor/backstage-plugin-renovate-backend 0.13.0 → 0.13.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,11 @@
1
1
  # @secustor/backstage-plugin-renovate-backend
2
2
 
3
+ ## 0.13.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [#425](https://github.com/secustor/backstage-plugins/pull/425) [`a53c9df`](https://github.com/secustor/backstage-plugins/commit/a53c9df5d41ec8988a742305d7ed9e127143bf65) Thanks [@secustor](https://github.com/secustor)! - Use correct table for dependency maintenance table
8
+
3
9
  ## 0.13.0
4
10
 
5
11
  ### Minor Changes
package/dist/index.d.ts CHANGED
@@ -13,7 +13,7 @@ declare class DatabaseHandler {
13
13
  private constructor();
14
14
  addReport(options: AddReportParameters): Promise<void>;
15
15
  getReports(query?: ReportQueryParameters): Promise<RepositoryReportResponse>;
16
- getTargets(): Promise<ReportTargetQuery[]>;
16
+ getTargets(table?: 'reports' | 'dependencies'): Promise<ReportTargetQuery[]>;
17
17
  deleteReportsByTarget({ host, repository }: ReportTargetQuery, options?: DeleteOptions): Promise<number>;
18
18
  deleteReports(options?: DeleteOptions): Promise<number>;
19
19
  private updateDependencies;
@@ -63,8 +63,8 @@ class DatabaseHandler {
63
63
  };
64
64
  });
65
65
  }
66
- async getTargets() {
67
- return this.client.select().distinct("host", "repository").from("reports");
66
+ async getTargets(table = "reports") {
67
+ return this.client.select().distinct("host", "repository").from(table);
68
68
  }
69
69
  async deleteReportsByTarget({ host, repository }, options) {
70
70
  const offset = getOffset(options);
@@ -228,7 +228,7 @@ class DatabaseHandler {
228
228
  return result;
229
229
  }
230
230
  async deleteDependencies(options) {
231
- const targets = await this.getTargets();
231
+ const targets = await this.getTargets("dependencies");
232
232
  const modified = await Promise.all(
233
233
  targets.map((target) => this.deleteDependenciesByTarget(target, options))
234
234
  );
@@ -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.toISOString(),\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(): Promise<ReportTargetQuery[]> {\n return this.client\n .select()\n .distinct<ReportsRow[]>('host', 'repository')\n .from('reports');\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?: 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();\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\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.toISOString(),\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?: 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\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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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@secustor/backstage-plugin-renovate-backend",
3
- "version": "0.13.0",
3
+ "version": "0.13.1",
4
4
  "main": "dist/index.cjs.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "type": "commonjs",