Skip to content

Commit

Permalink
chore: update eslint & ts configs (#273)
Browse files Browse the repository at this point in the history
  • Loading branch information
fraxken authored Jan 4, 2025
1 parent 14bdb2c commit 8d0e663
Show file tree
Hide file tree
Showing 19 changed files with 167 additions and 182 deletions.
10 changes: 0 additions & 10 deletions .eslintrc

This file was deleted.

2 changes: 1 addition & 1 deletion .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ jobs:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v2.6.0
- uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
with:
node-version: 16.x
node-version: 22.x
- name: Install dependencies
run: npm install
- name: Run ESLint
Expand Down
3 changes: 3 additions & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { typescriptConfig } from "@openally/config.eslint";

export default typescriptConfig();
5 changes: 3 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
"scripts": {
"build": "tsc",
"prepublishOnly": "npm run build",
"lint": "cross-env eslint src/**/*.ts",
"lint": "eslint src test",
"test-only": "glob -c \"tsx --test\" \"./test/**/*.spec.ts\"",
"unit-test-only": "glob -c \"tsx --test\" \"./test/**/*.unit.spec.ts\"",
"integration-test-only": "glob -c \"tsx --test\" \"./test/**/*.integration.spec.ts\"",
Expand Down Expand Up @@ -46,7 +46,8 @@
},
"homepage": "https://github.com/NodeSecure/vulnera#readme",
"devDependencies": {
"@nodesecure/eslint-config": "^1.8.0",
"@openally/config.eslint": "^1.1.0",
"@openally/config.typescript": "^1.0.3",
"@slimio/is": "^2.0.0",
"@types/node": "^22.1.0",
"c8": "^10.1.2",
Expand Down
6 changes: 3 additions & 3 deletions src/database/osv.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import * as httpie from "@myunisoft/httpie";

// Import Internal Dependencies
import { OSV } from "../formats/osv";
import type { OSV } from "../formats/osv/index.js";
import * as utils from "../utils.js";

// CONSTANTS
Expand All @@ -17,7 +17,7 @@ export type OSVApiParameter = {
*/
ecosystem?: string;
};
}
};

