forked from guacsec/trustify-da-javascript-client
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathprovider.js
More file actions
50 lines (46 loc) · 2.18 KB
/
provider.js
File metadata and controls
50 lines (46 loc) · 2.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import path from 'node:path'
import golangGomodulesProvider from './providers/golang_gomodules.js'
import Java_gradle_groovy from "./providers/java_gradle_groovy.js";
import Java_gradle_kotlin from "./providers/java_gradle_kotlin.js";
import Java_maven from "./providers/java_maven.js";
import Javascript_npm from './providers/javascript_npm.js';
import Javascript_pnpm from './providers/javascript_pnpm.js';
import Javascript_yarn from './providers/javascript_yarn.js';
import pythonPipProvider from './providers/python_pip.js'
/** @typedef {{ecosystem: string, contentType: string, content: string}} Provided */
/** @typedef {{isSupported: function(string): boolean, validateLockFile: function(string): void, provideComponent: function(string, {}): Provided, provideStack: function(string, {}): Provided}} Provider */
/**
* MUST include all providers here.
* @type {[Provider]}
*/
export const availableProviders = [
new Java_maven(),
new Java_gradle_groovy(),
new Java_gradle_kotlin(),
new Javascript_npm(),
new Javascript_pnpm(),
new Javascript_yarn(),
golangGomodulesProvider,
pythonPipProvider]
/**
* Match a provider from a list or providers based on file type.
* Each provider MUST export 'isSupported' taking a file name-type and returning true if supported.
* Each provider MUST export 'provideComponent' taking manifest data returning a {@link Provided}.
* Each provider MUST export 'provideStack' taking manifest path returning a {@link Provided}.
* @param {string} manifest - the name-type or path of the manifest
* @param {[Provider]} providers - list of providers to iterate over
* @returns {Provider}
* @throws {Error} when the manifest is not supported and no provider was matched
*/
export function match(manifest, providers) {
const manifestPath = path.parse(manifest)
const supported = providers.filter(prov => prov.isSupported(manifestPath.base))
if (supported.length === 0) {
throw new Error(`${manifestPath.base} is not supported`)
}
const provider = supported.find(prov => prov.validateLockFile(manifestPath.dir))
if(!provider) {
throw new Error(`${manifestPath.base} requires a lock file. Use your preferred package manager to generate the lock file.`);
}
return provider
}