-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_command.js
38 lines (30 loc) · 1.61 KB
/
run_command.js
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
const {resolve} = require('path');
const core = require('@actions/core');
const saf = require('@mitre/saf');
const parse = require('shell-quote/parse');
/**
* Runs the provided 'command string' against the SAF CLI
*
* @param {Object} [options]
* @param {string} [options.overrideCommand] - the command to run if one is not provided via environment variable
* @param {string} [options.safCLIPath] - the path to the entrypoint of the SAF CLI
* @return {Promise<unknown>} The result of running a command against an oclif cli tool
*/
async function runCommand({overrideCommand, safCLIPath}) {
const command_string = core.getInput('command_string') || overrideCommand;
if (!command_string) {
throw new Error("SAF CLI Command String argument is required.");
}
const saf_command = parse(command_string);
const allowable_topics = ['attest', 'convert', 'generate', 'harden', 'scan', 'validate', 'view'];
const topic = saf_command[0].includes(':') ? saf_command[0].split(':')[0] : saf_command[0];
if (!allowable_topics.includes(topic)) {
throw new Error("The command string did not include one of the allowable topics: " + allowable_topics.join(', ') + ". Please reference the documentation for more details.");
}
const command = saf_command[0].includes(':') ? saf_command[0].split(':')[1] : saf_command[1];
if (topic === "view" && command === "heimdall") {
throw new Error("The SAF Action does not support the 'view heimdall' command. Please reference the documentation for other uses.");
}
return saf.run(saf_command, resolve(safCLIPath));
}
module.exports = runCommand