export async function findOne(
parameters: OSVApiParameter
Expand All @@ -26,7 +26,7 @@ export async function findOne(
parameters.package.ecosystem = "npm";
}

const { data } = await httpie.post<{ vulns: OSV[] }>(
const { data } = await httpie.post<{ vulns: OSV[]; }>(
new URL("v1/query", ROOT_API),
{
body: parameters
Expand Down
16 changes: 8 additions & 8 deletions src/database/snyk.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,20 @@ import * as httpie from "@myunisoft/httpie";

// Import Internal Dependencies
import { SNYK_ORG, SNYK_TOKEN } from "../constants.js";
import { SnykAuditResponse } from "../formats/snyk/index.js";
import type { SnykAuditResponse } from "../formats/snyk/index.js";

// CONSTANTS
export const ROOT_API = "https://snyk.io";

export type SnykFindOneParameters = {
files: {
target: {
contents: string;
};
additional?: {
contents: string;
}[];
files: {
target: {
contents: string;
};
additional?: {
contents: string;
}[];
};
};

export async function findOne(
Expand Down
2 changes: 1 addition & 1 deletion src/formats/osv/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ export type OSVCreditType = "FINDER" |

export interface OSVAffected {
package: {
ecosystem: "npm",
ecosystem: "npm";
name: string;
purl: string;
};
Expand Down
154 changes: 77 additions & 77 deletions src/formats/snyk/index.ts
Original file line number Diff line number Diff line change
@@ -1,89 +1,89 @@
export interface SnykPatch {
id: string;
urls: string[];
version: string;
modificationTime: string;
comments: string[];
id: string;
urls: string[];
version: string;
modificationTime: string;
comments: string[];
}

export interface SnykVulnerability {
/** The issue ID **/
id: string;
/** A link to the issue details on snyk.io **/
url: string;
/** The issue title **/
title: string;
/** The issue type **/
type: "vulnerability" | "license";
/** The paths to the dependencies which have an issue, and their corresponding upgrade path (if an upgrade is available) **/
paths?: Array<{
"from": Array<string>,
"upgrade": Array<string | boolean>
}>;
/** The package identifier according to its package manager **/
package: string;
/** The package version this issue is applicable to. **/
version: string;
/** The Snyk defined severity level **/
severity: "critical" | "high" | "medium" | "low";
/** The package's programming language **/
language: string;
/** The package manager **/
packageManager: string;
/** One or more semver ranges this issue is applicable to. **/
semver: Record<string, string[]>;
/** The vulnerability publication time **/
publicationTime: string;
/** The time this vulnerability was originally disclosed to the package maintainers **/
disclosureTime: string;
/** Is this vulnerability fixable by upgrading a dependency? **/
isUpgradable: boolean;
/** The detailed description of the vulnerability, why and how it is exploitable. **/
description: string;
/** Is this vulnerability fixable by using a Snyk supplied patch? **/
isPatchable: boolean;
/** Is this vulnerability fixable by pinning a transitive dependency **/
isPinnable: boolean;
/** Additional vulnerability identifiers **/
identifiers: Record<string, string[]>;
/** The reporter of the vulnerability **/
credit: string;
/**
/** The issue ID **/
id: string;
/** A link to the issue details on snyk.io **/
url: string;
/** The issue title **/
title: string;
/** The issue type **/
type: "vulnerability" | "license";
/** The paths to the dependencies which have an issue, and their corresponding upgrade path (if an upgrade is available) **/
paths?: Array<{
from: Array<string>;
upgrade: Array<string | boolean>;
}>;
/** The package identifier according to its package manager **/
package: string;
/** The package version this issue is applicable to. **/
version: string;
/** The Snyk defined severity level **/
severity: "critical" | "high" | "medium" | "low";
/** The package's programming language **/
language: string;
/** The package manager **/
packageManager: string;
/** One or more semver ranges this issue is applicable to. **/
semver: Record<string, string[]>;
/** The vulnerability publication time **/
publicationTime: string;
/** The time this vulnerability was originally disclosed to the package maintainers **/
disclosureTime: string;
/** Is this vulnerability fixable by upgrading a dependency? **/
isUpgradable: boolean;
/** The detailed description of the vulnerability, why and how it is exploitable. **/
description: string;
/** Is this vulnerability fixable by using a Snyk supplied patch? **/
isPatchable: boolean;
/** Is this vulnerability fixable by pinning a transitive dependency **/
isPinnable: boolean;
/** Additional vulnerability identifiers **/
identifiers: Record<string, string[]>;
/** The reporter of the vulnerability **/
credit: string;
/**
* Common Vulnerability Scoring System (CVSS) provides a way to capture the principal characteristics
* of a vulnerability, and produce a numerical score reflecting its severity,
* as well as a textual representation of that score.
* **/
CVSSv3: string;
/** CVSS Score **/
cvssScore: number;
/** Patches to fix this issue, by snyk **/
patches: SnykPatch[];
/** The path to upgrade this issue, if applicable **/
upgradePath: string[];
/** Is this vulnerability patched? **/
isPatched: boolean;
/** The snyk exploit maturity level **/
exploitMaturity: string;
functions: any;
CVSSv3: string;
/** CVSS Score **/
cvssScore: number;
/** Patches to fix this issue, by snyk **/
patches: SnykPatch[];
/** The path to upgrade this issue, if applicable **/
upgradePath: string[];
/** Is this vulnerability patched? **/
isPatched: boolean;
/** The snyk exploit maturity level **/
exploitMaturity: string;
functions: any;
}

export interface SnykAuditResponse {
/** Does this package have one or more issues? **/
ok: boolean;
/** The issues found. **/
issues: {
vulnerabilities: SnykVulnerability[];
licenses: SnykVulnerability[];
};
/** The number of dependencies the package has. **/
dependencyCount: number;
/** The organization this test was carried out for. **/
org: {
id: string;
name: string;
};
/** The organization's licenses policy used for this test **/
licensesPolicy: null | object;
/** The package manager for this package **/
packageManager: string;
/** Does this package have one or more issues? **/
ok: boolean;
/** The issues found. **/
issues: {
vulnerabilities: SnykVulnerability[];
licenses: SnykVulnerability[];
};
/** The number of dependencies the package has. **/
dependencyCount: number;
/** The organization this test was carried out for. **/
org: {
id: string;
name: string;
};
/** The organization's licenses policy used for this test **/
licensesPolicy: null | object;
/** The package manager for this package **/
packageManager: string;
}
3 changes: 1 addition & 2 deletions src/formats/standard/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// Import Internal Dependencies
import { VULN_MAPPERS } from "./mappers.js";
import { Kind } from "../../constants.js";
import type { Kind } from "../../constants.js";

export type Severity = "info" | "low" | "medium" | "high" | "critical";

Expand Down Expand Up @@ -76,4 +76,3 @@ export function standardizeVulnsPayload(useStandardFormat = false) {
};
}


14 changes: 8 additions & 6 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,7 @@ import {

import {
SnykStrategy,
type SnykStrategyDefinition,
type SnykVulnerability
type SnykStrategyDefinition
} from "./strategies/snyk.js";

import {
Expand All @@ -28,6 +27,9 @@ import {
type Kind
} from "./constants.js";

import type {
SnykVulnerability
} from "./formats/snyk/index.js";
import type {
StandardVulnerability, Severity, StandardPatch
} from "./formats/standard/index.js";
Expand All @@ -49,10 +51,10 @@ import type {
export * as Database from "./database/index.js";

export type AllStrategy = {
"none": NoneStrategyDefinition;
none: NoneStrategyDefinition;
"github-advisory": GithubAdvisoryStrategyDefinition;
"snyk": SnykStrategyDefinition;
"sonatype": SonatypeStrategyDefinition;
snyk: SnykStrategyDefinition;
sonatype: SonatypeStrategyDefinition;
};
export type AnyStrategy = AllStrategy[keyof AllStrategy];

Expand Down Expand Up @@ -98,7 +100,7 @@ export function getStrategy(): AnyStrategy {
export const strategies = VULN_MODE;
export const defaultStrategyName = VULN_MODE.NONE;

export {
export type {
Kind,
BaseStrategyOptions,
BaseStrategy,
Expand Down
13 changes: 7 additions & 6 deletions src/strategies/github-advisory.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,17 @@
/* eslint-disable no-empty */
// Import Node.js Dependencies
import fs from "node:fs/promises";
import path from "node:path";

// Import Third-party Dependencies
import Arborist from "@npmcli/arborist";
import { audit, AuditAdvisory } from "@pnpm/audit";
import { audit, type AuditAdvisory } from "@pnpm/audit";
import { getLocalRegistryURL } from "@nodesecure/npm-registry-sdk";
import { readWantedLockfile } from "@pnpm/lockfile-file";

// Import Internal Dependencies
import { VULN_MODE, NPM_TOKEN } from "../constants.js";
import { StandardVulnerability, standardizeVulnsPayload } from "../formats/standard/index.js";
import { type StandardVulnerability, standardizeVulnsPayload } from "../formats/standard/index.js";
import type { Dependencies } from "./types/scanner.js";
import type {
BaseStrategyOptions,
Expand Down Expand Up @@ -44,7 +45,7 @@ export type NpmAuditAdvisory = {
range: string;
/** The set of versions that are vulnerable **/
vulnerableVersions?: string[];
}
};

export type PnpmAuditAdvisory = Exclude<AuditAdvisory, "cwe"> & {
github_advisory_id: string;
Expand All @@ -53,11 +54,11 @@ export type PnpmAuditAdvisory = Exclude<AuditAdvisory, "cwe"> & {
cvss: {
score: number;
vectorString: string;
}
};
};
export type GithubVulnerability = PnpmAuditAdvisory | NpmAuditAdvisory;

export type GithubAdvisoryStrategyDefinition = ExtendedStrategy<"github-advisory", GithubVulnerability>
export type GithubAdvisoryStrategyDefinition = ExtendedStrategy<"github-advisory", GithubVulnerability>;

export function GitHubAdvisoryStrategy(): GithubAdvisoryStrategyDefinition {
return {
Expand Down Expand Up @@ -140,7 +141,7 @@ async function npmAudit(
registry: string
): Promise<NpmAuditAdvisory[]> {
const arborist = new Arborist({ ...NPM_TOKEN, registry, path });
const { vulnerabilities } = (await arborist.audit()).toJSON() as { vulnerabilities: any[] };
const { vulnerabilities } = (await arborist.audit()).toJSON() as { vulnerabilities: any[]; };

// TODO: remove Symbols?
return Object.values(vulnerabilities)
Expand Down
1 change: 0 additions & 1 deletion src/strategies/none.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ export function NoneStrategy(): NoneStrategyDefinition {
};
}

// eslint-disable-next-line @typescript-eslint/no-unused-vars
async function hydratePayloadDependencies(dependencies: any) {
// Do nothing
}
Loading

0 comments on commit 8d0e663

Please sign in to comment.