Skip to main content

No project description provided

Project description

This package exports the Security Vulnerability Alerts from GitHub for all repositories of an organization as Prometheus metrics.

Usage

Configure API token

You’ll need to provide an access token with scope repo to access the GitHub API. See the GitHub documentation for details.

Start HTTP service

Start the HTTP server like this:

$ GITHUB_AUTHTOKEN=MYTOKEN GITHUB_OWNER=MyGitHubOrgOrUser github_vulnerability_exporter --host=127.0.0.1 --port=9597

Pass --ttl=SECONDS to cache GitHub API results for the given time or -1 to disable (default is 600). Prometheus considers metrics stale after 300s, so that’s the highest scrape_interval one should use. However it’s usually unnecessary to hit the API that often, since the vulnerability alert information does not change that rapidly.

Pass --forked if you want to include forked repositories (not sure if they actually receive vulnerability alerts, though).

Configure Prometheus

scrape_configs:
  - job_name: 'vulnerabilities'
    scrape_interval: 300s
    static_configs:
      - targets: ['localhost:9597']

We export one metric, a gauge called github_vulnerability_alerts, with labels {repository="MyGitHubOrgOrUser/my-repository-name, status="active|dismissed"}.

Additionally, a ghvuln_scrape_duration_seconds gauge is exported.

CHANGES

1.5.2 (2023-04-11)

  • Brown-bag release

1.5.1 (2023-04-11)

  • Interpret “dismissedAt: unknown” as dismissed, not active

1.5.0 (2019-06-07)

  • Add in-memory caching so we don’t have to hit the API on each scrape

1.4.0 (2019-06-07)

  • Support collecting data for repositories of either an organization or a user

1.3.0 (2019-06-07)

  • Make listen host configurable

1.2.0 (2019-06-07)

  • Add status label to differentiate between active and dismissed alerts

1.1.0 (2019-06-07)

  • Allow configuring via environment variables as well as command line parameters

1.0.1 (2019-06-07)

  • Increase repository query batch size.

1.0.0 (2019-06-06)

  • First release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

github_vulnerability_exporter-1.5.2.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file github_vulnerability_exporter-1.5.2.tar.gz.

File metadata

File hashes

Hashes for github_vulnerability_exporter-1.5.2.tar.gz
Algorithm Hash digest
SHA256 17f6458b7832288c76c77fa900360b2fa00fb053ff9792d3325cc020787a6dfe
MD5 b026850ab13aa6e728fddba1ee68b3b8
BLAKE2b-256 efd5ab20f5453d9f4557d7426531b0c60a4a9787a7eddd8bc9895e5b80aadabe

See more details on using hashes here.

File details

Details for the file github_vulnerability_exporter-1.5.2-py3-none-any.whl.

File metadata

File hashes

Hashes for github_vulnerability_exporter-1.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 db62cbc473ee0d387a2b9312edc72b2a41d2064bd55ad8c95cabce0daf26eeae
MD5 0b76ba19594612d10b28d5cbc66a26c4
BLAKE2b-256 9f0afbceec9cfe52ab3d01f42b2ec6944e2cbffb8bb774d5d9fe790df527ea18

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page