Phase 13 : sogoms-cron
- Jobs planifiés avec schedule cron standard
- Types: query_email, http, service
- Actions: list, trigger, status
Phase 16 : Réorganisation config/apps/{app}/
- Tous les fichiers d'une app dans un seul dossier
- Migration prokov vers nouvelle structure
Phase 17 : sogoms-admin
- Interface web d'administration (Go templates + htmx)
- Auth sessions cookies signées HMAC-SHA256
- Rôles super_admin / app_admin avec permissions
Phase 19 : Création d'app via Admin UI
- Formulaire création app avec config DB/auth
- Bouton "Scanner la base" : introspection + schema.yaml
- Rechargement automatique sogoway via SIGHUP
Infrastructure :
- sogoctl : socket de contrôle /run/sogoctl.sock
- sogoway : reload config sur SIGHUP sans restart
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
43 lines
1.0 KiB
YAML
43 lines
1.0 KiB
YAML
# Scénario: Détail d'un statut
|
|
name: statuses_show
|
|
version: "1.0"
|
|
description: Retourne un statut avec le nombre de tâches
|
|
|
|
input:
|
|
required:
|
|
- id
|
|
validation:
|
|
id:
|
|
type: int
|
|
|
|
steps:
|
|
- id: get_status
|
|
service: db
|
|
action: query_one
|
|
params:
|
|
query: "SELECT * FROM statuses WHERE id = ? AND user_id = ?"
|
|
args: ["{{input.id}}", "{{auth.user_id}}"]
|
|
on_error: abort
|
|
error_message: "Statut non trouvé"
|
|
error_status: 404
|
|
|
|
- id: count_tasks
|
|
service: db
|
|
action: query_one
|
|
params:
|
|
query: "SELECT COUNT(*) as count FROM tasks WHERE status_id = ?"
|
|
args: ["{{input.id}}"]
|
|
|
|
output:
|
|
status: 200
|
|
body:
|
|
success: true
|
|
data:
|
|
id: "{{steps.get_status.result.id}}"
|
|
code: "{{steps.get_status.result.code}}"
|
|
name: "{{steps.get_status.result.name}}"
|
|
color: "{{steps.get_status.result.color}}"
|
|
project_id: "{{steps.get_status.result.project_id}}"
|
|
position: "{{steps.get_status.result.position}}"
|
|
task_count: "{{steps.count_tasks.result.count}}"
|