Files
roadwave/docs/diagrammes/entites/modele-audio-guides.md
jpgiannetti 04cd6327ab 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.
2026-02-07 16:29:54 +01:00

2.6 KiB

Modèle de données - Audio-guides

📖 Voir Règles métier - Section 06 : Audio-guides multi-séquences | Entités globales

Diagramme

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é