Skip to content
Snippets Groups Projects
Select Git revision
  • 713e35e88f30629689643f8bcf70cdd8ed21bbcd
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • 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
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
  • 41.24.0
  • 41.23.5
  • 41.23.4
41 results

index.ts

Blame
  • fetch.ts 4.39 KiB
    import is from '@sindresorhus/is';
    import pAll from 'p-all';
    import { logger } from '../../../logger';
    import { getPackageUpdates } from '../../../manager';
    import {
      getManagerConfig,
      mergeChildConfig,
      RenovateConfig,
      ManagerConfig,
    } from '../../../config';
    import { applyPackageRules } from '../../../util/package-rules';
    import { lookupUpdates, LookupUpdateConfig, UpdateResult } from './lookup';
    import {
      PackageFile,
      PackageDependency,
      PackageUpdateResult,
    } from '../../../manager/common';
    import { SkipReason } from '../../../types';
    
    async function fetchDepUpdates(
      packageFileConfig: ManagerConfig & PackageFile,
      dep: PackageDependency
    ): Promise<void> {
      /* eslint-disable no-param-reassign */
      dep.updates = [];
      if (dep.skipReason) {
        return;
      }
      const { manager, packageFile } = packageFileConfig;
      const { depName, currentValue } = dep;
      // TODO: fix types
      let depConfig = mergeChildConfig(packageFileConfig, dep);
      depConfig = applyPackageRules(depConfig);
      if (depConfig.ignoreDeps.includes(depName)) {
        logger.debug({ dependency: dep.depName }, 'Dependency is ignored');
        dep.skipReason = SkipReason.Ignored;
      } else if (
        depConfig.internalPackages &&
        depConfig.internalPackages.includes(depName)
      ) {
        logger.debug(
          { dependency: dep.depName },
          'Dependency is ignored due to being internal'
        );
        dep.skipReason = SkipReason.InternalPackage;
      } else if (depConfig.enabled === false) {
        logger.debug({ dependency: dep.depName }, 'Dependency is disabled');
        dep.skipReason = SkipReason.Disabled;
      } else {
        let lookupResults: UpdateResult | PackageUpdateResult[];
        if (depConfig.datasource) {
          lookupResults = await lookupUpdates(depConfig as LookupUpdateConfig);
        } else {
          lookupResults = await getPackageUpdates(manager, depConfig);
        }
        // istanbul ignore else
        if (is.array(lookupResults)) {
          dep.updates = lookupResults;
        } else {
          Object.assign(dep, lookupResults);
        }
        // istanbul ignore if
        if (dep.updates.length) {
          logger.trace(
            { dependency: depName },
            `${dep.updates.length} result(s): ${dep.updates.map(
              upgrade => upgrade.newValue
            )}`
          );
        }