Skip to content

Latest commit

 

History

History
59 lines (35 loc) · 4.39 KB

README.md

File metadata and controls

59 lines (35 loc) · 4.39 KB

MonitoringActivite - Projet M1

Nous vous invitons à lire "rapport-MonitoringActivite.pdf" dans le dossier "rapport" pour mieux prendre connaissance du projet.

Remarque : La documentation utilisateur pour le site "Monitoring d'activité" se trouve dans le répertoire "User-Doc".

1) Court descriptif du projet

L’objectif du monitoring d’activité est de proposer une interface web permettant de visualiser l’ensemble des informations caractérisant l’activité de la personne présente dans une pièce nommée « LaboVision ». Cette pièce dispose de plusieurs capteurs. Afin de caractériser l'activité de la personne présente dans la pièce, trois indicateurs ont été développés :

  1. Temps passé devant la télévision.
  2. Présence de la personne dans les différentes parties du LaboVision (cuisine, salon, chambre).
  3. Anomalies sonores (niveau sonore anormalement élevé). L’utilisateur du monitoring peut configurer les paramètres qui caractérisent une anomalie sonore (le seuil de déclenchement, pendant combien de secondes, et sur quelle tranche horaire de la journée).

Trois programmes, s'exécutant sur des machines présentes dans le LaboVision, permettent de générer les données de ces indicateurs. Le monitoring d’activité permet de synthétiser ces données et de les afficher via un site internet simple et intuitif.

2) Machines utilisées

Voici l'ensemble des informations liées aux machines / adresses IP utilisées pour la version du projet déjà déployée dans le LaboVision.

  1. Deux machines virtuelles ont été utilisées (Ubuntu 16.04, 10GB d'espace disque, 2048 Mo de RAM).

  2. Informations concernant le site du "Monitoring d'activité" :

    • Site hébergé sur la machine n°1
    • Site accessible à l'adresse [adresse IP machine n°1]/monitoring_activite/
  3. Informations concernant BDD (base de données) :

    • BDD hébergée sur la machine n°1
    • Utilisateur créé spécifiquement pour la BDD du projet
  4. Quatre programmes Qt ont été développés (codes sources dans le répertoire "Programmes-Qt") :

    • BruitLabo : détecte les anomalies sonores et envoie les données via WebSocket (port 4420)
    • EnregTV : détecte une activité de visionnage TV et envoie les données via WebSocket (port 4430)
    • DetectZone : détecte les déplacements dans le LaboVision et envoie les données via WebSocket (port 4440)
    • WSLitener : reçoie ces données WebSocket et les communiquent aux fichiers PHP du site pour l'insertion en BDD

3) Déploiement du projet

  1. Créer une BDD MySQL avec comme nom de BDD : monitoring_activite.

  2. Une fois connectée à la BDD, créer l'ensemble des tables grâce au fichier "BDD/monitoring_activite_bdd_init.sql" présent dans ce dossier de rendu.

  3. Copier-coller le répertoire "monitoring_activite" présent dans ce dossier de rendu sur votre serveur web.

  4. Modifier le fichier "monitoring_activite/utils/bdd_connection.php" pour modifier les constantes de connexion afin que le site accède à la BDD créée à l'étape n°1.

  5. OPTIONNEL : connecté à la BDD, importer le fichier "BDD/INSERT-example.sql" présent dans ce dossier de rendu afin d'avoir des données à tester (penser à mettre ces données à la date du jour pour voir les informations s'afficher sur la page d'accueil du monitoring).

  6. Si nécessaire, penser à modifier :

    • l'adresse de la caméra dans les fichiers "zonetracker.cpp" (programme DetectZone) et "tvtracker.cpp" (programme EnregTV) dans la méthode tracking().
    • l'adresse IP fournie à l'initialisation du membre "m_network" dans le constructeur du fichier "listeconfanomaliesonore.cpp" (programme BruitLabo). L'adresse IP doit être celle de la machine où se trouve le site déployé à l'étape n°4.
    • l'adresse IP fournie à l'initialisation du membre "m_network" dans le constructeur du fichier "detect.cpp" (programme WSLitener). L'adresse IP doit être celle de la machine où se trouve le site déployé à l'étape n°4.
  7. Compiler les 4 programmes sous Qt et les placer sur les machines désirées.

Attention : Si vous déployez les programmes sur des machines différentes que celle de la version actuellement en production, pensez à modifier le fichier "run.sh" pour le lancement du programme "WSListener" (les adresses correspondent aux machines hébergeant les programmes. Adresses utilisées pour les communications WebSockets).