MCPcopy Index your code
hub / github.com/securego/gosec

github.com/securego/gosec @v2.27.1

Chat with this repo
repository ↗ · DeepWiki ↗ · release v2.27.1 ↗ · + Follow
1,123 symbols 3,581 edges 252 files 595 documented · 53% 18 cross-repo links updated 6d agov2.27.1 · 2026-06-01★ 8,8771 open issues
What it actually does AI analysis from the code graph — generated when you open this
loading…
README

gosec - Go Security Checker

Inspects source code for security problems by scanning the Go AST and SSA code representation.

Quick links

Features

  • Pattern-based rules for detecting common security issues in Go code
  • SSA-based analyzers for type conversions, slice bounds, and crypto issues
  • Taint analysis for tracking data flow from user input to dangerous functions (SQL injection, command injection, path traversal, SSRF, XSS, log injection, SMTP injection, SSTI, unsafe deserialization, open redirect)

License

Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with the License. You may obtain a copy of the License here.

Project status

CII Best Practices Build Status Coverage Status GoReport GoDoc Docs Downloads GHCR Slack go-recipes

Installation

GitHub Action

You can run gosec as a GitHub action as follows:

Use the versioned tag with @master which is pinned to the latest stable release. This will provide a stable behavior.

name: Run Gosec
on:
  push:
    branches:
      - master
  pull_request:
    branches:
      - master
jobs:
  tests:
    runs-on: ubuntu-latest
    env:
      GO111MODULE: on
    steps:
      - name: Checkout Source
        uses: actions/checkout@v3
      - name: Run Gosec Security Scanner
        uses: securego/gosec@master
        with:
          args: ./...

Scanning Projects with Private Modules

