Notre avis
Cette compétence permet de stocker et récupérer des mémoires de projet (plans, spécifications, tâches) à l'aide du système kv d'atuin, assurant une continuité de contexte entre les sessions.
Points forts
- Conserve le contexte du projet entre sessions sans fichiers locaux
- Utilise git pour identifier automatiquement le projet et la branche
- Support des mémoires multi-lignes via fichiers temporaires
- Commandes simples pour lister, récupérer, stocker et supprimer
Limites
- Nécessite qu'atuin soit installé et configuré
- Dépend de la cohérence des noms de clés (projet-branche)
- Ne supporte pas nativement le chiffrement des mémoires
Lorsque vous commencez une nouvelle session de travail sur un projet et souhaitez retrouver rapidement l'état d'avancement, les plans ou les spécifications précédentes.
Pour stocker des informations sensibles ou volumineuses qui nécessitent un système de gestion de base de données dédié.
Analyse de sécurité
SûrThe skill uses atuin kv (key-value store) for project memory, with Bash commands limited to safe patterns like git metadata retrieval and temp file handling. No destructive, exfiltrating, or obfuscated commands are present.
Aucun point d'attention détecté
Exemples
Check if there are any stored memories for this project on the current branch.Store the current implementation plan as a project memory so I can resume later.What was I working on last session? Show me the session summary from yesterday.name: atuin-memory description: Check, store, and retrieve project memories from atuin kv. Use when starting work on a project, recalling previous context, storing plans or specs, or when the user mentions memory, atuin, or project context. allowed-tools:
- Bash(atuin *)
- Bash(git rev-parse *)
- Bash(git branch *)
- Bash(basename *)
- Bash(pwd)
- Bash(cat *)
- Bash(echo *)
- Bash(grep *)
- Bash(head *)
- Read
Project Memory with Atuin
Store and retrieve project context using atuin kv to persist across sessions.
Project Detection
Reuse these variables in all commands:
PROJECT=$(basename "$(git rev-parse --show-toplevel 2>/dev/null)" 2>/dev/null || basename "$PWD")
BRANCH=$(git branch --show-current 2>/dev/null)
BRANCH=${BRANCH:-main}
Before Starting Work
echo "=== $PROJECT ($BRANCH) ==="
# Discover what memories exist for this project
atuin kv list --namespace "project-metadata" | grep -F "$PROJECT-" || echo "(no memories found)"
Then retrieve relevant memories:
# Empty output means memory doesn't exist
atuin kv get --namespace "project-metadata" "$PROJECT-$BRANCH-plan"
atuin kv get --namespace "project-metadata" "$PROJECT-$BRANCH-spec"
atuin kv get --namespace "project-metadata" "$PROJECT-$BRANCH-todo"
Acting on Retrieved Memories
<memory-actions> <on-retrieval> - Check if stored plan/spec/todo still matches git state and current goals - Briefly summarize what you found so user can correct misunderstandings - Raise blockers, gaps, or open questions before proceeding—don't assume, ask - Pick up from first incomplete todo item; if none exist, start fresh </on-retrieval> <on-completion> - Update stored state after completing work so next session can resume cleanly </on-completion> </memory-actions>Storing Memories
For multi-line content, write to a temp file first to avoid shell escaping issues:
# 1. Write content to temp file
# 2. Store from temp file
atuin kv set --namespace "project-metadata" --key "$PROJECT-$BRANCH-plan" "$(cat /tmp/plan.md)"
# 3. Verify storage succeeded
atuin kv get --namespace "project-metadata" "$PROJECT-$BRANCH-plan" | head -5
For short single-line values, store directly:
atuin kv set --namespace "project-metadata" --key "$PROJECT-$BRANCH-status" "in-progress"
Key Naming
| Key Pattern | Purpose |
|-------------|---------|
| {project}-{branch}-plan | Implementation plans |
| {project}-{branch}-spec | Specifications/designs |
| {project}-{branch}-todo | Task state |
| {project}-{branch}-session-$(date +%Y-%m-%d) | Session summaries (use current date) |
Deleting Memories
# Delete a specific key
atuin kv delete --namespace "project-metadata" "$PROJECT-$BRANCH-plan"
# Verify deletion (should return empty)
atuin kv get --namespace "project-metadata" "$PROJECT-$BRANCH-plan"
Quick Reference
Argument syntax is inconsistent across subcommands — pay attention to positional vs flag arguments:
| Operation | Command | Notes |
|-----------|---------|-------|
| List all | atuin kv list --namespace "project-metadata" | |
| Get | atuin kv get --namespace "project-metadata" "key" | KEY is positional |
| Set | atuin kv set --namespace "project-metadata" --key "key" "value" | KEY is --key flag, VALUE is positional |
| Delete | atuin kv delete --namespace "project-metadata" "key" | KEY is positional (not --key) |
Expert Next.js App Router
Developpement
Un skill qui transforme Claude en expert Next.js App Router.
Générateur de README
Developpement
Crée des README.md professionnels et complets pour vos projets.
Rédacteur de Documentation API
Developpement
Génère de la documentation API complète au format OpenAPI/Swagger.