Skip to content
Snippets Groups Projects
Select Git revision
  • 29dde2f6941c7f102bfc06cadb05e0e35e9204e9
  • main default protected
  • next
  • 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
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • gh-readonly-queue/next/pr-35009-9d5e583b7d7251148ab0d11ee8dd38149618d162
  • 41.17.2
  • 41.17.1
  • 41.17.0
  • 41.16.3
  • 41.16.2
  • 41.16.1
  • 41.16.0
  • 41.15.0
  • 41.14.0
  • 41.13.1
  • 41.13.0
  • 41.12.1
  • 41.12.0
  • 41.11.1
  • 41.11.0
  • 41.10.1
  • 41.10.0
  • 41.9.0
  • 41.8.0
  • 41.7.2
41 results

html.spec.ts

Blame
  • extract.ts NaN GiB
    import is from '@sindresorhus/is';
    import { XmlDocument, XmlElement, XmlNode } from 'xmldoc';
    import { logger } from '../../../logger';
    import { getSiblingFileName, localPathExists } from '../../../util/fs';
    import { hasKey } from '../../../util/object';
    import { regEx } from '../../../util/regex';
    import { NugetDatasource } from '../../datasource/nuget';
    import type {
      ExtractConfig,
      PackageDependency,
      PackageFileContent,
    } from '../types';
    import { extractMsbuildGlobalManifest } from './extract/global-manifest';
    import type { DotnetToolsManifest } from './types';
    import { getConfiguredRegistries } from './util';
    
    /**
     * https://docs.microsoft.com/en-us/nuget/concepts/package-versioning
     * This article mentions that  Nuget 3.x and later tries to restore the lowest possible version
     * regarding to given version range.
     * 1.3.4 equals [1.3.4,)
     * Due to guarantee that an update of package version will result in its usage by the next restore + build operation,
     * only following constrained versions make sense
     * 1.3.4, [1.3.4], [1.3.4, ], [1.3.4, )
     * The update of the right boundary does not make sense regarding to the lowest version restore rule,
     * so we don't include it in the extracting regexp
     */
    const checkVersion = regEx(
      `^\\s*(?:[[])?(?:(?<currentValue>[^"(,[\\]]+)\\s*(?:,\\s*[)\\]]|])?)\\s*$`
    );
    const elemNames = new Set([
      'PackageReference',
      'PackageVersion',
      'DotNetCliToolReference',
      'GlobalPackageReference',
    ]);
    
    function isXmlElem(node: XmlNode): boolean {
      return hasKey('name', node);
    }
    
    function extractDepsFromXml(xmlNode: XmlDocument): PackageDependency[] {
      const results: PackageDependency[] = [];
      const todo: XmlElement[] = [xmlNode];
      while (todo.length) {
        const child = todo.pop()!;
        const { name, attr } = child;
    
        if (elemNames.has(name)) {
          const depName = attr?.Include || attr?.Update;
          const version =
            attr?.Version ??
            child.valueWithPath('Version') ??
            attr?.VersionOverride ??
            child.valueWithPath('VersionOverride');
          const currentValue = is.nonEmptyStringAndNotWhitespace(version)
            ? checkVersion.exec(version)?.groups?.currentValue?.trim()
            : undefined;
          if (depName && currentValue) {
            results.push({
              datasource: NugetDatasource.id,
              depType: 'nuget',
              depName,
              currentValue,
            });
          }
        } else {
          todo.push(...(child.children.filter(isXmlElem) as XmlElement[]));
        }
      }
      return results;
    }
    
    export async function extractPackageFile(
      content: string,
      packageFile: string,
      _config: ExtractConfig
    ): Promise<PackageFileContent | null> {
      logger.trace(`nuget.extractPackageFile(${packageFile})`);
    
      const registries = await getConfiguredRegistries(packageFile);
      const registryUrls = registries
        ? registries.map((registry) => registry.url)
        : undefined;
    
      if (packageFile.endsWith('dotnet-tools.json')) {
        const deps: PackageDependency[] = [];
        let manifest: DotnetToolsManifest;
    
        try {
          manifest = JSON.parse(content);
        } catch (err) {
          logger.debug({ packageFile }, `Invalid JSON`);
          return null;
        }
    
        if (manifest.version !== 1) {
          logger.debug({ packageFile }, 'Unsupported dotnet tools version');
          return null;
        }
    
        for (const depName of Object.keys(manifest.tools ?? {})) {
          const tool = manifest.tools[depName];
          const currentValue = tool.version;
          const dep: PackageDependency = {
            depType: 'nuget',
            depName,
            currentValue,
            datasource: NugetDatasource.id,
          };
          if (registryUrls) {
            dep.registryUrls = registryUrls;
          }
    
          deps.push(dep);
        }
    
        return deps.length ? { deps } : null;
      }
    
      if (packageFile.endsWith('global.json')) {
        return extractMsbuildGlobalManifest(content, packageFile);
      }
    
      let deps: PackageDependency[] = [];
      let packageFileVersion = undefined;
      try {
        const parsedXml = new XmlDocument(content);
        deps = extractDepsFromXml(parsedXml).map((dep) => ({
          ...dep,
          ...(registryUrls && { registryUrls }),
        }));
        packageFileVersion = parsedXml.valueWithPath('PropertyGroup.Version');
      } catch (err) {
        logger.debug({ err, packageFile }, `Failed to parse XML`);
      }
    
      if (!deps.length) {
        return null;
      }
    
      const res: PackageFileContent = { deps, packageFileVersion };
      const lockFileName = getSiblingFileName(packageFile, 'packages.lock.json');
      // istanbul ignore if
      if (await localPathExists(lockFileName)) {
        res.lockFiles = [lockFileName];
      }
      return res;
    }