Skip to content

Runs gosec then uploads results to s3 and workflow artifacts.

Notifications You must be signed in to change notification settings

launchdarkly/gha-ld-gosec

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gha-ld-gosec

This action runs the gosec static code analyzer and then uploads the results to s3 and workflow artifacts. This is a required action for all launchdarkly critical repositories.

Usage

Add the following file to your repository:

.github/workflows/gosec.yml
name: Gosec
on:
  schedule:
    - cron: '0 8 * * *'
  push:
    branches:
      - main

permissions:
  id-token: write
  contents: read

jobs:
  Gosec:
    runs-on: ubuntu-latest
    env:
      GO111MODULE: on
    steps:
      - uses: launchdarkly/gha-ld-gosec@v2
        with:
          aws-assume-role: ${{ secrets.ORG_SECURITY_GHA_ROLE_ARN }}
          s3-bucket: ${{ secrets.ORG_SECURITY_INVENTORY_BUCKET }}

Inputs

name required type default description
aws-assume-role yes string The ARN of an AWS IAM role to assume. Used to auth with AWS to upload results to S3.
s3-bucket yes string Name of the s3 bucket to upload results to.
s3-path no string scan-results/gosec Path to write results to within the s3 bucket.
gosec-args no string '--exclude-generated=true --severity=medium --concurrency=1 --fmt json --out=gosec-results.json --stdout --verbose=text --no-fail ./...' Override the arguments passed to the gosec command.

Release tags

This action maintains parallel tags for major (v1) and minor (v1.0.0) versions. This allows us to reference the major tag in github workflows and pick up minor changes automatically. While still maintaining minor versioning in the event that a repository needs to pin to a specific version for some reason.

To publish a new version v1.0.1 we do the following after merging changes into the main branch:

# Checkout main branch and pull in latest changes and tags
git checkout main
git pull

# Create the minor version tag and push it to the remote repository
git tag v1.0.1
git push origin v1.0.1

# Delete and recreate the major version tag then delete and push it to the remote repository
git tag -d v1 && git tag v1
git push origin :v1 && git push origin v1