Skip to main content

Your GitHub clone stats, visualized and celebrated.

Project description

ClonePulse

Your GitHub clone stats, visualized and celebrated.
Track weekly trends, highlight milestones, and share visual dashboards—all automatically.

Use this template

Tests


🏷️ Add Badges to Your README

These are live examples of the badges.

# clones Milestone

The Milestone badge automatically starts celebrating #clones milestones:


What is ClonePulse?

ClonePulse is a GitHub-friendly toolchain that fetches, tracks, and visualizes repository clone activity.

It offers:

  • Daily clone tracking (total + unique)
  • 12-week visual dashboard (.PNG image)
  • Automatic milestone detection (e.g., 500, 1K, 2K+ clones)
  • Auto-annotations for clone spikes
    • Annotations can be manually added to clonepulse/fetch_clones.json (for example date of post on reddit)
  • Badge generation for README inclusion
  • GitHub Actions support for automation

📷 Example dashboard

A weekly clone activity chart is automatically updated and saved in doc/weekly_clones.png.

It is intended to run every Monday morning. Data from the current week is discarded - only data for full weeks are shown.

Clone Dashboard Example


Setup instructions

  1. Create a secret (see below)

  2. Add the secret to your repo (see below)

  3. Drop the essentials into your repo

  4. Copy these badge links to your README.md and replace your-username/your-repo with your actual GitHub username and repository name.

[![# clones](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/your-username/your-repo/main/clonepulse/badge_clones.json)](https://github.com/your-username/your-repo/blob/main/clonepulse/weekly_clones.png)

[![Milestone](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/your-username/your-repo/main/clonepulse/milestone_badge.json)](https://github.com/your-username/your-repo/blob/main/clonepulse/weekly_clones.png)

🔐 Create GitHub Token for ClonePulse

ClonePulse fetches traffic (clone) stats from the GitHub API. This requires a Personal Access Token (PAT) with read-only access to Read access to administration and metadata. Here's how to create one securely and use it with GitHub Actions.

Token Requirements

For public repositories, a fine-grained token with Read access to administration and metadata access is sufficient.

For private repositories, you will also need:

  • Repository contents: Read-only
  • Repository metadata: Read-only
  • Repository traffic: Read-only

How to Create a Fine-Grained Token

Visit: https://github.com/settings/tokens

Click "Generate new token" → "Fine-grained token"

Configure:

Name: e.g., "your repository"_ClonePulse

Expiration: e.g., 90 days

Resource owner: Your user or organization

Repository access: Select the specific repo

Set the following permissions on the token:

  • "Administration": Read-only
  • "Metadata": Read-only
  • For Private repos you might need more.....

Click "Generate token" and copy the value of the token to secure storage immediately. You only see it once.

Use the token in your repository

After having created the secret, you must now put it into the repository where you want to use it.

  1. Go to your GitHub repository:
    Settings → Secrets and variables → Actions → New repository secret

  2. Name the secret:
    CLONEPULSE_METRICS

  3. Paste the token you copied and save.

The workflow references the secret as an environment variable in this way:

- name: Run fetch_clones.py
  env:
    TOKEN: ${{ secrets.CLONEPULSE_METRICS }}
  run: python src/clonepulse/fetch_clones.py

How to drop the essentials into another repository

Create a tarball with the needed artifacts as shown below and extract the contents into your repository of choice.

Your destination repository must be somewhere on disk in a local git repo.

Take a look at SETUP.md also.

# create tarball with
#  - 2 .github workflows
#  - artifacts in clonepulse/
#  - the python scripts in src/clonepulse/
tar --exclude='.github/workflows/py-tests.yml' \
    --exclude='clonepulse/weekly_clones.png' \
    --exclude='*/__pycache__' --exclude='*.pyc' \
    -cvf clonepulse-artifacts.tar \
    {src/clonepulse,clonepulse,.github/workflows}

# extract artifacts to destination repo 
tar -xvf clonepulse-artifacts.tar -C <your repo>

After extraction, ensure that:

clonepulse/ and src/clonepulse/ exist in your repo root

GitHub Actions are in .github/workflows/

Installation (dev setup)

These instructions are only needed if you want to hack on ClonePulse

# python3 and a few packages are needed.
# This works on Ubuntu 24.04
sudo apt update
sudo apt install -y git python3 python3-venv python3-pip

git clone https://github.com/your-user/clonepulse.git
cd clonepulse
./build.sh  # Creates virtualenv and installs dependencies

This sets up a Python virtual environment and installs dependencies listed in pyproject.toml.

Contributing

Found a bug or have a suggestion?
Feel free to open an issue or submit a pull request!

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

clonepulse-1.0.0.tar.gz (73.7 kB view details)

Uploaded Source

Built Distribution

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

clonepulse-1.0.0-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file clonepulse-1.0.0.tar.gz.

File metadata

  • Download URL: clonepulse-1.0.0.tar.gz
  • Upload date:
  • Size: 73.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for clonepulse-1.0.0.tar.gz
Algorithm Hash digest
SHA256 94ba6e974843bd0199124e18926ce7741dc61dcd8bb54002a9e20e655f00d40e
MD5 360c3565e362bab1effa0b15e20f737d
BLAKE2b-256 587841bc56a5f1af678909ffab6a7f9c419ff04b6deaf62a087095e136b18ecf

See more details on using hashes here.

File details

Details for the file clonepulse-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: clonepulse-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for clonepulse-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28175b8a4659c01ec9fb58da90dc761c0d4ea4de8fffd544a8f1b699e01e43ad
MD5 718f3744f7aa30d79a2ba28b423483d8
BLAKE2b-256 8be93014644c34caac35012f4fc11f7656ceb3f1efd74cd8c3f34c4640fe6b48

See more details on using hashes here.

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