feat(diagrammes): créer tous les diagrammes d'entités du projet
Création complète de tous les modèles de données : ✅ Déjà existants : - modele-global.md : USERS, CONTENTS, SUBSCRIPTIONS, LISTENING_HISTORY - modele-moderation.md : REPORTS, SANCTIONS, APPEALS, STRIKES, BADGES 🆕 Nouveaux diagrammes : - modele-recommandation.md : USER_INTERESTS, INTEREST_CATEGORIES Jauges 0-100%, évolution temps réel, pas de dégradation temporelle - modele-publicites.md : AD_CAMPAIGNS, AD_METRICS, AD_IMPRESSIONS Ciblage géo/horaire/intérêts, budget prépayé, validation 24-48h - modele-premium.md : PREMIUM_SUBSCRIPTIONS, ACTIVE_STREAMS, OFFLINE_DOWNLOADS Multi-devices (1 stream actif), offline 30j, sans essai gratuit - modele-monetisation.md : CREATOR_MONETIZATION, CREATOR_REVENUES, PAYOUTS KYC obligatoire, revenus pub (3€/1000) + premium (70/30), seuil 50€ - modele-audio-guides.md : AUDIO_GUIDES, GUIDE_SEQUENCES, USER_GUIDE_PROGRESS Multi-séquences GPS, 4 modes (piéton/voiture/vélo/transport), 2-50 séquences - modele-radio-live.md : LIVE_STREAMS, LIVE_RECORDINGS, LIVE_LISTENERS Buffer 15s, max 8h, enregistrement auto, notification abonnés Avantages architecture : ✅ Séparation entités globales (1 source vérité) ✅ Diagrammes focalisés par domaine métier ✅ Maintenance simplifiée (pas de duplication) ✅ Cohérence avec règles métier validées 8 modèles de données complets couvrant 100% du projet MVP.
This commit is contained in:
68
docs/diagrammes/entites/modele-audio-guides.md
Normal file
68
docs/diagrammes/entites/modele-audio-guides.md
Normal file
@@ -0,0 +1,68 @@
|
||||
# Modèle de données - Audio-guides
|
||||
|
||||
📖 Voir [Règles métier - Section 06 : Audio-guides multi-séquences](../../regles-metier/06-audio-guides-multi-sequences.md) | [Entités globales](modele-global.md)
|
||||
|
||||
## Diagramme
|
||||
|
||||
```mermaid
|
||||
erDiagram
|
||||
AUDIO_GUIDES }o--|| USERS : "créé par"
|
||||
AUDIO_GUIDES ||--o{ GUIDE_SEQUENCES : "contient"
|
||||
AUDIO_GUIDES ||--o{ USER_GUIDE_PROGRESS : "progression"
|
||||
|
||||
GUIDE_SEQUENCES }o--|| AUDIO_GUIDES : "appartient à"
|
||||
|
||||
USER_GUIDE_PROGRESS }o--|| USERS : "utilisateur"
|
||||
USER_GUIDE_PROGRESS }o--|| AUDIO_GUIDES : "guide"
|
||||
USER_GUIDE_PROGRESS }o--|| GUIDE_SEQUENCES : "séquence actuelle"
|
||||
|
||||
AUDIO_GUIDES {
|
||||
uuid id PK
|
||||
uuid creator_id FK
|
||||
string title
|
||||
text description
|
||||
string travel_mode
|
||||
int recommended_speed_kmh
|
||||
int sequences_count
|
||||
int total_duration_seconds
|
||||
decimal total_distance_meters
|
||||
polygon diffusion_zone
|
||||
string[] tags
|
||||
string age_rating
|
||||
string status
|
||||
timestamp published_at
|
||||
}
|
||||
|
||||
GUIDE_SEQUENCES {
|
||||
uuid id PK
|
||||
uuid guide_id FK
|
||||
int sequence_order
|
||||
string title
|
||||
string audio_url
|
||||
int duration_seconds
|
||||
point gps_location
|
||||
int trigger_radius_meters
|
||||
boolean requires_manual_trigger
|
||||
timestamp created_at
|
||||
}
|
||||
|
||||
USER_GUIDE_PROGRESS {
|
||||
uuid id PK
|
||||
uuid user_id FK
|
||||
uuid guide_id FK
|
||||
uuid current_sequence_id FK
|
||||
int sequences_completed_count
|
||||
decimal completion_percentage
|
||||
timestamp started_at
|
||||
timestamp last_updated
|
||||
timestamp completed_at
|
||||
}
|
||||
```
|
||||
|
||||
## Légende
|
||||
|
||||
**Entités audio-guides** :
|
||||
|
||||
- **AUDIO_GUIDES** : Audio-guides multi-séquences - Travel_mode : `pedestrian` (manuel), `car` (auto GPS + manuel), `bicycle` (auto GPS + manuel), `transport` (auto GPS + manuel) - Sequences_count : Min 2, Max 50 séquences - Status : `draft`, `pending_review`, `published`, `archived` - Diffusion_zone : Polygon géographique (où l'audio-guide est recommandé)
|
||||
- **GUIDE_SEQUENCES** : Séquences audio géolocalisées - Sequence_order : Ordre lecture 1, 2, 3... - Trigger_radius : 10-100m selon mode (piéton 10m, voiture 50m) - Requires_manual_trigger : true si mode piéton (bouton "Suivant"), false si auto GPS - GPS_location : Point WGS84 (latitude, longitude) sauf mode piéton
|
||||
- **USER_GUIDE_PROGRESS** : Progression utilisateur - Completion_percentage : 0-100% (nb séquences complétées / total) - Current_sequence_id : Dernière séquence écoutée (pour reprise) - Started_at : Date démarrage parcours - Completed_at : NULL si en cours, timestamp si terminé
|
||||
Reference in New Issue
Block a user