Skip to main content

Zero-server GitHub traffic analytics — daily collection via Actions, gist-backed storage, client-side dashboard

Project description

GitHub Traffic Tracker

PyPI Release Date Python 3.10+ License GitHub Discussions Platform

Zero-server GitHub traffic analytics — daily collection, permanent history, smart badges.

Alpha Software: This tool is in early development. The core workflow and dashboard are stable, but CLI tooling is still evolving. See Current Status for details.

Live from this repo's own tracker:

Installs Views Clones

The Problem

GitHub's Traffic API only retains 14 days of clone and view data. After that it's gone forever. If you don't capture it daily, you lose permanent visibility into how your project is being used. There's no built-in way to accumulate traffic history over time.

GitHub Traffic Tracker solves this with zero infrastructure via a GitHub Actions workflow that collects your data daily and stores it in a Gist, giving you permanent traffic history with no servers and no cost.

How It Works

flowchart LR
    A["GitHub Actions<br/>daily · 3am UTC"] -->|"clones · views<br/>downloads · stars"| B["Public Gist<br/>state.json + badges"]
    A -->|"monthly"| C["Archive Gist<br/>long-term snapshots"]
    B -->|"client-side fetch"| D["Dashboard<br/>GitHub Pages"]
    B -->|"shields.io endpoint"| E["Badges<br/>README / anywhere"]

A GitHub Actions workflow runs daily at 3am UTC, fetching clone, view, download, star, and referrer data from the GitHub API. It merges new data into a running state.json stored in a public Gist, always preserving the highest values seen (merge upward, never erase). Shields.io-compatible badge JSON files are updated alongside the state. A separate unlisted Gist receives monthly archive snapshots for long-term storage. The static HTML dashboard reads directly from the Gist CDN, completing the loop with no backend at all.

Features

  • Daily data collection — Clones, views, downloads, stars, forks, referrers, popular paths
  • Permanent history — Accumulates beyond the 14-day API window indefinitely
  • Unique visitor tracking — Unique cloners and viewers alongside raw counts
  • CI clone detection — Separates organic clones from CI/CD checkout noise
  • Cascading recency badgesinstalls 1,234 (+18 24h)(+88 wk)(+145 mo)
  • Tabbed dashboard — Overview, Installs, Views, Community, Dev tabs
  • Monthly archives — Long-term snapshots in a separate unlisted Gist
  • Zero server — Pure GitHub Actions + Gist storage + client-side rendering

Quick Start

Prerequisites: gh CLI installed and authenticated, Python 3.10+

Option A: ghtraf CLI (recommended)

pip install github-traffic-tracker
ghtraf create --owner YOUR_ORG --repo YOUR_REPO --configure --repo-dir /path/to/your/repo

To redeploy templates without cloud setup (e.g., after upgrading ghtraf), use ghtraf create --files-only. See docs/parameters.md for all options.

Option B: Standalone script

# Interactive — prompts for all values
python setup-gists.py

# Or fully automated
python setup-gists.py --owner YOUR_ORG --repo YOUR_REPO --configure

# Preview without making changes
python setup-gists.py --dry-run

Both options will:

  1. Create a public badge Gist and an unlisted archive Gist
  2. Set repository variables (TRAFFIC_GIST_ID, TRAFFIC_ARCHIVE_GIST_ID)
  3. Guide you through creating a PAT with gist scope
  4. Optionally configure the dashboard and workflow files (--configure)

After setup, enable GitHub Pages (Settings > Pages > Deploy from branch > main, /docs) and push.

Verbosity & Diagnostics

ghtraf -v create ...              # Level 1 — setup steps, API calls, gist operations
ghtraf -vv create ...             # Level 2 — config detail, gist IDs
ghtraf -QQ create ...             # Quieter — warnings and errors only
ghtraf --show gist:2 create ...   # Show only gist channel at level 2
ghtraf --show                     # List all available channels

Eight named channels (api, config, gist, setup, general, hint, error, trace) let you see specific diagnostics without global noise.

For full parameter documentation, see docs/parameters.md.

Badge Showcase

Badge What it shows Example
Installs Downloads + clones combined, with cascading recency installs 1,234 (+18 24h)
Views Repository page views with recency views 5,678 (+92 24h)
Clones Git clones (organic, excluding CI) clones 890 (+7 24h)
Downloads Release asset downloads downloads 456

Recency cascades automatically: the badge shows the most recent non-zero period — (+N 24h) if there's activity today, otherwise (+N wk), then (+N mo). This gives visitors a sense of project activity at a glance.

[![Installs](https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/USER/GIST_ID/raw/installs.json)](https://USER.github.io/REPO/stats/#installs)

Live Dashboards

This system is actively running on:

Roadmap

See ROADMAP.md or Issue #1 — Roadmap for the full plan.

Current Status

GTT is in early alpha (v0.3.x). The core workflow and dashboard are functional and actively running on multiple repos, but CLI tooling and several features are still in development.

What works today:

  • Daily traffic collection via GitHub Actions
  • Permanent history in Gist storage (beyond GitHub's 14-day window)
  • Cascading recency badges (installs, views, clones)
  • 5-tab dashboard with charts
  • setup-gists.py onboarding script
  • pip install github-traffic-tracker / pip install ghtraf
  • Structured verbosity (-v/-Q/--show) with 8 named output channels
  • ghtraf create --files-only — copy workflow + dashboard templates into your repo

In progress:

  • ghtraf CLI subcommands: status, list, verify (#6)
  • Schema migration tooling (ghtraf upgrade)

Known limitations:

  • CI clone subtraction uses heuristic formulas (empirical validation planned)
  • Dashboard is a single HTML file (JS modularization planned)

Contributing

Contributions are welcome! Please read our Contributing Guide for details.

Like the project?

"Buy Me A Coffee"

License

Github-Traffic-Tracker (ghtraf), Copyright (C) 2025 Dustin Darcy

This project is licensed under the GNU General Public License v3.0 — see LICENSE for details.

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_traffic_tracker-0.3.10.tar.gz (928.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

github_traffic_tracker-0.3.10-py3-none-any.whl (906.0 kB view details)

Uploaded Python 3

File details

Details for the file github_traffic_tracker-0.3.10.tar.gz.

File metadata

  • Download URL: github_traffic_tracker-0.3.10.tar.gz
  • Upload date:
  • Size: 928.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for github_traffic_tracker-0.3.10.tar.gz
Algorithm Hash digest
SHA256 6b3d2bdc820c2c584d9594362d9338d6656149159bc93bf0bfaa569e462abd69
MD5 92148eb58a2bb838e122747ea98fe320
BLAKE2b-256 ecc37acc46e857cde5ef622a44ece543dfad8eb026ea6ebf285b593d8607b399

See more details on using hashes here.

Provenance

The following attestation bundles were made for github_traffic_tracker-0.3.10.tar.gz:

Publisher: publish.yml on djdarcy/github-traffic-tracker

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file github_traffic_tracker-0.3.10-py3-none-any.whl.

File metadata

File hashes

Hashes for github_traffic_tracker-0.3.10-py3-none-any.whl
Algorithm Hash digest
SHA256 8a22ab5b080f40fae5376efac5ccdecaab0811f31b6fc0fa4273d88da83af571
MD5 414312ac7cd58a49defcccc0b891472f
BLAKE2b-256 ce73d5035b5d300c59597ddbc8d20a0279c67bbdc8ae14130f3e0024ad3dc342

See more details on using hashes here.

Provenance

The following attestation bundles were made for github_traffic_tracker-0.3.10-py3-none-any.whl:

Publisher: publish.yml on djdarcy/github-traffic-tracker

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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