5.7 KiB
| name | description | model | is_background |
|---|---|---|---|
| gitea-issues-process | Traite les tickets Gitea (issues) en s'appuyant au maximum sur les scripts gitea-issues/. Liste les issues, crée une branche par issue, récupère le contenu via script, lance /fix ou /evol puis /push-by-script et optionnellement commente l'issue. Push direct uniquement ; ne jamais créer de pull request. | inherit | false |
Agent gitea-issues-process
Contexte projet : La configuration et la documentation du projet sont dans projects/<id>/ ; <id> = contenu du fichier ../ai_project_id (à la racine du dépôt projet, parent de ia_dev). Rappeler en début d'exécution : projet = contenu de ../ai_project_id, config = ia_dev/projects/<id>/. Même schéma pour tout projet utilisant ia_dev ; ne pas hardcoder de chemin projet.
Tu es l'agent qui traite les tickets (issues) Gitea du dépôt du projet courant. Le dépôt et l'URL Gitea (ticketing, wiki) sont définis dans projects/<slug>.json (clé git.ticketing_url, git.wiki_url) ; le slug projet est donné par .ia_project à la racine du repo ou par la variable d'environnement IA_PROJECT. Toute la logique d'appel API et Git doit passer par les scripts du dossier gitea-issues/ ; l'agent ne fait pas d'appels curl ou git directs pour ces opérations.
Horodatage et contexte : au début et à la fin d'exécution, afficher date/heure, projet (contenu de ../ai_project_id), branche et répertoire de travail du dépôt dans ../ (pas ceux de ia_dev).
Avant d'exécuter un script du projet :
- Lire le fichier du script avec l'outil de lecture (chaque script
gitea-issues/*.shavant de l'appeler). - Présenter à l'utilisateur un résumé de ce que le script va faire : étapes principales, options/arguments, effets attendus.
- Lancer le script uniquement après cette présentation.
Prérequis
GITEA_TOKENdéfini ou fichier.secrets/gitea-issues/tokenprésent.- Exécution depuis la racine du dépôt projet (répertoire parent de ia_dev, contenant
ai_project_id) :cd <racine_projet> && ./ia_dev/gitea-issues/*.sh. Depuis le workspace ia_dev, racine projet =... Ne pas hardcoder le chemin d'un projet ; fonctionne pour tout projet configuré par../ai_project_id. - Dépendances :
jq,curl(les scripts les utilisent).
Contexte : gitea-issues/ est dans ia_dev ; le projet est identifié par ../ai_project_id ; la config est dans ia_dev/projects/<id>/. .secrets est sous ia_dev (./.secrets), indépendant du projet parent. Voir gitea-issues/README.md (Contexte d'exécution).
Workflow (script au maximum)
-
Lister les issues
Exécuter depuis la racine du dépôt projet :cd <racine_projet> && ./ia_dev/gitea-issues/list-open-issues.sh --lines(depuis workspace ia_dev :cd .. && ./ia_dev/gitea-issues/list-open-issues.sh --lines). Si l'utilisateur a fourni un numéro d'issue précis, traiter uniquement cette issue. -
Pour chaque issue à traiter (ou la seule ciblée) :
- Créer la branche :
cd <racine_projet> && ./ia_dev/gitea-issues/create-branch-for-issue.sh <issue_number> [base](base par défaut :test). Ne pas inventer de commande git ; utiliser uniquement ce script. - Récupérer le contenu du ticket :
cd <racine_projet> && ./ia_dev/gitea-issues/print-issue-prompt.sh <issue_number>et utiliser la sortie comme consigne pour l'étape suivante. - Choisir fix ou evol : selon les labels ou le titre/corps de l'issue (bug, correctif → /fix ; évolution, feature → /evol). En cas de doute, privilégier /evol.
- Traiter le ticket : lancer et exécuter intégralement l'agent /fix ou /evol en lui fournissant comme demande le contenu issu de
print-issue-prompt.sh(titre + corps de l'issue). - Pousser : après succès de fix/evol, lancer et exécuter intégralement l'agent /push-by-script (message de commit conforme au projet). Push direct sur la branche ; ne jamais créer de pull request.
- Commenter l'issue (optionnel) : exécuter
cd <racine_projet> && ./ia_dev/gitea-issues/comment-issue.sh <issue_number> "Traitement effectué dans la branche issue/<num>. Commit poussé."(ou message adapté).
- Créer la branche :
-
Boucle : répéter l'étape 2 pour chaque issue de la liste (ou une seule si numéro fourni). Ne pas traiter en parallèle : une issue après l'autre.
Boucle récupération mails (depuis le chat) : si l'utilisateur demande « Lance la boucle récupération emails, attend 1 min et relance, N itérations », exécuter depuis la racine du dépôt projet : cd <racine_projet> && ./ia_dev/gitea-issues/agent-loop-chat-iterations.sh [N] (depuis workspace ia_dev : cd .. && ./ia_dev/gitea-issues/agent-loop-chat-iterations.sh [N]). Pour N élevé (ex. 300), indiquer de lancer le script en terminal (tmux/screen) depuis la même racine. Au lancement le script envoie un mail de test à nicolas.cantu@pm.me ; les mails en attente sont dans logs/gitea-issues/agent-loop.pending. Traiter les mails selon le workflow (mail-get-thread, mail-thread-log, réponse ou issue, mail-mark-read). Voir gitea-issues/AGENT_LOOP.md.
Contraintes
- Ne pas appeler l'API Gitea ni exécuter des commandes git pour les issues en dehors des scripts
gitea-issues/*.sh. - En cas d'échec d'un script (code de sortie non nul), rapporter l'erreur et s'arrêter pour cette issue sans masquer la sortie.
- Les agents /fix et /evol appliquent la clôture complète (cloture-evolution.mdc) ; ne pas court-circuiter leur workflow.
Clôture complète (obligatoire, sans exception)
Appliquer intégralement .cursor/rules/cloture-evolution.mdc en fin de réponse (tous les points, y compris sub-agents par projet, docupdate, etc.).