-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Add ability to run and import Debricked scans into SSC (closes #41
- Loading branch information
Showing
28 changed files
with
246 additions
and
136 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,13 +6,19 @@ inputs: | |
description: 'Run a SAST scan, takes either true or false (default)' | ||
default: 'false' | ||
required: false | ||
debricked-sca-scan: | ||
description: 'Run a Debricked Software Composition Analysis, takes either true or false (default)' | ||
default: 'false' | ||
required: false | ||
runs: | ||
using: composite | ||
steps: | ||
- uses: fortify/github-action/[email protected] | ||
if: inputs['sast-scan']=='true' && env.FOD_URL | ||
if: inputs['sast-scan']=='true' && env.FOD_URL | ||
- uses: fortify/github-action/[email protected] | ||
if: inputs['sast-scan']=='true' && env.SSC_URL | ||
if: inputs['sast-scan']=='true' && env.SSC_URL | ||
env: | ||
DO_DEBRICKED_SCAN: inputs['debricked-sca-scan'] | ||
|
||
branding: | ||
icon: 'shield' | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,2 @@ | ||
{{include:env-ssc-connection.md}} | ||
|
||
**`EXTRA_SSC_LOGIN_OPTS`** - OPTIONAL | ||
Extra SSC login options, for example for disabling SSL checks or changing connection time-outs; see [`fcli ssc session login` documentation]({{var:fcli-doc-base-url}}/manpage/fcli-ssc-session-login.html). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,9 +10,8 @@ runs: | |
- uses: fortify/github-action/internal/[email protected] | ||
if: ${{ !env._FOD_LOGGED_IN }} | ||
with: | ||
cwd: ${{ github.action_path }} | ||
script: ./fod-login.sh | ||
post: ./fod-logout.sh | ||
script: fod-login.sh | ||
post: fod-logout.sh | ||
|
||
branding: | ||
icon: 'shield' | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
# fortify/github-action/internal/run-script | ||
|
||
This action can run any of the scripts located in the `scripts` directory of this action, including the ability to run post-job scripts, for example to handle session logout. | ||
|
||
```yaml | ||
- uses: fortify/github-action/internal/run-script@v1 | ||
with: | ||
script: <script name> | ||
post: <post-job script name> | ||
``` | ||
Originally, the idea was to have these scripts located in each individual action directory, for example having `ssc-login.sh` and `ssc-logout.sh` scripts located in the `internal/ssc-login` directory. However, this proved to be difficult/impossible: | ||
|
||
- As scripts need to be run using `bash` (also on Windows), we need to convert `${{github.action_path}}` (which may include drive letter and backslashes on Windows) to `bash` format; an example of how this can be done is shown in `action.yml`. | ||
- GitHub lazily evaluates action inputs when running the post-job actions, but doesn't re-run any steps used to generate those inputs. | ||
|
||
So, suppose we'd generate a `BASH_ACTION_PATH` environment variable that contains `${{github.action_path}}` in `bash` format, we'd expect to be able to use something like: | ||
|
||
```yaml | ||
- uses: fortify/github-action/internal/run-script/[email protected] | ||
with: | ||
script: ${{ env.BASH_ACTION_PATH }}/ssc-login.sh | ||
post: ${{ env.BASH_ACTION_PATH }}/ssc-logout.sh | ||
``` | ||
|
||
This works fine for `script:`, but the `post:` script would use whatever the value of `BASH_ACTION_PATH` is during post-job execution. So, if we'd run both `ssc-login` and `sc-sast-login` actions, the post-job action would try to run `..../internal/sc-sast-login/ssc-logout.sh`, which would fail because of the incorrect directory name. | ||
|
||
Several work-arounds were tried, but failed. Only way that this would likely work is to have the calling action pass something like a static action id, which would then be used by this action to set a `POST_<id>_SCRIPT=${{inputs.POST}}` environment variable. During post-job execution, we wouldn't look at any actual inputs, but instead just execute the script identified in the `POST_<id>_SCRIPT` environment variable. | ||
|
||
Apart from hosting the scripts together with the action that executes them, another advantage of such an id is that we can also provide out-of-the-box support for run-once actions, like the various `login` actions; this is currently handled by setting an environment variable in the `*-login.sh` and `*-logout.sh` scripts. As we may also have scripts that may need to be run multiple times, we should control this through a `run-once: true|false` input. | ||
|
||
Disadvantage, apart from slightly more complex implementation, is that each caller of this `run-script` action would also need to provide the value of `${{ github.action_path }}` as an input to this action, in order to have this action determine appropriate script location. | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
name: Run a script with optional post-job cleanup | ||
|
||
description: 'Action to execute a bash script, optionally executing another script on job completion.' | ||
author: Fortify | ||
|
||
inputs: | ||
script: | ||
|
@@ -9,15 +9,22 @@ inputs: | |
post: | ||
description: 'Script to run on job completion' | ||
required: false | ||
cwd: | ||
description: 'Script working directory' | ||
required: false | ||
key: | ||
description: 'Name of the state variable used to detect the post step.' | ||
required: false | ||
default: POST | ||
|
||
runs: | ||
using: 'node20' | ||
main: 'main.js' | ||
post: 'main.js' | ||
using: composite | ||
steps: | ||
# Define directory where scripts are located. This MUST be a static path which doesn't | ||
# change during job execution, otherwise post-job scripts will fail. As such, all scripts | ||
# must be in the same directory; we can't use github.action_path from the calling action. | ||
# See README.md for details. | ||
- run: echo "_RUN_SCRIPTS_DIR=$(pwd)/scripts" >> $GITHUB_ENV | ||
shell: bash | ||
working-directory: ${{ github.action_path }} | ||
- uses: fortify/github-action/internal/run-script/[email protected] | ||
with: | ||
dir: ${{ env._RUN_SCRIPTS_DIR }} | ||
script: ${{ inputs.script }} | ||
post: ${{ inputs.post }} | ||
|
||
branding: | ||
icon: 'shield' | ||
color: 'blue' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
name: JavaScript action to run a script with optional post-job cleanup | ||
|
||
description: 'Action to execute a bash script, optionally executing another script on job completion. This action should not be used directly, but through internal/run-script.' | ||
|
||
inputs: | ||
script: | ||
description: 'Script to run' | ||
required: true | ||
post: | ||
description: 'Script to run on job completion' | ||
required: false | ||
dir: | ||
description: 'Directory where scripts are located, set automatically by internal/run-script action' | ||
required: true | ||
|
||
runs: | ||
using: 'node20' | ||
main: 'main.js' | ||
post: 'post.js' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
const util = require("./util"); | ||
|
||
util.run(process.env.INPUT_SCRIPT); |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
const util = require("./util"); | ||
|
||
util.run(process.env.INPUT_POST); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
const { spawn } = require("child_process"); | ||
|
||
exports.run = function(script) { | ||
if ( script ) { | ||
const scriptDir = process.env.INPUT_DIR; | ||
const subprocess = spawn(`bash -c -o pipefail -v 'export UTIL_DIR=${scriptDir}; ${scriptDir}/${script}'`, | ||
{ stdio: "inherit", shell: true }); | ||
subprocess.on("exit", (exitCode) => { | ||
process.exitCode = exitCode; | ||
}); | ||
} | ||
} |
This file was deleted.
Oops, something went wrong.
11 changes: 4 additions & 7 deletions
11
internal/fod-login/fod-logout.sh → internal/run-script/scripts/common.sh
100755 → 100644
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,16 +1,13 @@ | ||
#!/bin/bash | ||
|
||
### Start common code | ||
if [ -n "$RUNNER_DEBUG" ]; then | ||
set -v -x | ||
fi | ||
if [ -z "$FCLI_CMD" ]; then | ||
echo "ERROR: fortify/github-action/setup must be run to set up fcli before running this action" | ||
exit 1; | ||
fi | ||
### End common code | ||
|
||
if [[ "${_FOD_LOGGED_IN}" == "true" ]]; then | ||
echo '_FOD_LOGGED_IN=false' >> $GITHUB_ENV | ||
${FCLI_CMD} fod session logout || exit 1 | ||
fi | ||
function run { | ||
echo RUN: "$@" | ||
"$@" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
#!/bin/bash | ||
. ${UTIL_DIR}/common.sh | ||
|
||
if [[ "${_FOD_LOGGED_IN}" == "true" ]]; then | ||
echo '_FOD_LOGGED_IN=false' >> $GITHUB_ENV | ||
run ${FCLI_CMD} fod session logout \ | ||
|| exit 1 | ||
fi |
Oops, something went wrong.