diff --git a/.drone.yml b/.drone.yml
index fe49e6cf..8a1f3075 100644
--- a/.drone.yml
+++ b/.drone.yml
@@ -1,11 +1,8 @@
kind: pipeline
type: docker
-name: HeartTrack
+name: HeartWave
trigger:
- branch:
- - master
- - merged
event:
- push
@@ -51,7 +48,6 @@ steps:
from_secret: SECRET_REGISTRY_USERNAME
password:
from_secret: SECRET_REGISTRY_PASSWORD
- git_auth: true
- name: notify
image: ruby:2.1
@@ -62,4 +58,4 @@ steps:
- refs/tags/*-demo
commands:
- sh ./notifymail.sh
- depends_on: [ docker-build-and-push ]
\ No newline at end of file
+ depends_on: [ docker-build-and-push ]
diff --git a/.gitignore b/.gitignore
index 7f5f2930..b67a9030 100644
--- a/.gitignore
+++ b/.gitignore
@@ -6,11 +6,7 @@ dist
*.swo
.env
-# Cache file on macOS
.DS_Store
-
-.phpunit.cache
-
# Cache files for Sublime Text
*.tmlanguage.cache
*.tmPreferences.cache
diff --git a/Documents/Diagramme/BDD/README_BDD.md b/Documents/Diagramme/BDD/README_BDD.md
new file mode 100644
index 00000000..5bc2be22
--- /dev/null
+++ b/Documents/Diagramme/BDD/README_BDD.md
@@ -0,0 +1,178 @@
+[retour au README.md](../../../README.md)
+[Retour aux Documents](../../README_DOCUMENTS.md)
+[Retour au diagramme de classes](../README_DIAGRAMMES.md)
+
+# BDD
+
+## Modèle Logique de Données (MLD)
+
+Le MLD représente la structure de données de l'application, décrivant les entités et les relations entre elles. Voici un aperçu des principales entités du MLD :
+
+### Athlète (Athlete)
+
+L'entité principale représentant un athlète avec ces informations propre à lui telles que l'identifiant, le nom, le prénom, l'email, etc. Les athlètes peuvent être coach avec le boolean idCoach et être liés par des amitiés, ou par un coaching via la table `Amitie`.
+
+### Amitié (Friendship)
+
+Une entité qui modélise les relations d'amitié entre les athlètes et de coaching entre les athlètes et les coachs. Elle stocke les identifiants des deux utilisateurs impliqués.
+
+### Notification (Notification)
+
+L'entité qui stocke les notifications destinées aux athlètes, avec des détails tels que le message, la date, le statut, et le degré d'urgence.
+
+### Envoi de Notification (SendNotification)
+
+Une entité de liaison entre les athlètes et les notifications, indiquant quel athlète ou coach a envoyé quelle notification. Cela peut-être utile lors d'une notification d'ajout d'amie par exemple.
+
+### Statistique (Statistic)
+
+Les statistiques relatives à un athlètes, y compris le poids, la fréquence cardiaque moyenne, la fréquence cardiaque maximale, etc.
+
+### Entraînement (Training)
+
+Détails sur les sessions d'entraînement planifiés par un coach pour ses athlètes, comprenant la date, la description, la localisation, etc. Les athlètes peuvent participer à des entraînements et donner leur feedback sur l'entrainement donné.
+
+### Participation (Participate)
+
+Une entité de liaison entre les athlètes et les entraînements, indiquant quels athlètes participent à quels entraînements.
+
+### Don (GiveParticipation)
+
+Une entité de liaison entre les coachs et les entraînements, indiquant quels coachs ont attribué quels entraînements.
+
+### Source de Données (DataSource)
+
+L'entité représentant la source des données des enregistrements sportif, telle que le type, le modèle, la précision, etc., utilisée par les athlètes pour enregistrer une ou des activités.
+
+### Activité (Activity)
+
+Les détails des activités des athlètes, y compris le type, la date, les heures de début et de fin, l'effort ressenti, etc.
+
+### Fréquence Cardiaque (HeartRate)
+
+Les données de fréquence cardiaque enregistrées pendant les activités, avec des informations telles que l'altitude, la température, etc.
+
+Ce MLD forme la base de données sous-jacente pour l'application, offrant une structure organisée pour stocker et récupérer les informations relatives aux athlètes et à leurs activités.
+
+```plantuml
+@startuml
+skinparam classAttributeIconSize 0
+package MLD{
+entity "Athlete" as athlete {
+ {static} idAthlete
+ username
+ nom
+ prenom
+ email
+ sexe
+ taille
+ poids
+ motDePasse
+ dateNaissance
+ isCoach
+}
+
+entity "Amitie" as friendship{
+{static}# idAthlete1
+{static}# idAthlete2
+début
+}
+
+entity "Notification" as notif {
+ {static} idNotif
+ message
+ date
+ statut
+ urgence
+ #athleteId
+}
+
+entity "Envoi" as sendNotif{
+{static}# idAthlete
+{static}# idNotif
+}
+
+entity "Statistique" as stats {
+ {static} idStatistique
+ poids
+ fcMoyenne
+ fcMax
+ caloriesBruleesMoy
+ date
+ #athleteId
+}
+
+entity "Entrainement" as training {
+ {static} idEntrainement
+ date
+ description
+ latitude
+ longitude
+ feedback
+ #athleteId
+}
+
+entity "Participe" as takepart {
+ {static} #athleteId
+ {static} #entrainementId
+}
+
+entity "Donne" as givepart {
+ {static} #coachId
+ {static} #entrainementId
+}
+
+
+entity "SourceDonnee" as source {
+ {static} idSource
+ type
+ modele
+ precision
+ #athleteId
+}
+
+entity "Activite" as activity {
+ {static} idActivité
+ type
+ date
+ heureDeDebut
+ heureDeFin
+ effortRessent
+ variabilite
+ variance
+ ecartType
+ moyenne
+ maximum
+ minimum
+ temperatureMoyenne
+ #athleteId
+ #sourceId
+}
+entity "FréquenceCardiaque" as fc {
+ {static} idFc
+ altitude
+ temps : time
+ température
+ bpm
+ longitude
+ latitude
+ #activitéId
+}
+
+}
+activity --> athlete
+activity --> source
+activity <-- fc
+athlete <-- source
+stats --> athlete
+takepart --> athlete
+takepart --> training
+givepart --> athlete
+givepart --> training
+sendNotif --> athlete
+sendNotif --> notif
+friendship --> athlete
+notif --> athlete
+athlete <-- friendship
+@enduml
+```
\ No newline at end of file
diff --git a/Documents/Diagramme/DiagrammeDeClasses/README_DIAGRAMME.md b/Documents/Diagramme/DiagrammeDeClasses/README_DIAGRAMME.md
index 5ee68278..5c6b03f3 100644
--- a/Documents/Diagramme/DiagrammeDeClasses/README_DIAGRAMME.md
+++ b/Documents/Diagramme/DiagrammeDeClasses/README_DIAGRAMME.md
@@ -28,11 +28,11 @@ Bienvenue dans l'écosystème dynamique de notre plateforme de gestion d'activit
- Les Utilisateurs ont un rôle spécifique (Athlete, Coach) qui détermine leurs fonctionnalités.
-- Un Athlète peut enregistrer plusieurs Activités, Statistiques, et interagir avec différentes Sources de Données.
+- Un Athlète peut enregistrer plusieurs Activités, possède des Statistiques, et une Sources de Données qui est la plus utilisé.
- Les Entraînements sont liés aux Utilisateurs, permettant une planification efficace.
-- Les Notifications informent les Utilisateurs des événements importants.
+- Les Notifications informent les Utilisateurs des événements importants tels qu'une demande d'amis ou une notification d'avertissement de ban.
Explorez ce diagramme pour comprendre comment notre plateforme offre une expérience complète, de la gestion des utilisateurs à l'enregistrement des activités sportives et au suivi des performances.
diff --git a/Documents/Diagramme/DiagrammeDeClasses/README_issue016.md b/Documents/Diagramme/DiagrammeDeClasses/README_issue016.md
index 035cde6d..9b304ba5 100644
--- a/Documents/Diagramme/DiagrammeDeClasses/README_issue016.md
+++ b/Documents/Diagramme/DiagrammeDeClasses/README_issue016.md
@@ -4,15 +4,15 @@
# Introduction au Diagramme de Classes : Statistiques pour Coach
-Bienvenue dans l'univers captivant de notre système de gestion d'activités sportives avec une mise au point spéciale sur les statistiques destinées aux coaches. Ce diagramme de classes offre une vue approfondie de la manière dont les utilisateurs, en particulier les athlètes et les coaches, interagissent avec les données de performance.
+Bienvenue dans l'univers captivant de notre système de gestion d'activités sportives avec une mise au point spéciale sur les statistiques destinées aux athlètes. Ce diagramme de classes offre une vue approfondie de la manière dont les utilisateurs, en particulier les athlètes, interagissent avec leurs statistiques.
**Entités Principales :**
- **Utilisateur (User) :** Représente les individus inscrits sur notre plateforme, avec des détails personnels et un rôle spécifique dans l'écosystème sportif.
-- **Athlète (Athlete) :** Un type spécialisé d'utilisateur qui peut enregistrer des statistiques liées à ses activités sportives.
+- **Athlète (Athlete) :** Un type spécialisé d'utilisateur qui possède des statistiques liées à ses activités sportives.
-- **Coach (Coach) :** Un rôle qui s'étend à partir de la classe abstraite Role, dédié à la gestion des athlètes et de leurs statistiques.
+- **Coach (Coach) :** Un rôle qui s'étend à partir de la classe abstraite Role, dédié à la gestion des athlètes et de la vision de leurs statistiques.
- **Statistique (Statistique) :** Contient des informations détaillées sur les performances sportives d'un athlète, telles que la distance totale, le poids, le temps total, la fréquence cardiaque moyenne, minimale et maximale, ainsi que les calories brûlées.
@@ -22,11 +22,11 @@ Bienvenue dans l'univers captivant de notre système de gestion d'activités spo
- Un Coach peut gérer une liste d'athlètes et avoir accès à leurs statistiques.
-- Un Athlète peut enregistrer plusieurs statistiques liées à ses activités.
+- Un Athlète peut enregistrer plusieurs activités afin d'avoir des statistiques liées à celle-ci.
**Objectif Principal :**
-- Permettre aux coaches d'accéder et de surveiller les statistiques détaillées de leurs athlètes, offrant ainsi un aperçu complet de leurs performances sportives.
+- Permettre aux coachs d'accéder et de surveiller les statistiques détaillées de leurs athlètes, offrant ainsi un aperçu complet de leurs performances sportives.
Explorez ce diagramme pour découvrir comment notre application crée une synergie entre les utilisateurs, les rôles, et les statistiques, contribuant ainsi à une expérience enrichissante dans le suivi des activités sportives.
diff --git a/Documents/Diagramme/DiagrammeDeClasses/README_issue023.md b/Documents/Diagramme/DiagrammeDeClasses/README_issue023.md
index 9c3dc5d8..5154882d 100644
--- a/Documents/Diagramme/DiagrammeDeClasses/README_issue023.md
+++ b/Documents/Diagramme/DiagrammeDeClasses/README_issue023.md
@@ -4,7 +4,7 @@
# Introduction au Modèle de Données de l'Application
-L'architecture de données de notre application de suivi d'activités sportives repose sur un modèle robuste, avec des entités clés pour représenter les activités, les athlètes et les coachs. Découvrez les composants principaux de notre modèle de données :
+L'architecture de données de notre application de suivi d'activités sportives repose sur un modèle robuste, avec des entités clés pour représenter les activités, les athlètes et les coachs et la récupération de ces données au sein de notre application. Découvrez les composants principaux de notre modèle de données :
## Activité
L'entité Activité représente une session d'activité sportive avec des détails variés tels que le type d'activité, la date, la durée, l'effort ressenti, etc. Le `ActiviteEntity` encapsule ces données, tandis que le `ActiviteGateway` gère la communication avec la base de données pour les activités.
diff --git a/Documents/Diagramme/DiagrammeDeClasses/README_issue028.md b/Documents/Diagramme/DiagrammeDeClasses/README_issue028.md
index b029361f..e4c14c91 100644
--- a/Documents/Diagramme/DiagrammeDeClasses/README_issue028.md
+++ b/Documents/Diagramme/DiagrammeDeClasses/README_issue028.md
@@ -4,12 +4,12 @@
# Diagramme de classes pour l'importation de fichiers .fit
-Bienvenue dans le monde de la gestion d'activités sportives avec notre application innovante ! Cette user story se concentre sur une fonctionnalité essentielle qui améliorera l'expérience des utilisateurs : l'importation de fichiers .fit. Nous avons conçu un diagramme de classes pour vous offrir une vision claire et structurée de la manière dont cette fonctionnalité est implémentée au sein de notre application.
+Bienvenue dans le monde de la gestion d'activités sportives avec notre application innovante ! Ce diagramme de classe se concentre sur une fonctionnalité essentielle qui améliorera l'expérience des utilisateurs : l'importation de fichiers .fit. Nous avons conçu un diagramme de classes pour vous offrir une vision claire et structurée de la manière dont cette fonctionnalité est implémentée au sein de notre application.
**Acteurs Principaux :**
-- Utilisateur (User) : Représente un individu inscrit sur notre plateforme, avec la capacité d'importer des fichiers .fit.
-- Athlète (Athlete) : Un type spécialisé d'utilisateur, bénéficiant de fonctionnalités supplémentaires liées à la gestion d'activités sportives.
+- Utilisateur (User) : Représente un individu inscrit sur notre plateforme.
+- Athlète (Athlete) : Un type spécialisé d'utilisateur, bénéficiant de fonctionnalités supplémentaires liées à la gestion d'activités sportives et avec la capacité d'importer des fichiers .fit.
**Entités Clés :**
@@ -18,13 +18,13 @@ Bienvenue dans le monde de la gestion d'activités sportives avec notre applicat
**Fonctionnalité Clé :**
-- Importation de fichiers .fit : Permet aux utilisateurs de charger des données provenant de fichiers .fit, générés par des dispositifs de suivi d'activité. Ces fichiers contiennent des informations précieuses telles que la fréquence cardiaque, la distance parcourue et d'autres métriques essentielles.
+- Importation de fichiers .fit : Permet aux utilisateurs de charger des données provenant de fichiers .fit via la bibliothèque `php-fit-file-analysis`, générés par des dispositifs de suivi d'activité. Ces fichiers contiennent des informations précieuses telles que la fréquence cardiaque, la distance parcourue et d'autres données de santé importante pour nos analyses.
**Architecture :**
- AuthService (Service d'Authentification) : Gère l'authentification des utilisateurs, garantissant un accès sécurisé à la fonction d'importation.
- UserManager (Gestionnaire d'Utilisateurs) : Gère les opérations liées aux utilisateurs, y compris l'importation de fichiers .fit.
-ActivityManager (Gestionnaire d'Activités) : Responsable du stockage et de la gestion des activités importées.
+- ActivityManager (Gestionnaire d'Activités) : Responsable du stockage et de la gestion des activités importées.
**Objectif :**
diff --git a/Documents/Diagramme/README_DIAGRAMMES.md b/Documents/Diagramme/README_DIAGRAMMES.md
index ae7c906e..c2853bce 100644
--- a/Documents/Diagramme/README_DIAGRAMMES.md
+++ b/Documents/Diagramme/README_DIAGRAMMES.md
@@ -20,4 +20,7 @@
## Diagrammes de cas d'utilisation
- [Cas d'utilisation pour la gestion du compte et des amitiés](CasUtilisations/README_gestionCompteAmitie.md)
- [Cas d'utilisation pour la gestion des activités et données](CasUtilisations/README_gestionActivites.md)
-- [Cas d'utilisation pour la suivi d'une équipe sportive](CasUtilisations/README_coachSuiviSportif.md)
\ No newline at end of file
+- [Cas d'utilisation pour la suivi d'une équipe sportive](CasUtilisations/README_coachSuiviSportif.md)
+
+## Base de Données
+- [MLD](BDD/README_BDD.md)
\ No newline at end of file
diff --git a/Sources/config/.htaccess b/Sources/config/.htaccess
index e69de29b..0f5b0a29 100755
--- a/Sources/config/.htaccess
+++ b/Sources/config/.htaccess
@@ -0,0 +1,2 @@
+AddType text/css .css
+AddType application/javascript .js
\ No newline at end of file
diff --git a/Sources/config/Dockerfile b/Sources/config/Dockerfile
index ff714447..885c084c 100755
--- a/Sources/config/Dockerfile
+++ b/Sources/config/Dockerfile
@@ -1,17 +1,31 @@
-FROM php:8.2-fpm
+FROM php:8.2-apache as base
# Installation de dépendances nécessaires pour Composer
RUN apt-get update && apt-get install -y \
git \
unzip
# Installation de Composer
-# TODO : should use a image with composer install
+
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
RUN docker-php-ext-install pdo pdo_mysql
-COPY . /var/www/
+# Copy configs
+COPY ./config/virtual-host.conf /etc/apache2/sites-available/000-default.conf
+COPY ./config/httpd.conf /etc/apache2/httpd.conf
+
+# Setup App
+RUN mkdir -p /app/public && chown -R www-data:www-data /app
+
+WORKDIR /app
+
+# add sources code
+COPY . /app
+
+ENV VOLUME_PATH /app/public
+
+RUN composer install
-WORKDIR /var/www/
+EXPOSE 80
-RUN composer install
\ No newline at end of file
+CMD ["apache2-foreground"]
\ No newline at end of file
diff --git a/Sources/config/Dockerfile.local b/Sources/config/Dockerfile.local
new file mode 100644
index 00000000..ff714447
--- /dev/null
+++ b/Sources/config/Dockerfile.local
@@ -0,0 +1,17 @@
+FROM php:8.2-fpm
+# Installation de dépendances nécessaires pour Composer
+RUN apt-get update && apt-get install -y \
+ git \
+ unzip
+
+# Installation de Composer
+# TODO : should use a image with composer install
+RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
+
+RUN docker-php-ext-install pdo pdo_mysql
+
+COPY . /var/www/
+
+WORKDIR /var/www/
+
+RUN composer install
\ No newline at end of file
diff --git a/Sources/config/httpd.conf b/Sources/config/httpd.conf
new file mode 100644
index 00000000..6fcc6eb0
--- /dev/null
+++ b/Sources/config/httpd.conf
@@ -0,0 +1 @@
+SetEnv ASSET_PREFIX containers/HeartDev-web/
\ No newline at end of file
diff --git a/Sources/config/virtual-host.conf b/Sources/config/virtual-host.conf
new file mode 100644
index 00000000..095b7644
--- /dev/null
+++ b/Sources/config/virtual-host.conf
@@ -0,0 +1,39 @@
+
+ ServerName default
+
+
+ Options FollowSymLinks
+ AllowOverride None
+ Require all denied
+
+
+
+ AllowOverride All
+ Require all granted
+
+
+ DocumentRoot ${VOLUME_PATH}
+
+ AccessFileName .htaccess
+
+ Require all denied
+
+
+ LogFormat "%v:%p %h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" vhost_combined
+ LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
+ LogFormat "%h %l %u %t \"%r\" %>s %O" common
+ LogFormat "%{Referer}i -> %U" referer
+ LogFormat "%{User-agent}i" agent
+
+ CustomLog /proc/self/fd/1 combined
+
+
+ SetHandler application/x-httpd-php
+
+
+ # Multiple DirectoryIndex directives within the same context will add
+ # to the list of resources to look for rather than replace
+ # https://httpd.apache.org/docs/current/mod/mod_dir.html#directoryindex
+ DirectoryIndex disabled
+ DirectoryIndex index.php index.html
+
\ No newline at end of file
diff --git a/Sources/docker-compose-local.yml b/Sources/docker-compose-local.yml
index 918f65d6..b39e0b46 100755
--- a/Sources/docker-compose-local.yml
+++ b/Sources/docker-compose-local.yml
@@ -15,7 +15,7 @@ services:
web:
build:
context: .
- dockerfile: ./config/Dockerfile
+ dockerfile: ./config/Dockerfile.local
ports:
- 9000:9000
volumes:
@@ -24,7 +24,7 @@ services:
- mysql
environment:
DB_HOST: mysql
- DB_PORT: port
+ DB_PORT: port
DB_DATABASE: test
DB_USER: user
DB_PASSWORD: pass
@@ -41,4 +41,4 @@ services:
ports:
- "3307:3306"
volumes:
- - ./mysql-data:/var/lib/mysql
\ No newline at end of file
+ - ./mysql-data:/var/lib/mysql
\ No newline at end of file
diff --git a/Sources/src/app/controller/Controller.php b/Sources/src/app/controller/Controller.php
index cebeb34f..e69de29b 100644
--- a/Sources/src/app/controller/Controller.php
+++ b/Sources/src/app/controller/Controller.php
@@ -1,716 +0,0 @@
-preference = new Preferences();
-// }
-
- // #[Route(path: '/', name: 'index', methods: ['GET'])]
- // public function index(): Response
- // {
- // return $this->render('./page/index.html',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/home', name: 'home', methods: ['GET'])]
- // public function home(): Response
- // {
- // return $this->render('./page/home.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/analyses', name: 'analyses', methods: ['GET'])]
- // public function analyses(): Response
- // {
- // return $this->render('./page/analyze.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/activity', name: 'activity', methods: ['GET'])]
- // public function activity(): Response
- // {
- // return $this->render('./page/activity.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/exercice', name: 'exercice', methods: ['GET'])] // 8
- // public function exercice(): Response
- // {
- // return $this->render('./page/exercice.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/exercices', name: 'exercices', methods: ['POST'])] // 8
- // public function exercices(String $type, String $intensite, String $date, IRequest $req): Response
- // {
- // $exercicesArray = [
- // [
- // 'date' => $date,
- // 'type' => $type,
- // 'intensite' => $intensite,
- // 'status' => 'A venur',
- // ]
- // ];
- // return $this->render('./page/exercice.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => $exercicesArray,
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/search-user', name: 'search-user', methods: ['GET'])]
- // public function searchUser(string $username, IRequest $req): Response
- // {
- // $taberror = [];
- // // FILTER
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // // if(!Validation::val_string($name)){
- // try {
- // //code...
- // // $model->userMgr->addFriend($name);
- // return $this->render('./page/addfriend.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // 'responce' => "Notification d'ajout envoyée à $username"
- // ]);
- // } catch (\Throwable $th) {
- // //throw $th;
- // // return $this->render("addfriend.html.twig", ['tabError' => $taberror ]);
- // }
- // // }
-
- // }
-
- // #[Route(path: '/search-member', name: 'search-member', methods: ['GET'])]
- // public function searchMember(string $username, IRequest $req): Response
- // {
- // $taberror = [];
- // // FILTER
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // // if(!Validation::val_string($name)){
- // try {
- // //code...
- // // $model->userMgr->addFriend($name);
- // return $this->render('./page/addmember.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // 'responce' => "Notification d'ajout envoyée à $username"
- // ]);
- // } catch (\Throwable $th) {
- // //throw $th;
- // // return $this->render("addfriend.html.twig", ['tabError' => $taberror ]);
- // }
- // // }
-
- // }
-
- // #[Route(path: '/add-member', name: 'add-member', methods: ['POST'])]
- // public function addmember(string $username, IRequest $req): Response
- // {
- // $taberror = [];
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // // if(!Validation::val_string($name)){
- // try {
- // //code...
- // // $model->userMgr->addFriend($name);
- // return $this->render('./page/addmember.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // 'responce' => "Notification d'ajout envoyée à $username"
- // ]);
- // } catch (\Throwable $th) {
- // //throw $th;
- // // return $this->render("addfriend.html.twig", ['tabError' => $taberror ]);
- // }
- // // }
-
- // }
-
- // #[Route(path: '/member', name: 'member', methods: ['GET'])]
- // public function member(): Response
- // {
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // return $this->render('./page/addmember.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // ]);
- // }
-
- // #[Route(path: '/add-friend', name: 'add-friend', methods: ['POST'])]
- // public function addFriend(string $username, IRequest $req): Response
- // {
- // $taberror = [];
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // // if(!Validation::val_string($name)){
- // try {
- // //code...
- // // $model->userMgr->addFriend($name);
- // return $this->render('./page/addfriend.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // 'responce' => "Notification d'ajout envoyée à $username"
- // ]);
- // } catch (\Throwable $th) {
- // //throw $th;
- // // return $this->render("addfriend.html.twig", ['tabError' => $taberror ]);
- // }
- // // }
-
- // }
-
- // #[Route(path: '/friend', name: 'friend', methods: ['GET'])]
- // public function friend(): Response
- // {
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // return $this->render('./page/addfriend.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => $utiliArray,
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // ]);
- // }
-
- // #[Route(path: '/friendlist', name: 'friendlist', methods: ['POST'])]
- // public function friendlist(string $username, IRequest $req): Response
- // {
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'john_doe',
- // 'username' => 'johndoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'alice_smith',
- // 'username' => 'alicesmith',
- // ],
- // ];
- // /* TODO */
-
- // // -> Enlever ou bloquer un utilisateur en fonction de son username
-
- // return $this->render('./page/friend.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => $utiliArray,
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // ]);
- // }
-
- // #[Route(path: '/friendlist', name: 'friendlist2', methods: ['GET'])]
- // public function friendlist2(): Response
- // {
- // $utiliArray = [
- // [
- // 'nom' => 'John',
- // 'prenom' => 'Doe',
- // 'img' => 'test',
- // 'status' => 'johndoe',
- // 'username' => 'jdoe',
- // ],
- // [
- // 'nom' => 'Alice',
- // 'prenom' => 'Smith',
- // 'img' => 'test2',
- // 'status' => 'alicesmith',
- // 'username' => 'asmith',
- // ],
- // ];
- // return $this->render('./page/friend.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => $utiliArray,
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => [],
- // ]);
- // }
-
- // #[Route(path: '/coaching', name: 'coaching', methods: ['GET'])]
- // public function coaching(): Response
- // {
- // return $this->render('./page/coaching.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/mail', name: 'mail', methods: ['GET'])]
- // public function mail(): Response
- // {
- // return $this->render('./page/mail.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/import', name: 'import', methods: ['GET'])]
- // public function import(): Response
- // {
- // return $this->render('./page/import.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/settings', name: 'settings', methods: ['GET'])]
- // public function settings(IRequest $req): Response
- // {
- // return $this->render('./page/settings.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/profile', name: 'profile', methods: ['GET'])]
- // public function profile(): Response
- // {
- // return $this->render('./page/profile.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/preferences', name: 'preferences', methods: ['POST'])]
- // public function preferences(string $theme, IRequest $req): Response
- // {
- // /*TODO*/
-
- // // VALIDER LES DONNEES
- // $this->preference->majCookie($theme);
-
- // return $this->render('./page/settings.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/psettings', name: 'psettings', methods: ['POST'])]
- // public function psettings(string $nom,string $prenom,string $dateNaissance,string $mail,string $tel, IRequest $req): Response
- // {
-
-
- // return $this->render('./page/settings.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => $prenom,
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/mdp', name: 'mdp', methods: ['POST'])]
- // public function mdp(string $ancienMotDePasse,string $nouveauMotDePasse,string $confirmerMotDePasse, IRequest $req): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/settings.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/login', name: 'login', methods: ['POST'])]
- // public function login(string $username,string $mdp, IRequest $req): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/home.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/log', name: 'log', methods: ['GET'])]
- // public function login2(): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/login.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/register', name: 'register', methods: ['POST'])]
- // public function register(string $username,string $mdp,string $confirmMdp,string $nom,string $prenom,string $dateNaissance,string $sexe,string $taille,string $poids, IRequest $req): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/home.html.twig',[
- // 'css' => $this->preference->getCookie()
- // ]);
- // }
-
- // #[Route(path: '/regist', name: 'regist', methods: ['GET'])]
- // public function register2(): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/register.html.twig',[
- // 'css' => $this->preference->getCookie()
- // ]);
- // }
-
- // #[Route(path: '/pass', name: 'pass', methods: ['GET'])]
- // public function pass(): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/password.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
- // #[Route(path: '/password', name: 'password', methods: ['POST'])]
- // public function password(string $email, IRequest $req): Response
- // {
-
- // // CONFIRMER LES DONNESS !!!!! IMPORTANT
-
- // return $this->render('./page/login.html.twig',[
- // 'css' => $this->preference->getCookie(),
- // 'pp' => "test2",
- // 'user' => "Doe",
- // 'role' => "Athlète",
- // 'friendship' => [],
- // 'analyzes' => [],
- // 'mails' => [],
- // 'users' => [],
- // 'infoUser' => [],
- // 'exos' => [],
- // 'member' => []
- // ]);
- // }
-
-//}
-
-
-
diff --git a/Sources/src/app/views/Templates/page/password.html.twig b/Sources/src/app/views/Templates/page/password.html.twig
index 12a4912f..40a09b15 100644
--- a/Sources/src/app/views/Templates/page/password.html.twig
+++ b/Sources/src/app/views/Templates/page/password.html.twig
@@ -12,7 +12,7 @@
Entrez votre adresse eMail pour recevoir un lien pour changer de mot de passe
-