Skip to content

Commit

Permalink
feat(bandit): Add Bandit (#108)
Browse files Browse the repository at this point in the history
* Fix Python version and install Bandit
* Add Bandit

---------

Signed-off-by: Scott Schreckengaust <[email protected]>
Signed-off-by: github-actions <[email protected]>
Co-authored-by: github-actions <[email protected]>
  • Loading branch information
scottschreckengaust and github-actions authored Nov 16, 2023
1 parent 5285638 commit 4ce992e
Show file tree
Hide file tree
Showing 6 changed files with 141 additions and 0 deletions.
1 change: 1 addition & 0 deletions .gitattributes

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

36 changes: 36 additions & 0 deletions .github/workflows/bandit.yml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions .gitignore

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions .projen/files.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

22 changes: 22 additions & 0 deletions .projenrc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import {
buildAutoApproveWorkflow,
buildOrtToolkitWorkflow,
runSemGrepWorkflow,
runBanditWorkflow,
} from './projenrc/github-workflows';

// Constants
Expand Down Expand Up @@ -94,6 +95,27 @@ buildUpdateContributorsWorkflow(project);
buildAutoApproveWorkflow(project);
buildOrtToolkitWorkflow(project);
runSemGrepWorkflow(project);
runBanditWorkflow(project);

// Add specific overrides https://projen.io/github.html#actions-versions
project.github?.actions.set('actions/checkout@v3', 'actions/checkout@f43a0e5ff2bd294095638e18286ca9a3d1956744');
project.github?.actions.set('actions/download-artifact@v3', 'actions/download-artifact@9bc31d5ccc31df68ecc42ccf4149144866c47d8a');
project.github?.actions.set('actions/github-script@v6', 'actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410');
project.github?.actions.set('actions/setup-node@v3', 'actions/setup-node@1a4442cacd436585916779262731d5b162bc6ec7');
project.github?.actions.set('actions/setup-python@v4', 'actions/setup-python@65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236');
project.github?.actions.set('actions/stale@v4', 'actions/stale@a20b814fb01b71def3bd6f56e7494d667ddf28da');
project.github?.actions.set('actions/upload-artifact@v3', 'actions/upload-artifact@a8a3f3ad30e3422c9c7b888a15615d19a852ae32');
project.github?.actions.set('amannn/[email protected]', 'amannn/action-semantic-pull-request@01d5fd8a8ebb9aafe902c40c53f0f4744f7381eb');
project.github?.actions.set('aws-github-ops/github-merit-badger@main', 'aws-github-ops/github-merit-badger@70d1c47f7051d6e324d4ddc48d676ba61ef69a3e');
project.github?.actions.set('codecov/codecov-action@v3', 'codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d');
project.github?.actions.set('github/issue-metrics@v2', 'github/issue-metrics@6bc5254e72971dbb7462db077779f1643f772afd');
project.github?.actions.set('hmarr/[email protected]', 'hmarr/auto-approve-action@44888193675f29a83e04faf4002fa8c0b537b1e4');
project.github?.actions.set('minicli/[email protected]', 'minicli/action-contributors@20ec03af008cb51110a3137fbf77f59a4fd7ff5a');
project.github?.actions.set('oss-review-toolkit/ort-ci-github-action@v1', 'oss-review-toolkit/ort-ci-github-action@7f23c1f8d169dad430e41df223d3b8409c7a156e');
project.github?.actions.set('peter-evans/create-issue-from-file@v4', 'peter-evans/create-issue-from-file@433e51abf769039ee20ba1293a088ca19d573b7f');
project.github?.actions.set('peter-evans/create-pull-request@v4', 'peter-evans/create-pull-request@38e0b6e68b4c852a5500a94740f0e535e0d7ba54');
project.github?.actions.set('peter-evans/create-pull-request@v5', 'peter-evans/create-pull-request@153407881ec5c347639a548ade7d8ad1d6740e38');


// Add specific overrides https://projen.io/github.html#actions-versions
project.github?.actions.set('actions/checkout@v3', 'actions/checkout@f43a0e5ff2bd294095638e18286ca9a3d1956744');
Expand Down
80 changes: 80 additions & 0 deletions projenrc/github-workflows.ts
Original file line number Diff line number Diff line change
Expand Up @@ -350,3 +350,83 @@ export function runSemGrepWorkflow(project: AwsCdkConstructLibrary) {
}
}
}

/**
* https://github.com/mdegis/bandit-action
* Runs Bandit on the repository.
* @param project AwsCdkConstructLibrary
*/
export function runBanditWorkflow(project: AwsCdkConstructLibrary) {
const bandit: Job = {
name: 'bandit/ci',
runsOn: ['ubuntu-latest'],
// container: {
// image: 'returntocorp/semgrep',
// },
permissions: {
contents: JobPermission.READ,
pullRequests: JobPermission.READ,
securityEvents: JobPermission.WRITE,
actions: JobPermission.READ,
},
if: "(github.actor != 'dependabot[bot]')",

steps: [
{
name: 'Checkout project',
uses: 'actions/checkout@v3',
},
{
name: 'Setup Python',
uses: 'actions/setup-python@v4',
with: {
'python-version': '3.x',
},
run: 'python -m pip install bandit',
},
{
name: 'Run Bandit',
run: 'bandit --recursive --format html --output bandit-report.html .',
},
{
name: 'Store Bandit as Artifact',
uses: 'actions/upload-artifact@v3',
with: {
name: 'bandit-report.html',
path: 'bandit-report.html',
},
},
// `awslabs` has the Advanced Security disabled.
// {
// name: 'Upload SARIF file for GitHub Advanced Security Dashboard',
// uses: 'github/codeql-action/upload-sarif@v2',
// with: {
// sarif_file: 'semgrep.sarif',
// },
// if: 'always()',
// },
],
};

if (project.github) {
const workflow = project.github.addWorkflow('bandit');
if (workflow) {
workflow.on({
pullRequest: {},
workflowDispatch: {
},
push: {
branches: [
'main',
],
},
schedule: [
{ cron: '20 17 * * *' },
],
});
workflow.addJobs({
bandit: bandit,
});
}
}
}

0 comments on commit 4ce992e

Please sign in to comment.