-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update dependencies and add Static analysis and fix issues
Update dependencies and add Static analysis and fix issues
- Loading branch information
Showing
25 changed files
with
377 additions
and
182 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,31 +1,42 @@ | ||
name: "Static Analysis" | ||
on: ["push", "pull_request"] | ||
name: Static Code Analysis | ||
on: | ||
push: | ||
branches: | ||
- "**" | ||
tags-ignore: | ||
- "**" | ||
pull_request: | ||
jobs: | ||
Static-Check: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Source | ||
uses: actions/checkout@v3 | ||
|
||
- name: Install Go | ||
uses: actions/setup-go@v3 | ||
with: | ||
go-version: 1.20.x | ||
|
||
- name: Static Code Analysis | ||
uses: dominikh/staticcheck-action@v1 | ||
uses: golangci/golangci-lint-action@v3 | ||
with: | ||
install-go: false | ||
args: | | ||
--timeout 5m --out-${NO_FUTURE}format colored-line-number --enable errcheck,gosimple,govet,ineffassign,staticcheck,typecheck,unused,gocritic,asasalint,asciicheck,errchkjson,exportloopref,makezero,nilerr,unparam,unconvert,wastedassign,usestdlibvars | ||
Go-Sec: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Source | ||
uses: actions/checkout@v3 | ||
|
||
- name: Install Go | ||
uses: actions/setup-go@v3 | ||
with: | ||
go-version: 1.20.x | ||
- name: Install gosec | ||
run: curl -sfL https://raw.githubusercontent.com/securego/gosec/master/install.sh | sh -s -- -b $(go env GOPATH)/bin | ||
- name: Run gosec | ||
# Temporary ignoring G301,G302,G306 | ||
run: gosec -exclude=G204,G301,G302,G304,G306 -exclude-dir=\.*test\.* ./... | ||
|
||
- name: Run Gosec Security Scanner | ||
uses: securego/gosec@master | ||
with: | ||
args: -exclude G204,G304,G404,G401,G505 -tests -exclude-dir \.*test\.* ./... |
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 was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
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,119 @@ | ||
name: "Frogbot Scan Pull Request" | ||
on: | ||
pull_request_target: | ||
types: [ opened, synchronize ] | ||
permissions: | ||
pull-requests: write | ||
contents: read | ||
jobs: | ||
scan-pull-request: | ||
runs-on: ubuntu-latest | ||
# A pull request needs to be approved before Frogbot scans it. Any GitHub user who is associated with the | ||
# "frogbot" GitHub environment can approve the pull request to be scanned. | ||
environment: frogbot | ||
steps: | ||
- uses: jfrog/frogbot@v2 | ||
env: | ||
JFROG_CLI_LOG_LEVEL: "DEBUG" | ||
# [Mandatory] | ||
# JFrog platform URL (This functionality requires version 3.29.0 or above of Xray) | ||
JF_URL: ${{ secrets.FROGBOT_URL }} | ||
|
||
# [Mandatory if JF_USER and JF_PASSWORD are not provided] | ||
# JFrog access token with 'read' permissions on Xray service | ||
JF_ACCESS_TOKEN: ${{ secrets.FROGBOT_ACCESS_TOKEN }} | ||
|
||
# [Mandatory] | ||
# The GitHub token is automatically generated for the job | ||
JF_GIT_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
# [Optional, default: https://api.github.com] | ||
# API endpoint to GitHub | ||
# JF_GIT_API_ENDPOINT: https://github.example.com | ||
|
||
# [Optional] | ||
# By default, the Frogbot workflows download the Frogbot executable as well as other tools | ||
# needed from https://releases.jfrog.io | ||
# If the machine that runs Frogbot has no access to the internet, follow these steps to allow the | ||
# executable to be downloaded from an Artifactory instance, which the machine has access to: | ||
# | ||
# 1. Login to the Artifactory UI, with a user who has admin credentials. | ||
# 2. Create a Remote Repository with the following properties set. | ||
# Under the 'Basic' tab: | ||
# Package Type: Generic | ||
# URL: https://releases.jfrog.io | ||
# Under the 'Advanced' tab: | ||
# Uncheck the 'Store Artifacts Locally' option | ||
# 3. Set the value of the 'JF_RELEASES_REPO' variable with the Repository Key you created. | ||
# JF_RELEASES_REPO: "" | ||
|
||
# [Optional] | ||
# Configure the SMTP server to enable Frogbot to send emails with detected secrets in pull request scans. | ||
# SMTP server URL including should the relevant port: (Example: smtp.server.com:8080) | ||
JF_SMTP_SERVER: ${{ secrets.JF_SMTP_SERVER }} | ||
|
||
# [Mandatory if JF_SMTP_SERVER is set] | ||
# The username required for authenticating with the SMTP server. | ||
JF_SMTP_USER: ${{ secrets.JF_SMTP_USER }} | ||
|
||
# [Mandatory if JF_SMTP_SERVER is set] | ||
# The password associated with the username required for authentication with the SMTP server. | ||
JF_SMTP_PASSWORD: ${{ secrets.JF_SMTP_PASSWORD }} | ||
|
||
# [Optional] | ||
# List of comma separated email addresses to receive email notifications about secrets | ||
# detected during pull request scanning. The notification is also sent to the email set | ||
# in the committer git profile regardless of whether this variable is set or not. | ||
JF_EMAIL_RECEIVERS: "[email protected]" | ||
|
||
########################################################################## | ||
## If your project uses a 'frogbot-config.yml' file, you can define ## | ||
## the following variables inside the file, instead of here. ## | ||
########################################################################## | ||
|
||
# [Mandatory if the two conditions below are met] | ||
# 1. The project uses yarn 2, NuGet or .NET Core to download its dependencies | ||
# 2. The `installCommand` variable isn't set in your frogbot-config.yml file. | ||
# | ||
# The command that installs the project dependencies (e.g "nuget restore") | ||
# JF_INSTALL_DEPS_CMD: "" | ||
|
||
# [Optional, default: "."] | ||
# Relative path to the root of the project in the Git repository | ||
# JF_WORKING_DIR: path/to/project/dir | ||
|
||
# [Optional] | ||
# Xray Watches. Learn more about them here: https://www.jfrog.com/confluence/display/JFROG/Configuring+Xray+Watches | ||
# JF_WATCHES: <watch-1>,<watch-2>...<watch-n> | ||
|
||
# [Optional] | ||
# JFrog project. Learn more about it here: https://www.jfrog.com/confluence/display/JFROG/Projects | ||
# JF_PROJECT: <project-key> | ||
|
||
# [Optional, default: "FALSE"] | ||
# Displays all existing vulnerabilities, including the ones that were added by the pull request. | ||
# JF_INCLUDE_ALL_VULNERABILITIES: "TRUE" | ||
|
||
# [Optional, default: "TRUE"] | ||
# Fails the Frogbot task if any security issue is found. | ||
# JF_FAIL: "FALSE" | ||
|
||
# [Optional] | ||
# Frogbot will download the project dependencies if they're not cached locally. To download the | ||
# dependencies from a virtual repository in Artifactory, set the name of the repository. There's no | ||
# need to set this value, if it is set in the frogbot-config.yml file. | ||
# JF_DEPS_REPO: "" | ||
|
||
# [Optional, Default: "FALSE"] | ||
# If TRUE, Frogbot creates a single pull request with all the fixes. | ||
# If false, Frogbot creates a separate pull request for each fix. | ||
# JF_GIT_AGGREGATE_FIXES: "FALSE" | ||
|
||
# [Optional, Default: "FALSE"] | ||
# Handle vulnerabilities with fix versions only | ||
# JF_FIXABLE_ONLY: "TRUE" | ||
|
||
# [Optional] | ||
# Set the minimum severity for vulnerabilities that should be fixed and commented on in pull requests | ||
# The following values are accepted: Low, Medium, High or Critical | ||
# JF_MIN_SEVERITY: "" |
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,125 @@ | ||
name: "Frogbot Scan Repository" | ||
on: | ||
workflow_dispatch: | ||
schedule: | ||
# The repository will be scanned once a day at 00:00 GMT. | ||
- cron: "0 0 * * *" | ||
permissions: | ||
contents: write | ||
pull-requests: write | ||
security-events: write | ||
jobs: | ||
scan-repository: | ||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: | ||
# The repository scanning will be triggered periodically on the following branches. | ||
branch: [ "master" ] | ||
steps: | ||
- uses: jfrog/frogbot@v2 | ||
env: | ||
JFROG_CLI_LOG_LEVEL: "DEBUG" | ||
# [Mandatory] | ||
# JFrog platform URL (This functionality requires version 3.29.0 or above of Xray) | ||
JF_URL: ${{ secrets.FROGBOT_URL }} | ||
|
||
# [Mandatory if JF_USER and JF_PASSWORD are not provided] | ||
# JFrog access token with 'read' permissions on Xray service | ||
JF_ACCESS_TOKEN: ${{ secrets.FROGBOT_ACCESS_TOKEN }} | ||
|
||
# [Mandatory if JF_ACCESS_TOKEN is not provided] | ||
# JFrog username with 'read' permissions for Xray. Must be provided with JF_PASSWORD | ||
# JF_USER: ${{ secrets.JF_USER }} | ||
|
||
# [Mandatory if JF_ACCESS_TOKEN is not provided] | ||
# JFrog password. Must be provided with JF_USER | ||
# JF_PASSWORD: ${{ secrets.JF_PASSWORD }} | ||
|
||
# [Mandatory] | ||
# The GitHub token is automatically generated for the job | ||
JF_GIT_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
# [Mandatory] | ||
# The name of the branch on which Frogbot will perform the scan | ||
JF_GIT_BASE_BRANCH: ${{ matrix.branch }} | ||
|
||
# [Optional, default: https://api.github.com] | ||
# API endpoint to GitHub | ||
# JF_GIT_API_ENDPOINT: https://github.example.com | ||
|
||
# [Optional] | ||
# By default, the Frogbot workflows download the Frogbot executable as well as other tools | ||
# needed from https://releases.jfrog.io | ||
# If the machine that runs Frogbot has no access to the internet, follow these steps to allow the | ||
# executable to be downloaded from an Artifactory instance, which the machine has access to: | ||
# | ||
# 1. Login to the Artifactory UI, with a user who has admin credentials. | ||
# 2. Create a Remote Repository with the following properties set. | ||
# Under the 'Basic' tab: | ||
# Package Type: Generic | ||
# URL: https://releases.jfrog.io | ||
# Under the 'Advanced' tab: | ||
# Uncheck the 'Store Artifacts Locally' option | ||
# 3. Set the value of the 'JF_RELEASES_REPO' variable with the Repository Key you created. | ||
# JF_RELEASES_REPO: "" | ||
|
||
########################################################################## | ||
## If your project uses a 'frogbot-config.yml' file, you can define ## | ||
## the following variables inside the file, instead of here. ## | ||
########################################################################## | ||
|
||
# [Optional, default: "."] | ||
# Relative path to the root of the project in the Git repository | ||
# JF_WORKING_DIR: path/to/project/dir | ||
|
||
# [Optional] | ||
# Xray Watches. Learn more about them here: https://www.jfrog.com/confluence/display/JFROG/Configuring+Xray+Watches | ||
# JF_WATCHES: <watch-1>,<watch-2>...<watch-n> | ||
|
||
# [Optional] | ||
# JFrog project. Learn more about it here: https://www.jfrog.com/confluence/display/JFROG/Projects | ||
# JF_PROJECT: <project-key> | ||
|
||
# [Optional, default: "TRUE"] | ||
# Fails the Frogbot task if any security issue is found. | ||
# JF_FAIL: "FALSE" | ||
|
||
# [Optional] | ||
# Frogbot will download the project dependencies, if they're not cached locally. To download the | ||
# dependencies from a virtual repository in Artifactory, set the name of the repository. There's no | ||
# need to set this value, if it is set in the frogbot-config.yml file. | ||
# JF_DEPS_REPO: "" | ||
|
||
# [Optional] | ||
# Template for the branch name generated by Frogbot when creating pull requests with fixes. | ||
# The template must include ${BRANCH_NAME_HASH}, to ensure that the generated branch name is unique. | ||
# The template can optionally include the ${IMPACTED_PACKAGE} and ${FIX_VERSION} variables. | ||
# JF_BRANCH_NAME_TEMPLATE: "frogbot-${IMPACTED_PACKAGE}-${BRANCH_NAME_HASH}" | ||
|
||
# [Optional] | ||
# Template for the commit message generated by Frogbot when creating pull requests with fixes | ||
# The template can optionally include the ${IMPACTED_PACKAGE} and ${FIX_VERSION} variables. | ||
# JF_COMMIT_MESSAGE_TEMPLATE: "Upgrade ${IMPACTED_PACKAGE} to ${FIX_VERSION}" | ||
|
||
# [Optional] | ||
# Template for the pull request title generated by Frogbot when creating pull requests with fixes. | ||
# The template can optionally include the ${IMPACTED_PACKAGE} and ${FIX_VERSION} variables. | ||
# JF_PULL_REQUEST_TITLE_TEMPLATE: "[🐸 Frogbot] Upgrade ${IMPACTED_PACKAGE} to ${FIX_VERSION}" | ||
|
||
# [Optional, Default: "FALSE"] | ||
# If TRUE, Frogbot creates a single pull request with all the fixes. | ||
# If FALSE, Frogbot creates a separate pull request for each fix. | ||
# JF_GIT_AGGREGATE_FIXES: "FALSE" | ||
|
||
# [Optional, Default: "FALSE"] | ||
# Handle vulnerabilities with fix versions only | ||
# JF_FIXABLE_ONLY: "TRUE" | ||
|
||
# [Optional] | ||
# Set the minimum severity for vulnerabilities that should be fixed and commented on in pull requests | ||
# The following values are accepted: Low, Medium, High or Critical | ||
# JF_MIN_SEVERITY: "" | ||
|
||
# [Optional, Default: [email protected]] | ||
# Set the email of the commit author | ||
# JF_GIT_EMAIL_AUTHOR: "" |
Oops, something went wrong.