GithubHelp home page GithubHelp logo

mcesystems / whitesource-unified-agent-wrapper Goto Github PK

View Code? Open in Web Editor NEW
1.0 3.0 1.0 34 KB

A wrapper module around WhiteSource Unified Agent https://whitesource.atlassian.net/wiki/spaces/WD/pages/804814917/Unified+Agent+Overview

License: MIT License

TypeScript 100.00%

whitesource-unified-agent-wrapper's Introduction

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

Key Type Optional Description
agentConfig WhiteSourceAgentConfiguration No A TypeScript representation of the WhiteSource Agent Configuration - see documentation here
dirs string[] Yes Directories to scan. If not passed, will run on current directory
agentVersion string Yes Version 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) => void Yes Callback 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

whitesource-unified-agent-wrapper's People

Contributors

mceido avatar

Watchers

James Cloos avatar Koby Boyango avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.