If your project imports private Go modules, you need to configure authentication so that gosec can fetch the dependencies. Set the following environment variables in your workflow:

  • GOPRIVATE: A comma-separated list of module path prefixes that should be considered private (e.g., github.com/your-org/*).
  • GITHUB_AUTHENTICATION_TOKEN: A GitHub token with read access to your private repositories.
name: Run Gosec
on:
  push:
    branches:
      - master
  pull_request:
    branches:
      - master
jobs:
  tests:
    runs-on: ubuntu-latest
    env:
      GO111MODULE: on
      GOPRIVATE: github.com/your-org/*
      GITHUB_AUTHENTICATION_TOKEN: ${{ secrets.PRIVATE_REPO_TOKEN }}
    steps:
      - name: Checkout Source
        uses: actions/checkout@v3
      - name: Run Gosec Security Scanner
        uses: securego/gosec@v2
        with:
          args: ./...

Integrating with code scanning

You can integrate third-party code analysis tools with GitHub code scanning by uploading data as SARIF files.

The workflow shows an example of running the gosec as a step in a GitHub action workflow which outputs the results.sarif file. The workflow then uploads the results.sarif file to GitHub using the upload-sarif action.

name: "Security Scan"

# Run workflow each time code is pushed to your repository and on a schedule.
# The scheduled workflow runs every at 00:00 on Sunday UTC time.
on:
  push:
  schedule:
  - cron: '0 0 * * 0'

jobs:
  tests:
    runs-on: ubuntu-latest
    env:
      GO111MODULE: on
    steps:
      - name: Checkout Source
        uses: actions/checkout@v3
      - name: Run Gosec Security Scanner
        uses: securego/gosec@v2
        with:
          # we let the report trigger content trigger a failure using the GitHub Security features.
          args: '-no-fail -fmt sarif -out results.sarif ./...'
      - name: Upload SARIF file
        uses: github/codeql-action/upload-sarif@v2
        with:
          # Path to SARIF file relative to the root of the repository
          sarif_file: results.sarif

Go Analysis

The goanalysis package provides a golang.org/x/tools/go/analysis.Analyzer for integration with tools that support the standard Go analysis interface, such as Bazel's nogo framework:

nogo(
    name = "nogo",
    deps = [
        "@com_github_securego_gosec_v2//goanalysis",
        # add more analyzers as needed
    ],
    visibility = ["//visibility:public"],
)

Local Installation

gosec requires Go 1.25 or newer.

go install github.com/securego/gosec/v2/cmd/gosec@latest

Quick start

# Scan all packages in current module
gosec ./...

# Write JSON report
gosec -fmt json -out results.json ./...

# Write SARIF report for code scanning
gosec -fmt sarif -out results.sarif ./...

Exit codes

  • 0: scan finished without unsuppressed findings/errors
  • 1: at least one unsuppressed finding or processing error
  • Use -no-fail to always return 0

Usage

Gosec can be configured to only run a subset of rules, to exclude certain file paths, and produce reports in different formats. By default all rules will be run against the supplied input files. To recursively scan from the current directory you can supply ./... as the input argument.

Available rules

gosec includes rules across these categories:

  • G1xx: general secure coding issues (for example hardcoded credentials, unsafe usage, HTTP hardening, cookie security)
  • G2xx: injection risks in query/template/command construction
  • G3xx: file and path handling risks (permissions, traversal, temp files, archive extraction)
  • G4xx: crypto and TLS weaknesses
  • G5xx: blocklisted imports
  • G6xx: Go-specific correctness/security checks (for example range aliasing and slice bounds)
  • G7xx: taint analysis rules (SQL injection, command injection, path traversal, SSRF, XSS, log, SMTP injection, SSTI, unsafe deserialization, and open redirect)

For the full list, rule descriptions, and per-rule configuration, see RULES.md.

Retired rules

  • G105: Audit the use of math/big.Int.Exp - CVE is fixed
  • G307: Deferring a method which returns an error - causing more inconvenience than fixing a security issue, despite the details from this blog post

Selecting rules

By default, gosec will run all rules against the supplied file paths. It is however possible to select a subset of rules to run via the -include= flag, or to specify a set of rules to explicitly exclude using the -exclude= flag.

# Run a specific set of rules
$ gosec -include=G101,G203,G401 ./...

# Run everything except for rule G303
$ gosec -exclude=G303 ./...

CWE Mapping

Every issue detected by gosec is mapped to a CWE (Common Weakness Enumeration) which describes in more generic terms the vulnerability. The exact mapping can be found here.

Configuration

A number of global settings can be provided in a configuration file as follows:

{
    "global": {
        "nosec": "enabled",
        "audit": "enabled"
    }
}
  • nosec: this setting will overwrite all #nosec directives defined throughout the code base
  • audit: runs in audit mode which enables addition checks that for normal code analysis might be too nosy
# Run with a global configuration file
$ gosec -conf config.json .

Path-Based Rule Exclusions

Large repositories with multiple components may need different security rules for different paths. Use exclude-rules to suppress specific rules for specific paths.

Configuration File:

{
  "exclude-rules": [
    {
      "path": "cmd/.*",
      "rules": ["G204", "G304"]
    },
    {
      "path": "scripts/.*",
      "rules": ["*"]
    }
  ]
}

CLI Flag:

# Exclude G204 and G304 from cmd/ directory
gosec --exclude-rules="cmd/.*:G204,G304" ./...

# Exclude all rules from scripts/ directory  
gosec --exclude-rules="scripts/.*:*" ./...

# Multiple exclusions
gosec --exclude-rules="cmd/.*:G204,G304;test/.*:G101" ./...
Field Type Description
path string (regex) Regex matched against file paths
rules []string Rule IDs to exclude. * for all

Rule Configuration

Some rules accept configuration flags as well; these flags are documented in RULES.md.

Go version

Some rules require a specific Go version which is retrieved from the Go module file present in the project. If this version cannot be found, it will fallback to Go runtime version.

The Go module version is parsed using the go list command which in some cases might lead to performance degradation. In this situation, the go module version can be easily provided by setting the environment variable GOSECGOVERSION=go1.21.1.

Dependencies

gosec loads packages using Go modules. In most projects, dependencies are resolved automatically during scanning.

If dependencies are missing, run:

go mod tidy
go mod download

Excluding test files and folders

gosec will ignore test files across all packages and any dependencies in your vendor directory.

The scanning of test files can be enabled with the following flag:

gosec -tests ./...

Also additional folders can be excluded as follows:

 gosec -exclude-dir=rules -exclude-dir=cmd ./...

Excluding generated files

gosec can ignore generated go files with default generated code comment.

// Code generated by some generator DO NOT EDIT.
gosec -exclude-generated ./...

Auto fixing vulnerabilities

gosec can suggest fixes based on AI recommendation. It will call an AI API to receive a suggestion for a security finding.

You can enable this feature by providing the following command line arguments:

  • ai-api-provider: the name of the AI API provider. Supported providers:
  • Atlas Cloud: atlas (default model deepseek-ai/deepseek-v4-flash), atlas-deepseek-v4-flash, atlas-qwen3-coder-next, atlas-kimi-k2.6, or atlas:<model-id> for any Atlas Cloud hosted chat model. Atlas Cloud is an OpenAI-compatible provider available at atlascloud.ai
  • Gemini: gemini-3-pro-preview (default), gemini-2.5-pro, gemini-2.5-flash, gemini-2.5-flash-lite
  • Claude: claude-sonnet-4-6 (default), claude-opus-4-7, claude-opus-4-6, claude-sonnet-4-5, claude-opus-4-5, claude-haiku-4-5
  • OpenAI: gpt-5.4 (default), gpt-5.4-mini, gpt-5.4-nano
  • Custom OpenAI-compatible: Any custom model name (requires ai-base-url)
  • ai-api-key or set the environment variable GOSEC_AI_API_KEY: the key to access the AI API
  • For Gemini, you can create an API key following these instructions
  • For Claude, get your API key from Anthropic Console
  • For OpenAI, get your API key from OpenAI Platform
  • ai-base-url: (optional) custom base URL for OpenAI-compatible APIs (e.g., Azure OpenAI, LocalAI, Ollama)
  • Atlas Cloud uses https://api.atlascloud.ai/v1 by default, so ai-base-url is optional for the built-in atlas provider
  • GOSEC_AI_PROVIDER: (optional) environment variable alternative to ai-api-provider
  • GOSEC_AI_BASE_URL: (optional) environment variable alternative to ai-base-url
  • ai-skip-ssl: (optional) skip SSL certificate verification for AI API (useful for self-signed certificates)

🎁 Atlas Cloud is a full-modal AI inference platform that gives developers a single AI API to access video generation, image generation, and LLM APIs. Instead of managing multiple vendor integrations, you connect once and get unified access to 300+ curated models across all modalities.

Check out Atlas Cloud's new coding plan promotion for more budget-friendly API access: https://www.atlascloud.ai/console/coding-plan

Examples:

```bash

Using Atlas Cloud with the default DeepSeek V4 Flash model

export GOSEC_AI_API_KEY="your_key" export GOSEC_AI_PROVIDER="atlas" gosec ./...

Using Atlas Cloud with an explicit hosted model

Extension points exported contracts — how you extend this code

GenAIClient (Interface)
(no doc) [4 implementers]
autofix/ai.go
Rule (Interface)
The Rule interface used by all rules supported by gosec. [1 implementers]
rule.go
Option (FuncType)
Option provides a way to adjust the package config depending on testing requirements
testutils/pkg.go
AnalyzerBuilder (FuncType)
AnalyzerBuilder is used to register an analyzer definition with the analyzer
analyzers/analyzerslist.go
RuleFilter (FuncType)
RuleFilter can be used to include or exclude a rule depending on the return value of the function
rules/rulelist.go
RuleBuilder (FuncType)
RuleBuilder is used to register a rule definition with the analyzer
rule.go
AnalyzerFilter (FuncType)
AnalyzerFilter can be used to include or exclude an analyzer depending on the return value of the function
analyzers/analyzerslist.go

Core symbols most depended-on inside this repo

Close
called by 247
testutils/pkg.go
AddFile
called by 190
testutils/pkg.go
NewTestPackage
called by 186
testutils/pkg.go
Build
called by 134
testutils/pkg.go
Process
called by 125
analyzer.go
Report
called by 123
analyzer.go
Generate
called by 114
rules/rulelist.go
LoadRules
called by 112
analyzer.go

Shape

Function 631
Method 281
Struct 188
TypeAlias 14
FuncType 7
Interface 2

Languages

Go100%

Modules by API surface

report/sarif/types.go53 symbols
analyzer.go45 symbols
taint/taint.go38 symbols
taint/analyzer_internal_test.go38 symbols
analyzers/context_propagation.go38 symbols
helpers.go36 symbols
analyzers/util.go34 symbols
analyzers/range_analyzer.go34 symbols
report/sarif/builder.go30 symbols
rules/secret_serialization.go25 symbols
analyzers/slice_bounds.go24 symbols
cmd/gosecutil/tools.go19 symbols

Dependencies from manifests, versioned

cloud.google.com/gov0.123.0 · 1×
cloud.google.com/go/compute/metadatav0.9.0 · 1×
github.com/Masterminds/semver/v3v3.5.0 · 1×
github.com/anthropics/anthropic-sdk-gov1.46.0 · 1×
github.com/bahlo/generic-list-gov0.2.0 · 1×
github.com/ccojocar/zxcvbn-gov1.0.4 · 1×
github.com/cespare/xxhash/v2v2.3.0 · 1×
github.com/felixge/httpsnoopv1.0.4 · 1×

For agents

$ claude mcp add gosec \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact