1.0.6 • Published 3 years ago

@mcesystems/whitesource-unified-agent-wrapper v1.0.6

Weekly downloads
110
License
MIT
Repository
github
Last release
3 years ago

WhiteSource Unified Agent Wrapper

A wrapper module around WhiteSource Unified Agent https://whitesource.atlassian.net/wiki/spaces/WD/pages/804814917/Unified+Agent+Overview \ This module was create to expose the WhiteSource Unified Agent for programmatic TypeScript/Javascript usage (in nodejs processes).

Important notice

This module is developed and maintained by mceSystems. It is not an official WhiteSource module. \ If you find nay issues with this module, use the Issues page of th repo.\

Installation

npm i @mcesystems/whitesource-unified-agent-wrapper

Usage

import runAgent, { RunAgentOptions } from "@mcesystems/whitesource-unified-agent-wrapper";

const options: RunAgentOptions = {
	...
};
...
await runAgent(options);

runAgent(options: RunAgentOptions) => Promise

  • options - settings for running the Unified Agent (see the RunAgentOptions documentation below)

Returns a Promise<void> that resolves if the Unified Agent process completed with exit code 0, and rejects otherwise

RunAgentOptions

KeyTypeOptionalDescription
agentConfigWhiteSourceAgentConfigurationNoA TypeScript representation of the WhiteSource Agent Configuration - see documentation here
dirsstring[]YesDirectories to scan. If not passed, will run on current directory
agentVersionstringYesVersion of the agent to run. Will download the file if not available locally. Defaults to "latest" but keep in mind that this will always trigger a download, regardless to the locally available files
onLogLine(line: string) => voidYesCallback to be invoked on each log line during the scan

WhiteSourceAgentConfiguration

As mentioned above, this is an interface representing the Unified Agent Configuration Parameters.\ Each configuration parameter is represented by a field in this interface, and period (.) delimited configuration keys are represented by sub hierarchy deeper levels of the interface. \ For example, if the Unified Agent Configuration Parameters doc states the docker.pull.maxImages configuration parameter, the corresponding object representation is

const agentOptions: WhiteSourceAgentConfiguration = {
	...
	docker: {
		pull: {
			maxImages : 10,
		},
	},
	...
}
A word on this interface

It was generated automatically, so some of the types may seem a bit too generic.\ We have done some work on making some parameters more accurate (like turning the type of log.files.level from a simple string to the more explicit "trace" | "debug" | "info" | "warn" | "error" | "off" union), and making sure optional/non-optional parameters are delcared as they should.\ That said, there is more work on making this interface more accurate and descriptive, and any help doing this, in the form of pull-request will be much appreciated.

License

MIT

1.0.6

3 years ago

1.0.5

3 years ago

1.0.4

3 years ago

1.0.3

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago

1.0.0

3 years ago