Socket
Socket
Sign inDemoInstall

snyk-nuget-plugin

Package Overview
Dependencies
Maintainers
1
Versions
123
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

snyk-nuget-plugin - npm Package Compare versions

Comparing version 1.25.5 to 1.26.0

dist/nuget-parser/dotnet-core-v2-parser.js

16

dist/index.js

@@ -37,3 +37,2 @@ "use strict";

const createPackageTree = (depTree) => {
// TODO implement for paket and more than one framework
const targetFramework = depTree.meta

@@ -58,2 +57,17 @@ ? depTree.meta.targetFramework

}
if (options['dotnet-runtime-resolution']) {
if (manifestType !== 'dotnet-core') {
return Promise.reject(new Error('runtime resolution beta flag is currently only applicable for .net core projects'));
}
const result = await nugetParser.buildDepGraphFromFiles(root, targetFile, manifestType, options['assets-project-name'], options['project-name-prefix']);
return {
dependencyGraph: result.dependencyGraph,
package: 'n/a',
plugin: {
name: 'snyk-nuget-plugin',
targetFile,
targetRuntime: result.targetFramework,
},
};
}
return nugetParser

@@ -60,0 +74,0 @@ .buildDepTreeFromFiles(root, targetFile, options.packagesFolder, manifestType, options['assets-project-name'], options['project-name-prefix'])

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getMinimumTargetFrameworkFromPackagesConfig = exports.buildDepTreeFromFiles = void 0;
exports.getMinimumTargetFrameworkFromPackagesConfig = exports.buildDepTreeFromFiles = exports.buildDepGraphFromFiles = void 0;
const fs = require("fs");

@@ -8,4 +8,4 @@ const path = require("path");

const debugModule = require("debug");
const debug = debugModule('snyk');
const dotnetCoreParser = require("./dotnet-core-parser");
const dotnetCoreV2Parser = require("./dotnet-core-v2-parser");
const dotnetFrameworkParser = require("./dotnet-framework-parser");

@@ -17,2 +17,3 @@ const projectJsonParser = require("./project-json-parser");

const framework_1 = require("./framework");
const debug = debugModule('snyk');
const PARSERS = {

@@ -23,2 +24,6 @@ 'dotnet-core': {

},
'dotnet-core-v2': {
depParser: dotnetCoreV2Parser,
fileContentParser: JSON,
},
'packages.config': {

@@ -46,11 +51,6 @@ depParser: dotnetFrameworkParser,

}
async function buildDepTreeFromFiles(root, targetFile, packagesFolderPath, manifestType, useProjectNameFromAssetsFile, projectNamePrefix) {
var _a, _b;
const safeRoot = root || '.';
const safeTargetFile = targetFile || '.';
const fileContentPath = path.resolve(safeRoot, safeTargetFile);
let fileContent;
function getFileContents(fileContentPath) {
try {
debug(`Parsing content of ${fileContentPath}`);
fileContent = fs.readFileSync(fileContentPath, 'utf-8');
return fs.readFileSync(fileContentPath, 'utf-8');
}

@@ -60,3 +60,38 @@ catch (error) {

}
}
async function buildDepGraphFromFiles(root, targetFile, manifestType, useProjectNameFromAssetsFile, projectNamePrefix) {
var _a, _b;
const safeRoot = root || '.';
const safeTargetFile = targetFile || '.';
const fileContentPath = path.resolve(safeRoot, safeTargetFile);
const fileContent = getFileContents(fileContentPath);
const projectRootFolder = path.resolve(fileContentPath, '../../');
const targetFramework = await (0, csproj_parser_1.getTargetFrameworksFromProjFile)(projectRootFolder);
const parser = PARSERS['dotnet-core-v2'];
const manifest = await parser.fileContentParser.parse(fileContent);
let resolvedProjectName = getRootName(root, projectRootFolder, projectNamePrefix);
if (manifestType === 'dotnet-core' && useProjectNameFromAssetsFile) {
const projectName = (_b = (_a = manifest === null || manifest === void 0 ? void 0 : manifest.project) === null || _a === void 0 ? void 0 : _a.restore) === null || _b === void 0 ? void 0 : _b.projectName;
if (projectName) {
resolvedProjectName = projectName;
}
else {
debug("project.assets.json file doesn't contain a value for 'projectName'. Using default value: " +
resolvedProjectName);
}
}
const depGraph = parser.depParser.parse(resolvedProjectName, manifest);
return {
dependencyGraph: depGraph,
targetFramework: targetFramework === null || targetFramework === void 0 ? void 0 : targetFramework.original,
};
}
exports.buildDepGraphFromFiles = buildDepGraphFromFiles;
async function buildDepTreeFromFiles(root, targetFile, packagesFolderPath, manifestType, useProjectNameFromAssetsFile, projectNamePrefix) {
var _a, _b;
const safeRoot = root || '.';
const safeTargetFile = targetFile || '.';
const fileContentPath = path.resolve(safeRoot, safeTargetFile);
const fileContent = getFileContents(fileContentPath);
const projectRootFolder = path.resolve(fileContentPath, '../../');
const packagesFolder = getPackagesFolder(packagesFolderPath, projectRootFolder);

@@ -63,0 +98,0 @@ const tree = {

3

package.json

@@ -37,2 +37,3 @@ {

"dependencies": {
"@snyk/dep-graph": "^2.7.0",
"debug": "^4.3.4",

@@ -57,3 +58,3 @@ "dotnet-deps-parser": "5.3.0",

},
"version": "1.25.5"
"version": "1.26.0"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc