Skip to content
Snippets Groups Projects
Select Git revision
  • 4bc7414df2fa67ad51e1512d3ef1ea5ddbb99c1b
  • main default protected
  • feat/gnupg
  • next
  • fix/36615b-branch-reuse-no-cache
  • renovate/main-redis-5.x
  • chore/punycode
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • gh-readonly-queue/next/pr-35009-9d5e583b7d7251148ab0d11ee8dd38149618d162
  • 41.43.5
  • 41.43.4
  • 41.43.3
  • 41.43.2
  • 41.43.1
  • 41.43.0
  • 41.42.12
  • 41.42.11
  • 41.42.10
  • 41.42.9
  • 41.42.8
  • 41.42.7
  • 41.42.6
  • 41.42.5
  • 41.42.4
  • 41.42.3
  • 41.42.2
  • 41.42.1
  • 41.42.0
  • 41.41.0
41 results

errors.spec.ts

Blame
  • utils.ts 3.02 KiB
    import { URL } from 'url';
    import is from '@sindresorhus/is';
    import type { RegexManagerTemplates } from '../../../config/types';
    import { logger } from '../../../logger';
    import * as template from '../../../util/template';
    import type { CustomExtractConfig, PackageDependency } from '../types';
    import type { ExtractionTemplate } from './types';
    
    export const validMatchFields = [
      'depName',
      'packageName',
      'currentValue',
      'currentDigest',
      'datasource',
      'versioning',
      'extractVersion',
      'registryUrl',
      'depType',
    ] as const;
    
    type ValidMatchFields = typeof validMatchFields[number];
    
    function updateDependency(
      dependency: PackageDependency,
      field: ValidMatchFields,
      value: string
    ): void {
      switch (field) {
        case 'registryUrl':
          // check if URL is valid and pack inside an array
          try {
            const url = new URL(value).toString();
            dependency.registryUrls = [url];
          } catch (err) {
            logger.warn({ value }, 'Invalid regex manager registryUrl');
          }
          break;
        default:
          dependency[field] = value;
          break;
      }
    }
    
    export function createDependency(
      extractionTemplate: ExtractionTemplate,
      config: CustomExtractConfig,
      dep?: PackageDependency
    ): PackageDependency | null {
      const dependency = dep ?? {};
      const { groups, replaceString } = extractionTemplate;
    
      for (const field of validMatchFields) {
        const fieldTemplate = `${field}Template` as keyof RegexManagerTemplates;
        const tmpl = config[fieldTemplate];
        if (tmpl) {
          try {
            const compiled = template.compile(tmpl, groups, false);
            updateDependency(dependency, field, compiled);
          } catch (err) {
            logger.warn(
              { template: tmpl },
              'Error compiling template for custom manager'
            );
            return null;
          }
        } else if (groups[field]) {
          updateDependency(dependency, field, groups[field]);
        }
      }
      dependency.replaceString = replaceString;
      return dependency;
    }
    
    export function regexMatchAll(
      regex: RegExp,
      content: string
    ): RegExpMatchArray[] {
      const matches: RegExpMatchArray[] = [];
      let matchResult: RegExpMatchArray | null;
      do {
        matchResult = regex.exec(content);
        if (matchResult) {
          matches.push(matchResult);
        }
      } while (matchResult);
      return matches;
    }
    
    export function mergeGroups(
      mergedGroup: Record<string, string>,
      secondGroup: Record<string, string>
    ): Record<string, string> {
      return { ...mergedGroup, ...secondGroup };
    }
    
    export function mergeExtractionTemplate(
      base: ExtractionTemplate,
      addition: ExtractionTemplate
    ): ExtractionTemplate {
      return {
        groups: mergeGroups(base.groups, addition.groups),
        replaceString: addition.replaceString ?? base.replaceString,
      };
    }
    
    export function isValidDependency({
      depName,
      currentValue,
      currentDigest,
    }: PackageDependency): boolean {
      // check if all the fields are set
      return (
        is.nonEmptyStringAndNotWhitespace(depName) &&
        (is.nonEmptyStringAndNotWhitespace(currentDigest) ||
          is.nonEmptyStringAndNotWhitespace(currentValue))
      );
    }