Skip to content
Snippets Groups Projects
Select Git revision
  • bf378a46377cd98bb00e7b4053c179474316ce27
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-11.x
  • renovate/main-vitest-eslint-plugin-1.x
  • renovate/main-actions-setup-node-5.x
  • jamietanna-patch-2
  • jamietanna-patch-1
  • test/mc-maven
  • feat/minimumReleaseAgeTimestamp-required
  • defect/test-name
  • renovate/main-linters
  • renovate/main-find-up-8.x
  • refactor/pin-new-value
  • fix/user-agent
  • feat/37517-base64-private-key
  • next
  • feat/gnupg
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • 41.144.1
  • 41.144.0
  • 41.143.3
  • 41.143.2
  • 41.143.1
  • 41.143.0
  • 41.142.1
  • 41.142.0
  • 41.141.0
  • 41.140.3
  • 41.140.2
  • 41.140.1
  • 41.140.0
  • 41.139.1
  • 41.139.0
  • 41.138.5
  • 41.138.4
  • 41.138.3
  • 41.138.2
  • 41.138.1
41 results

deprecated.ts

Blame
  • user avatar
    Michael Kriese authored and GitHub committed
    * refactor:  enable strict checks
    
    * chore: revert changes
    
    * chore: fix tsconfig
    e5c6f38d
    History
    deprecated.ts 3.14 KiB
    // TODO #7154
    import { GlobalConfig } from '../../../config/global';
    import type { RenovateConfig } from '../../../config/types';
    import { logger } from '../../../logger';
    import type { PackageFile } from '../../../modules/manager/types';
    import { platform } from '../../../modules/platform';
    
    export async function raiseDeprecationWarnings(
      config: RenovateConfig,
      packageFiles: Record<string, PackageFile[]>
    ): Promise<void> {
      if (!config.repoIsOnboarded) {
        return;
      }
      if (config.suppressNotifications?.includes('deprecationWarningIssues')) {
        return;
      }
      for (const [manager, files] of Object.entries(packageFiles)) {
        const deprecatedPackages: Record<
          string,
          { deprecationMessage?: string; depPackageFiles: string[] }
        > = {};
        for (const packageFile of files) {
          for (const dep of packageFile.deps) {
            const { deprecationMessage } = dep;
            if (deprecationMessage) {
              deprecatedPackages[dep.depName!] = deprecatedPackages[
                dep.depName!
              ] || {
                deprecationMessage,
                depPackageFiles: [],
              };
              deprecatedPackages[dep.depName!].depPackageFiles.push(
                packageFile.packageFile!
              );
            }
          }
        }
    
        logger.debug({ deprecatedPackages });
        const issueTitleList: string[] = [];
        const issueTitlePrefix = 'Dependency deprecation warning:';
        for (const [depName, val] of Object.entries(deprecatedPackages)) {
          const { deprecationMessage, depPackageFiles } = val;
          logger.debug(
            {
              depName,
              deprecationMessage,
              packageFiles: depPackageFiles,
            },
            'dependency is deprecated'
          );
          const issueTitle = `${issueTitlePrefix} ${depName} (${manager})`;
          issueTitleList.push(issueTitle);
          let issueBody = deprecationMessage;
          issueBody += `\n\nAffected package file(s): ${depPackageFiles
            .map((f) => '`' + f + '`')
            .join(', ')}`;
          issueBody += `\n\nIf you don't care about this, you can close this issue and not be warned about \`${depName}\`'s deprecation again. If you would like to completely disable all future deprecation warnings then add the following to your config:\n\n\`\`\`\n"suppressNotifications": ["deprecationWarningIssues"]\n\`\`\`\n\n`;
          // istanbul ignore if
          if (GlobalConfig.get('dryRun')) {
            logger.info('DRY-RUN: Ensure deprecation warning issue for ' + depName);
          } else {
            const ensureOnce = true;
            await platform.ensureIssue({
              title: issueTitle,
              body: issueBody!,
              once: ensureOnce,
              confidential: config.confidential,
            });
          }
        }
        logger.debug(
          'Checking for existing deprecated package issues missing in current deprecatedPackages'
        );
        const issueList = await platform.getIssueList();
        if (issueList?.length) {
          const deprecatedIssues = issueList.filter(
            (i) => i.title!.startsWith(issueTitlePrefix) && i.state === 'open'
          );
          for (const i of deprecatedIssues) {
            if (!issueTitleList.includes(i.title!)) {
              await platform.ensureIssueClosing(i.title!);
            }
          }
        }
      }
    }