Skip to content

Commit

Permalink
Merge pull request #1459 from snyk/feat/container-static-scanning
Browse files Browse the repository at this point in the history
Feat/container static scanning
  • Loading branch information
ivanstanev authored Oct 15, 2020
2 parents d0f71d4 + 188baaa commit c2815f6
Show file tree
Hide file tree
Showing 27 changed files with 2,023 additions and 1,253 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@
"semver": "^6.0.0",
"snyk-config": "3.1.1",
"snyk-cpp-plugin": "2.0.0",
"snyk-docker-plugin": "3.26.2",
"snyk-docker-plugin": "4.1.1",
"snyk-go-plugin": "1.16.2",
"snyk-gradle-plugin": "3.10.0",
"snyk-module": "3.1.0",
Expand Down
20 changes: 20 additions & 0 deletions src/cli/commands/monitor/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ import { PluginMetadata } from '@snyk/cli-interface/legacy/plugin';
import { getContributors } from '../../../lib/monitor/dev-count-analysis';
import { FailedToRunTestError, MonitorError } from '../../../lib/errors';
import { isMultiProjectScan } from '../../../lib/is-multi-project-scan';
import { getEcosystem, monitorEcosystem } from '../../../lib/ecosystems';
import { getFormattedMonitorOutput } from '../../../lib/ecosystems/monitor';

const SEPARATOR = '\n-------------------------------------------------------\n';
const debug = Debug('snyk');
Expand Down Expand Up @@ -95,6 +97,24 @@ async function monitor(...args0: MethodArgs): Promise<any> {
}
}

const ecosystem = getEcosystem(options);
if (ecosystem) {
const commandResult = await monitorEcosystem(
ecosystem,
args as string[],
options,
);

const [monitorResults, monitorErrors] = commandResult;

return await getFormattedMonitorOutput(
results,
monitorResults,
monitorErrors,
options,
);
}

// Part 1: every argument is a scan target; process them sequentially
for (const path of args as string[]) {
debug(`Processing ${path}...`);
Expand Down
7 changes: 7 additions & 0 deletions src/cli/commands/test/formatters/format-test-meta.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,13 @@ export function formatTestMeta(
chalk.bold(rightPadWithSpaces('Docker image: ', padToLength)) +
options.path,
);

if (res.platform) {
meta.push(
chalk.bold(rightPadWithSpaces('Platform: ', padToLength)) +
res.platform,
);
}
} else {
meta.push(
chalk.bold(rightPadWithSpaces('Open source: ', padToLength)) + openSource,
Expand Down
6 changes: 3 additions & 3 deletions src/cli/commands/test/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ import {
} from './formatters';
import * as utils from './utils';
import { getIacDisplayedOutput, createSarifOutputForIac } from './iac-output';
import { getEcosystem, testEcosystem } from '../../../lib/ecosystems';
import { getEcosystemForTest, testEcosystem } from '../../../lib/ecosystems';
import { isMultiProjectScan } from '../../../lib/is-multi-project-scan';
import { createSarifOutputForContainers } from './sarif-output';
import {
Expand Down Expand Up @@ -107,14 +107,14 @@ async function test(...args: MethodArgs): Promise<TestCommandResult> {
apiTokenExists();
} catch (err) {
if (options.docker && getDockerToken()) {
options.testDepGraphDockerEndpoint = '/docker-jwt/test-dep-graph';
options.testDepGraphDockerEndpoint = '/docker-jwt/test-dependencies';
options.isDockerUser = true;
} else {
throw err;
}
}

const ecosystem = getEcosystem(options);
const ecosystem = getEcosystemForTest(options);
if (ecosystem) {
try {
const commandResult = await testEcosystem(
Expand Down
160 changes: 0 additions & 160 deletions src/lib/ecosystems.ts

This file was deleted.

32 changes: 32 additions & 0 deletions src/lib/ecosystems/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import { Options } from '../types';
import { Ecosystem } from './types';

export { testEcosystem } from './test';
export { monitorEcosystem } from './monitor';
export { getPlugin } from './plugins';

/**
* Ecosystems are listed here if you opt in to the new plugin test flow.
* This is a breaking change to the old plugin formats, so only a select few
* plugins currently work with it.
*
* Currently container scanning is not yet ready to work with this flow,
* hence this is in a separate function from getEcosystem().
*/
export function getEcosystemForTest(options: Options): Ecosystem | null {
if (options.source) {
return 'cpp';
}
return null;
}

export function getEcosystem(options: Options): Ecosystem | null {
if (options.source) {
return 'cpp';
}

if (options.docker) {
return 'docker';
}
return null;
}
Loading

0 comments on commit c2815f6

Please sign in to comment.