- Seed: restructure Engagement Forgeron (51→59 items) avec 3 nouvelles sections: Engagements fondamentaux (EF1-EF3), Engagements techniques (ET1-ET3), Qualification (Q0-Q1) liée au protocole Embarquement - Seed: ajout protocole Embarquement Forgeron (5 jalons: candidature, miroir, évaluation, certification Smith, mise en ligne) - GenesisBlock: fix lisibilité — fond mood-surface teinté accent au lieu de mood-text inversé, texte mood-aware au lieu de rgba blanc hardcodé - InertiaSlider: mini affiche "Inertie" sous le curseur, compact en width:fit-content pour s'adapter au label - Frontend: ajout section qualification dans SECTION_META/SECTION_ORDER - Pages, composants et tests des sprints précédents Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
11 KiB
Spike : Moteur de workflow — Protocole Embarquement Forgerons
Date : 2026-03-02 Statut : Spike / Pré-étude Auteur : Yvv + Claude
Contexte : deux objets distincts
L'app a déjà deux concepts qui se côtoient dans "Protocoles" :
| Objet | Ce que c'est | Exemple |
|---|---|---|
| VotingProtocol | Règle de vote (formule, seuils, critères) | "Vote forgeron (Smith)" — D30M50B.1G.2S.1 |
| Decision + Steps | Processus multi-étapes (one-shot) | "Runtime Upgrade" — 5 étapes séquentielles |
Il manque un troisième objet : le Protocole opérationnel réutilisable — un template de workflow qui s'instancie pour chaque candidat/cas.
Exemple : Embarquement Forgerons
Ce n'est pas une décision ponctuelle. C'est un processus répétable :
[Candidat] ──invite──▶ [Invitation on-chain]
│
◀──accept──
│
──setSessionKeys──▶ [Preuve technique]
│
┌──checklist aspirant (aléatoire, avec pièges)
│
├──certif smith 1 (checklist certificateur)
├──certif smith 2 (checklist certificateur)
└──certif smith 3 (checklist certificateur)
│
──goOnline──▶ [Autorité active]
Chaque étape a :
- Un acteur (candidat, certificateur, système)
- Des prérequis (étapes précédentes complétées)
- Une preuve (on-chain tx, checklist complétée, vote)
- Un délai (optionnel)
Volume croissant prévisible
| Protocole opérationnel | Acteurs | Instances/an estimées |
|---|---|---|
| Embarquement Forgerons | candidat + 3 certifieurs | ~10-50 |
| Embarquement Membre (Certification) | certifié + 5 certifieurs | ~500-2000 |
| Runtime Upgrade | CoTec + forgerons + communauté | ~4-12 |
| Modification Document | proposeur + communauté | ~10-50 |
| Mandat (élection/révocation) | candidat + communauté | ~5-20 |
| Engagement CoTec | candidat + CoTec | ~2-5 |
Observation clé : l'Embarquement Membre est le plus massif et partage la même structure que l'Embarquement Forgeron (checklist + certifications multiples). L'architecture doit être pensée pour ce volume.
Options évaluées
Option A : n8n (workflow automation)
n8n est un outil d'automatisation visuel (self-hosted, open source).
| Pour | Contre |
|---|---|
| Éditeur visuel de workflows | Dépendance externe lourde (~500 MB Docker) |
| Webhooks, triggers, crons intégrés | Latence réseau (appels HTTP entre services) |
| 400+ intégrations (email, matrix, etc.) | Pas de MCP server configuré actuellement |
| Pas de code à écrire pour l'orchestration | Pas de concept natif de "checklist aléatoire" |
| Les preuves on-chain nécessitent du dev custom de toute façon | |
| La communauté Duniter refuse les dépendances centralisées |
Verdict : n8n est excellent pour les automations périphériques (notifications, alertes, reporting), pas pour le cœur du workflow. Le cœur doit rester dans l'app.
Usage recommandé de n8n : connecteur optionnel pour les triggers de notification (webhook quand une étape change de statut → email/matrix/telegram). Ne pas en faire le moteur.
Option B : Dev maison — étendre Decision/DecisionStep
Étendre le modèle Decision existant avec un concept de template.
class ProcessTemplate(Base):
"""Reusable workflow template (e.g. "Embarquement Forgeron")."""
id: UUID
slug: str # "embarquement-forgeron"
name: str # "Embarquement Forgerons"
description: str
category: str # "onboarding", "governance", "upgrade"
step_templates: JSON # Ordered list of step definitions
checklist_document_id: UUID # FK to Document (engagement forgeron)
voting_protocol_id: UUID # FK to VotingProtocol
is_active: bool
class ProcessInstance(Base):
"""One execution of a template (e.g. "Embarquement de Matograine")."""
id: UUID
template_id: UUID # FK to ProcessTemplate
candidate_id: UUID # FK to DuniterIdentity (le candidat)
status: str # invited, accepted, keys_set, checklist, certifying, online, failed
current_step: int
started_at: datetime
completed_at: datetime | None
metadata: JSON # on-chain tx hashes, certifier IDs, etc.
class ProcessStepExecution(Base):
"""One step within an instance."""
id: UUID
instance_id: UUID
step_order: int
step_type: str # "on_chain", "checklist", "certification", "manual"
actor_id: UUID | None # Who must act
status: str # pending, active, completed, failed, skipped
proof: JSON | None # tx_hash, checklist_result, vote_session_id
started_at: datetime | None
completed_at: datetime | None
| Pour | Contre |
|---|---|
| Zéro dépendance externe | Plus de code à écrire |
| Contrôle total sur la checklist (ordre aléatoire, pièges) | Faut designer le moteur de transitions |
| Les preuves on-chain sont natives (substrate-interface) | Le workflow avancé (timeouts, escalation) sera simpliste |
| S'intègre avec le vote engine existant | |
| La DB track tout (audit trail complet) | |
| Volume OK avec PostgreSQL (100k instances/an = rien) |
Verdict : c'est la voie naturelle. Le modèle actuel Decision + Steps est une version simplifiée de ça. On l'étend proprement.
Option C : Temporal.io / autre moteur de workflow distribué
| Pour | Contre |
|---|---|
| Garanties transactionnelles fortes | Énorme pour le use case (~GB de RAM) |
| Retry/timeout/escalation natifs | Cluster Temporal = infra supplémentaire |
| Bon pour les longs workflows (jours/semaines) | Surcharge conceptuelle |
| Aucune intégration native blockchain |
Verdict : overkill. À considérer uniquement si on dépasse 10 protocoles actifs avec des centaines d'instances simultanées. Pas avant 2028.
Recommandation
Sprint 2 : Option B — Dev maison, progressif
Phase 1 (Sprint 2) — Fondations :
- Créer
ProcessTemplate+ProcessInstance+ProcessStepExecution - Seed : template "Embarquement Forgerons" avec ses 7 étapes
- Frontend : page
/protocols/embarquement-forgeronsavec timeline visuelle - API :
POST /processes/{template_slug}/start→ crée une instance - API :
POST /processes/instances/{id}/advance→ passe à l'étape suivante
Phase 2 (Sprint 3) — Checklist interactive :
- UI de checklist avec ordre aléatoire + détection pièges
- Liaison avec le Document (engagement forgeron) pour les clauses
- Signature Ed25519 du résultat de checklist (preuve cryptographique)
Phase 3 (Sprint 4+) — On-chain :
- Trigger on-chain via substrate-interface (invite, accept, certify, goOnline)
- Listener d'événements blockchain pour compléter automatiquement les étapes on-chain
- Optionnel : webhook n8n pour notifications matrix/telegram
Architecture cible
┌─────────────────────────────────────────────────┐
│ Frontend │
│ /protocols/embarquement-forgerons │
│ ├── Vue template (timeline, étapes) │
│ ├── Checklist interactive (aléatoire + pièges) │
│ └── Instance dashboard (candidats en cours) │
└──────────────────┬──────────────────────────────┘
│ API REST
┌──────────────────▼──────────────────────────────┐
│ Backend │
│ ProcessService │
│ ├── create_instance(template, candidate) │
│ ├── advance_step(instance, proof) │
│ ├── evaluate_checklist(instance, answers) │
│ └── on_chain_trigger(instance, extrinsic) │
│ │
│ SubstrateService (substrate-interface) │
│ ├── smithsMembership.invite() │
│ ├── smithsMembership.acceptInvitation() │
│ ├── smithsMembership.setSessionKeys() │
│ └── authorityMembers.goOnline() │
└──────────────────┬──────────────────────────────┘
│ Events
┌──────────────────▼──────────────────────────────┐
│ n8n (optionnel) │
│ Webhook → Notification matrix/telegram/email │
│ Cron → Relance candidats inactifs │
└─────────────────────────────────────────────────┘
Ce que n8n ne fait PAS (et qu'on doit coder) :
- Checklist aléatoire avec clause piège et interruption
- Signature Ed25519 du résultat
- Appels substrate-interface (invite, certify, goOnline)
- Calcul de seuil unani-majoritaire
- Intégrité du workflow (preuve on-chain de chaque étape)
Ce que n8n PEUT faire (optionnel, sprint 4+) :
- Webhook → notification email quand un candidat arrive à l'étape "certification"
- Cron → rappel hebdo aux certificateurs qui n'ont pas agi
- Webhook → post forum automatique quand un forgeron est accepté
- Dashboard monitoring (combien de candidats en cours, taux de completion)
Nomenclature proposée dans l'UI
| Menu | Sous-section | Contenu |
|---|---|---|
| Protocoles | Protocoles de vote | VotingProtocol (binaire, nuancé, smith, techcomm) |
| Simulateur de formules | FormulaConfig interactif | |
| Protocoles opérationnels | ProcessTemplate (embarquement, upgrade, etc.) | |
| Décisions | (inchangé) | Decision + Steps (instances one-shot) |
Les protocoles opérationnels ont leur propre section dans /protocols avec :
- Carte par template (nom, description, nb d'instances actives)
- Page détail : timeline template + liste d'instances en cours
- Page instance : suivi temps réel d'un candidat spécifique
Prochaine étape
Valider cette orientation avec Yvv, puis :
- Créer les 3 tables (ProcessTemplate, ProcessInstance, ProcessStepExecution)
- Migration Alembic
- Seed le template "Embarquement Forgerons" (7 étapes)
- Router + service backend
- Frontend : page template + page instance