https://github.com/dexhunter/vibe-clock
Track AI coding agent usage across Claude Code, Codex, and OpenCode — SVG charts for your GitHub profile
https://github.com/dexhunter/vibe-clock
ai-agents claude-code cli codex developer-tools github-actions github-profile opencode svg
Last synced: 4 months ago
JSON representation
Track AI coding agent usage across Claude Code, Codex, and OpenCode — SVG charts for your GitHub profile
- Host: GitHub
- URL: https://github.com/dexhunter/vibe-clock
- Owner: dexhunter
- License: mit
- Created: 2026-02-18T15:40:33.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2026-02-22T13:31:57.000Z (4 months ago)
- Last Synced: 2026-02-22T18:59:07.093Z (4 months ago)
- Topics: ai-agents, claude-code, cli, codex, developer-tools, github-actions, github-profile, opencode, svg
- Language: Python
- Homepage:
- Size: 185 KB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.es.md
- License: LICENSE
Awesome Lists containing this project
README
# vibe-clock
[English](README.md) | [简体中文](README.zh-CN.md) | [日本語](README.ja.md) | Español
**WakaTime para agentes de programación con IA.** Rastrea el uso de Claude Code, Codex y OpenCode — y muéstralo en tu perfil de GitHub.
[](LICENSE)
[](https://www.python.org/)
[](https://github.com/dexhunter/vibe-clock)
---
## Inicio rápido
```bash
# macOS (Homebrew)
brew install dexhunter/tap/vibe-clock
# o vía pip
pip install vibe-clock
```
```bash
vibe-clock init # detecta agentes automáticamente, configura todo
vibe-clock summary # ve tus estadísticas en la terminal
```
## Privacidad y seguridad
**Tu código nunca sale de tu máquina.** vibe-clock solo lee metadatos de sesión (marcas de tiempo, conteos de tokens, nombres de modelos) de los logs JSONL locales. Antes de que se envíe cualquier dato:
1. **El sanitizador elimina toda información personal** — rutas de archivos, nombres de proyectos, nombres de usuario y código son removidos ([`sanitizer.py`](vibe_clock/sanitizer.py))
2. **Los proyectos se anonimizan** — los nombres reales se convierten en "Project A", "Project B"
3. **`--dry-run` te permite inspeccionar** exactamente qué se enviará antes de hacerlo
**Lo que se envía** (a tu propio gist público):
- Conteos de sesiones, conteos de mensajes, duraciones
- Totales de uso de tokens por modelo
- Nombres de modelos y agentes
- Agregados de actividad diaria
**Lo que NUNCA se envía**: rutas de archivos, nombres de proyectos, contenido de mensajes, fragmentos de código, información de git o cualquier información personal.
## Gráficos configurables
Genera solo los gráficos que necesites con `--type`:
```bash
vibe-clock render --type card,donut # solo estos dos
vibe-clock render --type all # los 7 gráficos (por defecto)
```
| Gráfico | Archivo | Descripción |
|---------|---------|-------------|
| `card` | `vibe-clock-card.svg` | Tarjeta de resumen de estadísticas |
| `heatmap` | `vibe-clock-heatmap.svg` | Mapa de calor de actividad diaria |
| `donut` | `vibe-clock-donut.svg` | Distribución de uso de modelos |
| `bars` | `vibe-clock-bars.svg` | Barras de sesiones por proyecto |
| `token_bars` | `vibe-clock-token-bars.svg` | Uso de tokens por modelo |
| `hourly` | `vibe-clock-hourly.svg` | Actividad por hora del día |
| `weekly` | `vibe-clock-weekly.svg` | Actividad por día de la semana |
## Configuración de GitHub Actions
Agrega esto a tu repositorio de perfil `/` para actualizar los SVGs automáticamente cada día.
### 1. Envía tus estadísticas
```bash
vibe-clock push # crea un gist público con datos sanitizados
# Anota el ID del gist que se muestra
```
### 2. Agrega el secreto
En tu repositorio de perfil: **Settings → Secrets → Actions** → agrega:
- `VIBE_CLOCK_GIST_ID` — el ID del gist del paso 1
### 3. Crea el workflow
`.github/workflows/vibe-clock.yml`:
```yaml
name: Update Vibe Clock Stats
on:
workflow_dispatch:
jobs:
update:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dexhunter/vibe-clock@v1.4.0
with:
gist_id: ${{ secrets.VIBE_CLOCK_GIST_ID }}
```
### 4. Agrega los SVGs a tu README
```html
```
### 5. Ejecútalo
Ve a la pestaña **Actions** → "Update Vibe Clock Stats" → **Run workflow**
### Parámetros del Action
| Parámetro | Predeterminado | Descripción |
|-----------|---------------|-------------|
| `gist_id` | *requerido* | ID del Gist que contiene `vibe-clock-data.json` |
| `theme` | `dark` | `dark` o `light` |
| `output_dir` | `./images` | Directorio de salida para archivos SVG |
| `chart_types` | `all` | Separados por coma: `card,heatmap,donut,bars,token_bars,hourly,weekly` o `all` |
| `commit` | `true` | Auto-commit de los SVGs generados |
| `commit_message` | `chore: update vibe-clock stats` | Mensaje del commit |
### Cómo funciona
```
Tú (local) GitHub
───────── ──────
vibe-clock push ──▶ Gist (JSON sanitizado)
│
└──▶ workflow_dispatch
│
obtener JSON del gist
generar SVGs
commit al repositorio de perfil
```
## Agentes soportados
| Agente | Ubicación de logs | Estado |
|--------|-------------------|--------|
| **Claude Code** | `~/.claude/` | Soportado |
| **Codex** | `~/.codex/` | Soportado |
| **Gemini CLI** | `~/.gemini/` | Soportado |
| **OpenCode** | `~/.local/share/opencode/` | Soportado |
## Comandos
| Comando | Descripción |
|---------|-------------|
| `vibe-clock init` | Configuración interactiva — detecta agentes, solicita token de GitHub |
| `vibe-clock summary` | Resumen enriquecido de estadísticas de uso en la terminal |
| `vibe-clock status` | Muestra la configuración actual y el estado de conexión |
| `vibe-clock render` | Genera visualizaciones SVG localmente |
| `vibe-clock export` | Exporta estadísticas sin procesar como JSON |
| `vibe-clock push` | Envía estadísticas sanitizadas a un gist de GitHub y dispara el renderizado del repositorio de perfil |
| `vibe-clock push --dry-run` | Previsualiza lo que se enviaría |
| `vibe-clock schedule` | Programar push periódico automático (launchd / systemd / cron) |
| `vibe-clock unschedule` | Eliminar la tarea de push programada |
## Configuración
Archivo de configuración: `~/.config/vibe-clock/config.toml`
Variables de entorno:
- `GITHUB_TOKEN` — PAT de GitHub con permisos de `gist`
- `VIBE_CLOCK_GIST_ID` — ID del Gist para enviar/recibir
- `VIBE_CLOCK_DAYS` — Número de días a agregar
## Licencia
MIT