Create a brag list of open source contributions
Project description
git brag
Create professional contribution reports for your GitHub open source work.
Showcase your impact with comprehensive reports perfect for performance reviews, portfolio building, and demonstrating your open source contributions.
✨ Try it now at gitbrag.tedivm.com — No installation required!
Why GitBrag?
- Easy to Use: Login with GitHub OAuth — no tokens or configuration needed
- Professional Reports: Beautiful, shareable contribution summaries with detailed statistics
- Fast & Cached: Instant page loads with smart caching and background generation
- Privacy-Friendly: Only accesses publicly available GitHub data
- Rich Insights: Code statistics, language breakdown, PR sizes, and repository roles
Features
Web Interface (Recommended)
Visit gitbrag.tedivm.com to:
- Generate reports instantly with GitHub OAuth authentication
- Share your achievements with clean, professional URLs
- Track your progress with cached reports and automatic refresh
- No setup required — works in any browser
The web interface provides:
- Instant Page Loads: Cached reports served in <2 seconds
- Background Generation: Reports generate asynchronously without blocking
- Smart Auto-Refresh: Pages automatically reload every 10 seconds during generation
- Code Statistics: Lines added, deleted, and files changed per PR
- Language Analysis: Programming language breakdown
- PR Size Categories: One Liner, Small, Medium, Large, Huge, or Massive
- Repository Roles: Owner, Member, or Contributor status
Command-Line Interface
For automation and power users, GitBrag is also available as a CLI tool:
# Install
pip install gitbrag
# Or run directly with uvx (no installation)
uvx gitbrag list <username>
Getting Started
Web Interface (Easiest)
- Visit gitbrag.tedivm.com
- Login with your GitHub account
- View your contribution report instantly!
Share your report URL with others or use it in performance reviews and portfolios.
Self-Hosting
Host your own instance with Docker:
docker compose up
Then visit http://localhost and login with GitHub.
See Web Interface Documentation for detailed setup instructions.
CLI Configuration
For command-line usage, set your GitHub Personal Access Token:
export GITHUB_TOKEN="your_token_here"
Or create a .env file:
GITHUB_TOKEN=your_token_here
CLI Usage
List pull requests for a GitHub user:
gitbrag list <username> [OPTIONS]
Options
--since DATE- Start date (ISO format, default: 365 days ago)--until DATE- End date (ISO format, default: today)--include-private- Include private repositories--show-urls- Display PR URLs in output--show-star-increase- Display repository star increases during the filtered period--sort FIELD[:ORDER]- Sort by field (can be used multiple times)- Valid fields:
repository,state,created,merged,title,stars(requires--show-star-increase) - Valid orders:
asc,desc(default:desc)
- Valid fields:
Examples
Show all PRs from the last year:
gitbrag list tedivm
Show PRs from a specific date range:
gitbrag list tedivm --since 2024-12-14 --until 2025-12-14
Sort by repository, then by merge date:
gitbrag list tedivm --since 2024-12-14 --until 2025-12-14 --sort repository --sort merged:desc
Show repository star increases during the filtered period:
gitbrag list tedivm --since 2024-12-14 --until 2025-12-14 --show-star-increase
Example output:
╭────────────────────────────── Summary ───────────────────────────────╮
│ Total Pull Requests: 16 │
│ │
│ Code Statistics: │
│ +12,847 additions │
│ -3,421 deletions │
│ 247 files changed │
│ │
│ Top Languages: │
│ Python: 68.3% │
│ JavaScript: 15.2% │
│ TypeScript: 8.7% │
│ Go: 4.9% │
│ YAML: 2.9% │
│ │
│ Repository Roles: │
│ OWNER: 8 repositories │
│ CONTRIBUTOR: 4 repositories │
╰──────────────────────────────────────────────────────────────────────╯
Pull Requests
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━┓
┃ Repository ┃ PR # ┃ Title ┃ Size ┃ State ┃ Created ┃ Merged ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━┩
│ TerraformInDepth/terrafor… │ 1 │ Version Upgrades │ Small │ merged │ 2025-04-05 │ 2025-04-05 │
│ TerraformInDepth/tofupy │ 1 │ Update version, test │ Medium │ merged │ 2025-04-05 │ 2025-04-05 │
│ │ │ range of python versions │ │ │ │ │
│ TerraformInDepth/tofupy │ 5 │ Improve Documentation │ Small │ merged │ 2025-08-02 │ 2025-08-02 │
│ tedious/JShrink │ 149 │ Update PHP versions in CI │ Small │ merged │ 2025-11-20 │ 2025-11-20 │
│ │ │ workflow │ │ │ │ │
│ tedious/Stash │ 429 │ Update tested versions of │ One │ merged │ 2024-12-18 │ 2024-12-18 │
│ │ │ php │ Liner │ │ │ │
│ tedious/Stash │ 435 │ Update PHP versions in │ Small │ open │ 2025-11-20 │ - │
│ │ │ GitHub Actions workflow │ │ │ │ │
│ tedivm/paracelsus │ 39 │ Lock down pydot to v3 │ Small │ merged │ 2025-08-20 │ 2025-08-20 │
│ tedivm/paracelsus │ 44 │ Run test suite against │ Small │ merged │ 2025-10-10 │ 2025-10-10 │
│ │ │ 3.14 │ │ │ │ │
│ tedivm/paracelsus │ 47 │ Drop tests and docs from │ Large │ merged │ 2025-11-22 │ 2025-11-22 │
│ │ │ wheel build │ │ │ │ │
│ tedivm/paracelsus │ 52 │ Switch delimiter for │ Small │ merged │ 2025-12-14 │ 2025-12-14 │
│ │ │ column parameters in │ │ │ │ │
│ │ │ Mermaid │ │ │ │ │
│ tedivm/paracelsus │ 53 │ Support PyDot v3 and v4 │ Medium │ merged │ 2025-12-14 │ 2025-12-14 │
│ tedivm/quasiqueue │ 15 │ Run Test Suite against │ Small │ merged │ 2025-10-10 │ 2025-10-10 │
│ │ │ Python 3.14 │ │ │ │ │
│ tedivm/robs_awesome_pytho… │ 15 │ fix pytest workflow │ One │ merged │ 2025-04-11 │ 2025-04-11 │
│ │ │ rendering │ Liner │ │ │ │
│ tedivm/robs_awesome_pytho… │ 16 │ Add template test suite │ Huge │ merged │ 2025-04-11 │ 2025-04-11 │
│ tedivm/robs_awesome_pytho… │ 19 │ Caching, Testing, and │ Large │ merged │ 2025-11-27 │ 2025-11-27 │
│ │ │ Documentation Updates │ │ │ │ │
│ tedivm/skysnoop │ 4 │ Create a high level │ Medium │ merged │ 2025-11-30 │ 2025-11-30 │
│ │ │ unified client │ │ │ │ │
└────────────────────────────┴──────┴───────────────────────────┴──────────┴────────┴────────────┴────────────┘
Total: 16 pull requests
Developer Documentation
Comprehensive developer documentation is available in docs/dev/ covering testing, configuration, deployment, and all project features.
Quick Start for Developers
# Install development environment
make install
# Start services with Docker
docker compose up -d
# Run tests
make tests
# Auto-fix formatting
make chores
See the developer documentation for complete guides and reference.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gitbrag-1.1.1.tar.gz.
File metadata
- Download URL: gitbrag-1.1.1.tar.gz
- Upload date:
- Size: 490.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
26e670d4b61ac282e8532ace9bc51529774460e69395ec25e387277d9eb7f38b
|
|
| MD5 |
7ef6174617d5d944ce53c8d66d7e0624
|
|
| BLAKE2b-256 |
fb4bff553e3ddcf373ba37d1d85151afbc71d702a8941c72d45b57bf13a429ea
|
Provenance
The following attestation bundles were made for gitbrag-1.1.1.tar.gz:
Publisher:
pypi.yaml on tedivm/gitbrag
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitbrag-1.1.1.tar.gz -
Subject digest:
26e670d4b61ac282e8532ace9bc51529774460e69395ec25e387277d9eb7f38b - Sigstore transparency entry: 790870226
- Sigstore integration time:
-
Permalink:
tedivm/gitbrag@3545d178c2c580b07f61fe4f8da0e861f9806b2e -
Branch / Tag:
refs/tags/v1.1.1 - Owner: https://github.com/tedivm
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yaml@3545d178c2c580b07f61fe4f8da0e861f9806b2e -
Trigger Event:
push
-
Statement type:
File details
Details for the file gitbrag-1.1.1-py3-none-any.whl.
File metadata
- Download URL: gitbrag-1.1.1-py3-none-any.whl
- Upload date:
- Size: 310.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4a859b3eea32926c9581ea7a07801d49dd69e3c335230ecac6fbb5a00ca98c78
|
|
| MD5 |
0b499cf1c315ea3bf82dfdb9e7360592
|
|
| BLAKE2b-256 |
b692ee2bc136536e61b2d83d63e1640056326cded7b4b0e740c7b86cd5339488
|
Provenance
The following attestation bundles were made for gitbrag-1.1.1-py3-none-any.whl:
Publisher:
pypi.yaml on tedivm/gitbrag
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitbrag-1.1.1-py3-none-any.whl -
Subject digest:
4a859b3eea32926c9581ea7a07801d49dd69e3c335230ecac6fbb5a00ca98c78 - Sigstore transparency entry: 790870228
- Sigstore integration time:
-
Permalink:
tedivm/gitbrag@3545d178c2c580b07f61fe4f8da0e861f9806b2e -
Branch / Tag:
refs/tags/v1.1.1 - Owner: https://github.com/tedivm
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yaml@3545d178c2c580b07f61fe4f8da0e861f9806b2e -
Trigger Event:
push
-
Statement type: