Merge remote-tracking branch 'origin/merged'
continuous-integration/drone/push Build is failing Details

master
Antoine PEREDERII 1 year ago
commit d57f95ca62

@ -0,0 +1,113 @@
@startuml
skinparam classAttributeIconSize 0
package MLD{
entity "Athlète" as athlete {
{static} idAthlete
nom
prénom
email
sexe
taille
poids
motDePasse
dateNaissance
}
entity "Amitié" as friendship{
{static}# idAthlete1
{static}# idAthlete2
début
}
entity "Notification" as notif {
{static} idNotif
message
date
statut
urgence
#athleteId
}
entity "Coach" as coach {
{static} idCoach
// attributs spécifiques au coach
#athleteId
}
entity "Statistique" as stats {
{static} idStatistique
poids
fcMoyenne
fcMax
caloriesBrûléesMoy
date
#athleteId
}
entity "Entraînement" as training {
{static} idEntrainement
date
description
// Exercices
latitude
longitude
feedback
#coachId
}
entity "Participe" as takepart {
{static} #athleteId
{static} #entrainementId
}
entity "SourceDonnée" as source {
{static} idSource
type
modèle
précision
#athleteId
}
entity "Activité" as activity {
{static} idActivité
type
date
heureDeDébut
heureDeFin
effortRessent
variabilité
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
coach --> athlete
athlete <-- source
stats --> athlete
takepart --> athlete
takepart --> training
friendship --> athlete
notif --> athlete
coach <-- training
athlete <-- friendship
@enduml

@ -0,0 +1,56 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Cas d'utilisation : Suivi d'une Équipe Sportive
Bienvenue dans le monde dynamique du suivi d'équipe sportive, où notre application offre une plateforme complète pour les entraîneurs soucieux d'optimiser les performances de leurs athlètes. Ce diagramme de cas d'utilisation vous plonge dans les fonctionnalités clés qui facilitent la gestion d'une équipe sportive avec efficacité.
**Acteurs Principaux :**
- **Coach :** Le protagoniste central, utilisant l'application pour gérer et superviser son équipe.
**Fonctionnalités Clés :**
- **Ajouter un Athlète :** Permet au coach d'ajouter de nouveaux membres à son équipe, avec des étapes incluant la validation par l'athlète et l'authentification.
- **Supprimer un Athlète :** Offre la possibilité de retirer des athlètes de l'équipe, avec une authentification préalable pour garantir la légitimité de l'action.
- **Afficher ses Athlètes :** Permet au coach de visualiser la liste complète de ses athlètes, nécessitant une authentification pour accéder à ces informations sensibles.
- **Afficher les Activités de Tous les Athlètes :** Donne au coach un aperçu global des activités de toute l'équipe, nécessitant une authentification pour garantir la confidentialité des données.
**Flux d'Interaction :**
- Le processus d'ajout d'un athlète inclut des étapes telles que la validation par l'athlète et l'authentification, garantissant une intégration fluide.
- Les actions de suppression, affichage des athlètes et affichage des activités nécessitent une authentification préalable pour assurer la sécurité des données.
- Des extensions telles que la visualisation des activités d'un athlète et l'analyse des performances offrent des fonctionnalités avancées pour un suivi détaillé.
Explorez ce diagramme pour comprendre l'étendue des fonctionnalités que notre application offre aux entraîneurs, les aidant à gérer leurs équipes de manière efficace et à maximiser le potentiel de chaque athlète.
```plantuml
left to right direction
:Coach: as a
a --> (Ajouter un athlète)
a --> (Supprimer un athlète)
a --> (Afficher ses athlètes )
a --> (Afficher les activités de tous les athlètes)
(Ajouter un athlète).>(Validation par l'athlète) : <<include>>
(Ajouter un athlète)..>(S'authentifier) : <<include>>
(Supprimer un athlète)..>(S'authentifier) : <<include>>
(Afficher ses athlètes )..>(S'authentifier) : <<include>>
(Afficher les activités de tous les athlètes)..>(S'authentifier) : <<include>>
(S'authentifier)..>(S'inscrire) : <<extends>>
(S'inscrire).>(Inscription Coach) : <<include>>
(S'authentifier)..>(Se connecter) : <<include>>
(Afficher ses athlètes )..>(Voir les activités d'un athlète) : <<extends>>
(Afficher ses athlètes )..>(Voir les stats d'un athlète) : <<extends>>
(Afficher les activités de tous les athlètes)..>(Sélectionner une activité) : <<include>>
(Sélectionner une activité)..>(Voir l'analyse) : <<extends>>
(Sélectionner une activité)..>(Exporter l'analyse) : <<extends>>
(Voir les activités d'un athlète)..>(Voir l'analyse) : <<extends>>
(Voir les activités d'un athlète)..>(Exporter l'analyse) : <<extends>>
```

@ -0,0 +1,57 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Cas d'utilisation : Gestion d'Activités pour un Athlète
Bienvenue dans l'univers dédié à la gestion d'activités sportives personnalisées pour les athlètes ! Ce diagramme de cas d'utilisation explore les différentes fonctionnalités offertes aux utilisateurs, mettant en avant la flexibilité et la richesse d'interactions pour une expérience utilisateur optimale.
**Acteurs Principaux :**
- **Athlète :** Le protagoniste central, utilisant l'application pour importer, gérer et analyser ses activités sportives.
**Fonctionnalités Clés :**
- **Importer des Données :** Permet à l'athlète d'importer des données d'activités depuis différentes sources, avec la possibilité de spécifier la source pour une intégration transparente.
- **Exporter Mes Données :** Offre la possibilité d'exporter l'ensemble des activités, avec des extensions pour exporter une activité spécifique, le tout soumis à une authentification préalable.
- **Ajouter une Activité :** Permet à l'athlète d'ajouter de nouvelles activités, avec des étapes inclusives telles que la saisie du titre, du type d'activité, de la source, du matériel utilisé et de la visibilité, chacune accessible via l'authentification.
- **Voir une Activité :** Permet à l'athlète de visualiser en détail une activité particulière, avec la possibilité d'exporter une analyse et de gérer la visibilité, soumis à une authentification.
- **Supprimer une Activité :** Offre la possibilité de retirer une activité, requérant une authentification pour garantir la sécurité des données.
**Flux d'Interaction :**
- Les actions telles que l'importation, l'exportation, l'ajout et la visualisation d'activités impliquent une authentification préalable pour garantir la confidentialité des données personnelles.
- Des inclusions précises, telles que la saisie du titre, du type d'activité, de la source, du matériel utilisé et de la visibilité, sont incorporées dans le processus d'ajout d'une activité, offrant une expérience utilisateur détaillée et conviviale.
Explorez ce diagramme pour comprendre la manière dont notre application place la gestion d'activités entre les mains des athlètes, les encourageant à suivre, analyser et optimiser leurs performances sportives de manière personnalisée et efficace.
```plantuml
left to right direction
:Athlete: as a
a --> (Importer des données)
(Importer des données) .> (Saisir la source) : <<include>>
a --> (Exporter mes données)
(Exporter mes données) .>(Exporter toutes les activités): <<extends>>
(Exporter mes données) ..>(Exporter une activité): <<include>>
a --> (Ajouter une activité)
(Ajouter une activité) ..>(Saisir un titre et une description): <<include>>
(Ajouter une activité) ..>(Saisir le type d'activité): <<include>>
(Ajouter une activité) .>(Saisir la source): <<include>>
(Saisir la source) ..>(Saisir le matériel utilisé): <<include>>
(Ajouter une activité) ..>(Saisir la visibilité): <<include>>
a --> (Voir une activité)
(Voir une activité) ..>(Exporter l'analyse): <<extends>>
(Voir une activité) ..>(Saisir la visibilité): <<extends>>
a --> (Supprimer une activité)
(Importer des données) ...>(S'authentifier): <<include>>
(Exporter mes données) ...>(S'authentifier): <<include>>
(Ajouter une activité) ...>(S'authentifier): <<include>>
(Voir une activité) ...>(S'authentifier): <<include>>
```

@ -0,0 +1,55 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Cas d'utilisation : Gestion des Relations Sociales pour un Athlète
Bienvenue dans la sphère sociale de notre application dédiée aux athlètes ! Ce diagramme de cas d'utilisation explore les fonctionnalités sociales clés offertes aux utilisateurs, mettant en lumière la connectivité et l'interaction sociale au sein de notre communauté sportive.
**Acteurs Principaux :**
- **Athlète :** Le protagoniste central, utilisant l'application pour gérer ses relations sociales et explorer les profils de ses pairs.
**Fonctionnalités Clés :**
- **Ajouter un Ami :** Permet à l'athlète d'ajouter de nouveaux amis, nécessitant la saisie du nom de l'ami et soumis à une authentification préalable.
- **Supprimer un Ami :** Offre la possibilité de retirer un ami, exigeant une authentification pour garantir la sécurité des données.
- **Voir Mes Amis :** Permet à l'athlète de visualiser la liste de ses amis, avec la possibilité d'accéder à des fonctionnalités supplémentaires comme la visualisation des profils.
- **Modifier Mes Informations :** Offre à l'athlète la possibilité de mettre à jour ses informations personnelles et de connexion, avec des extensions pour des détails plus spécifiques.
**Flux d'Interaction :**
- Le processus d'ajout d'un ami inclut la saisie du nom de l'ami, tandis que la suppression d'un ami et la visualisation de la liste des amis sont soumises à une authentification préalable pour protéger la confidentialité.
- Les modifications d'informations englobent deux extensions : la mise à jour des informations personnelles et la mise à jour des informations de connexion, offrant une personnalisation approfondie du profil athlétique.
- La visualisation du profil d'un ami s'étend à des fonctionnalités telles que la consultation des activités et des statistiques de l'ami, ajoutant une dimension sociale à l'expérience de suivi sportif.
Explorez ce diagramme pour découvrir comment notre application encourage l'interaction sociale entre les athlètes, favorisant une communauté engagée et collaborative au sein de laquelle les utilisateurs peuvent partager, interagir et se soutenir mutuellement dans leur parcours sportif.
```plantuml
left to right direction
:Athlete: as a
a --> (Ajouter un ami)
a --> (Supprimer un ami)
a --> (Voir mes amis)
a --> (Modifier mes informations)
(Ajouter un ami)->(Saisir le nom de l'ami)
(Supprimer un ami)..>(S'authentifier) : <<include>>
(Ajouter un ami)..>(S'authentifier) : <<include>>
(Voir mes amis)..>(S'authentifier) : <<include>>
(Voir mes amis)..>(Lister les amis) : <<include>>
(Modifier mes informations)..>(Informations personnelles) : <<extends>>
(Modifier mes informations)..>(Informations de connexion) : <<extends>>
(Lister les amis)..>(Voir son profil) : <<include>>
(Voir son profil)..>(Voir ses activités) : <<extends>>
(Voir son profil)..>(Voir ses statistiques) : <<extends>>
(S'authentifier)..>(S'inscrire) : <<extends>>
(S'authentifier)..>(Se connecter) : <<include>>
(S'inscrire)..>(Inscription Athlète) : <<include>>
```

@ -0,0 +1,33 @@
@startuml
class phpFITFileAnalysis
{
data_mesgs : array
dev_field_descriptions : array
options : null
file_contents : string
file_pointer : integer
defn_mesgs : array
defn_mesgs_all : array
file_header : array
php_trader_ext_loaded : boolean
types : null
garmin_timestamps : boolean
readDataRecords : function
fixData($options) : function
interpolateMissingData(&$missing_keys, &$array)
}
ProjectModel --|> Project
AttributeModel --|> Element
UMLModel --|> Element
UMLClassDiagram --|> Element
UMLClassView --|> View
UMLNameCompartmentView --|> View
UMLAttributeCompartmentView --|> View
UMLOperationCompartmentView --|> View
UMLReceptionCompartmentView --|> View
UMLTemplateParameterCompartmentView --|> View
LabelView --|> View
@enduml

@ -0,0 +1,91 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Diagramme de la Couche d'Accès aux Données
Bienvenue dans le cœur de notre système, où les données prennent vie à travers des ensembles de données (repositories) structurés et performants. Ce diagramme met en lumière la conception de la couche d'accès aux données de notre application, offrant un aperçu clair de la gestion des entités clées telles que les utilisateurs, les notifications, les demandes de relations et les entraînements.
**Principes Fondamentaux :**
- **IGenericRepository :** Une abstraction générique établissant les contrats essentiels pour l'accès aux données. Définissant des opérations standardisées telles que la récupération, la mise à jour, l'ajout et la suppression d'entités.
- **Interfaces Spécialisées :** Des interfaces telles que `IUserRepository`, `INotificationRepository`, `IRelationshipRequestRepository` et `ITrainingRepository` étendent les fonctionnalités génériques pour répondre aux besoins spécifiques de chaque entité.
**Repositories Concrets :**
- **UserRepository :** Gère les données relatives aux utilisateurs, permettant des opérations de récupération, de mise à jour et de suppression avec une efficacité optimale.
- **NotificationRepository :** Responsable de la gestion des notifications, assurant un accès structuré et une manipulation sécurisée de ces informations cruciales.
- **RelationshipRequestRepository :** Facilite la gestion des demandes de relations entre utilisateurs, garantissant une interaction claire et ordonnée.
- **TrainingRepository :** Permet l'accès et la manipulation des données liées aux entraînements, facilitant le suivi des performances athlétiques.
Explorez ce diagramme pour découvrir la robustesse de notre architecture de gestion des données, mettant en œuvre des pratiques de développement solides pour assurer une expérience utilisateur fiable et évolutive.
```plantuml
@startuml couche_acces_aux_donnees
abstract class IGenericRepository {
+ getItemById(int id) : object
+ getNbItems() : int
+ getItems(int index, int count, string orderingPropertyName, bool descending) : array
+ getItemsByName(string substring, int index, int count, string orderingPropertyName, bool descending) : array
+ getItemByName(string substring, int index, int count, string orderingPropertyName, bool descending) : object
+ updateItem(oldItem, newItem) : void
+ addItem(item) : void
+ deleteItem(item) : bool
}
abstract class IUserRepository extends IGenericRepository {
}
interface INotificationRepository extends IGenericRepository {
}
interface IRelationshipRequestRepository extends IGenericRepository {
}
interface ITrainingRepository extends IGenericRepository {
}
class NotificationRepository implements INotificationRepository {
- notifications : array
+ getItemById(int id) : object
+ getNbItems() : int
+ getItems(int index, int count, string orderingPropertyName, bool descending) : array
+ getItemsByName(string substring, int index, int count, string orderingPropertyName, bool descending) : array
+ getItemByName(string substring, int index, int count, string orderingPropertyName, bool descending) : object
+ updateItem(oldItem, newItem) : void
+ addItem(item) : void
+ deleteItem(item) : bool
}
class RelationshipRequestRepository implements IRelationshipRequestRepository {
- requests : array
+ getItemById(int id) : object
+ getNbItems() : int
+ getItems(int index, int count, string orderingPropertyName, bool descending) : array
+ getItemsByName(string substring, int index, int count, string orderingPropertyName, bool descending) : array
+ getItemByName(string substring, int index, int count, string orderingPropertyName, bool descending) : object
+ updateItem(oldItem, newItem) : void
+ addItem(item) : void
+ deleteItem(item) : bool
}
class TrainingRepository implements ITrainingRepository {
- trainings : array
+ getItemById(int id) : object
+ getNbItems() : int
+ getItems(int index, int count, string orderingPropertyName, bool descending) : array
+ getItemsByDate(date, int index, int count, string orderingPropertyName, bool descending) : array
+ updateItem(oldItem, newItem) : void
+ addItem(item) : void
+ deleteItem(item) : bool
}
class UserRepository implements IUserRepository {
- users : array
+ getItemById(int id) : object
+ getNbItems() : int
+ getItems(int index, int count, string orderingPropertyName, bool descending) : array
+ getItemsByName(string substring, int index, int count, string orderingPropertyName, bool descending) : array
+ getItemByName(string substring, int index, int count, string orderingPropertyName, bool descending) : object
+ updateItem(oldItem, newItem) : void
+ addItem(item) : void
+ deleteItem(item) : bool
}
@enduml
```

@ -0,0 +1,91 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Diagramme de Classes : Gestion des Utilisateurs et Notifications
Bienvenue dans le cœur de notre système, où la gestion des utilisateurs et des notifications prend vie à travers ce diagramme de classes. Explorez les relations et les fonctionnalités essentielles qui orchestrent l'interaction entre les utilisateurs, les demandes d'amis, et les notifications.
**Entités Principales :**
- **Utilisateur (User) :** Représente les individus inscrits sur notre plateforme, caractérisés par leur nom et établissant des liens d'amitié avec d'autres utilisateurs.
- **Notification (Notification) :** Contient le texte informatif des notifications qui peuvent être émises par le système.
- **Demande d'Ami (Ask) :** Modélise une demande d'amitié émise par un utilisateur en direction d'un autre.
**Interfaces et Classes Abstraites :**
- **INotifier :** Interface définissant la méthode `notify()`, implémentée par des classes concrètes pour gérer la notification aux observateurs.
- **Observer :** Interface définissant la méthode `update()`, implémentée par les classes qui souhaitent être informées des changements dans un sujet observé.
- **UserManager :** Classe abstraite gérant la logique métier liée aux utilisateurs, tels que l'ajout ou la suppression d'amis, la réponse aux demandes d'amis, et la récupération de la liste d'amis.
- **IUserRepository :** Interface définissant les méthodes pour la recherche d'utilisateurs et l'ajout d'un nouvel utilisateur.
**Relations Clés :**
- Les utilisateurs peuvent avoir plusieurs amis et plusieurs notifications.
- La classe UserManager est connectée à IUserRepository pour gérer les opérations liées aux utilisateurs.
- Observer et Subject sont des composants du modèle de conception "Observer", permettant la notification efficace des changements dans le système.
Plongez-vous dans ce diagramme pour découvrir comment notre application crée un écosystème social dynamique, permettant aux utilisateurs d'interagir, de rester informés et de développer des liens significatifs au sein de la communauté.
```plantuml
class User {
+ name : string
}
User "1" --> "*" User: friends
User "1" --> "*" Notification: notifications
User "1" --> "*" Ask: friendRequests
class Notification {
- text : string
}
interface INotifier {
+ notify() : void
}
INotifier --|> Observer
abstract class UserManager {
- currentUser : User
+ deleteFriend(userId : int) : void
+ addFriend(userId : int) : void
+ respondToFriendRequest(requestId : int, choice : bool) : void
+ getFriends(userId : int) : User[]
}
class Ask {
- fromUser : int
- toUser : int
}
Ask --|> Subject
abstract class Subject {
+ attach(o : Observer) : void
+ detach(o : Observer) : void
+ notify() : void
}
Subject "1" --> "*" Observer
interface Observer {
+ update() : void
}
UserManager ..> User
UserManager o-- IUserRepository
UserManager o-- INotifier
interface IUserRepository {
+ findByUsername(username : string) : User
+ addUser(user : User) : bool
}
IUserRepository ..> User
```

@ -0,0 +1,158 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
## Diagramme de classe
```plantuml
class Athlete {
- array statsList
- array activityList
- array dataSourcesList
- TrainingRepository trainingRepository
- array usersList
+ __construct(trainingRepository: ?TrainingRepository)
+ getAthlete(): Athlete
+ getStatistic(): ?array
+ getActivite(): ?array
+ getDataSource(): ?array
+ getUsersList(): array
+ getUserList(user: User): User
+ getTraining(): ?TrainingRepository
+ getTrainingList(training: Training): ?Training
+ setTrainingsList(newTrainingsList: array): void
+ CheckAdd(user: User): bool
+ CheckAddTraining(training: Training): bool
+ addUser(user: User): bool
+ removeUser(user: User): bool
+ delUser(user: User): bool
+ addTraining(training: Training): bool
+ removeTraining(training: Training): bool
+ getTrainingsList(): ?array
}
Athlete --|> Role
Athlete *-- TrainingRepository
Athlete *-- User
Athlete *-- Training
abstract class Coach {
+ abstract __construct(trainingRepository: ?TrainingRepository)
+ abstract getUsersList(): ?array
+ abstract getUserList(user: User): User
+ abstract getTraining(): ?TrainingRepository
+ abstract getTrainingsList(): ?array
+ abstract getTrainingList(training: Training): ?Training
+ abstract CheckAdd(user: User): bool
+ abstract CheckAddTraining(training: Training): bool
+ abstract addUser(user: User): bool
+ abstract removeUser(user: User): bool
+ abstract addTraining(training: Training): bool
+ abstract removeTraining(training: Training): bool
}
Coach --|> Role
Coach *-- User
Coach *-- TrainingRepository
Coach *-- Training
class CoachAthlete {
- TrainingRepository trainingRepository
- array usersList
+ __construct(trainingRepository: ?TrainingRepository)
+ getUsersList(): ?array
+ getUserList(user: User): User
+ getTraining(): TrainingRepository
+ getTrainingsList(): ?array
+ getTrainingList(training: Training): ?Training
+ CheckAdd(user: User): bool
+ CheckAddTraining(training: Training): bool
+ addUser(user: User): bool
+ removeUser(user: User): bool
+ addTraining(training: Training): bool
+ removeTraining(training: Training): bool
}
CoachAthlete --|> Coach
CoachAthlete *-- User
CoachAthlete *-- TrainingRepository
CoachAthlete *-- Training
abstract class Role {
- int id
- array usersList
- TrainingRepository trainingRepository
+ abstract __construct(trainingRepository: ?TrainingRepository)
+ abstract getUsersList(): ?array
+ abstract getUserList(user: User): User
+ abstract getTraining(): ?TrainingRepository
+ abstract getTrainingsList(): ?array
+ abstract getTrainingList(training: Training): ?Training
+ abstract CheckAdd(user: User): bool
+ abstract CheckAddTraining(training: Training): bool
+ abstract addUser(user: User): bool
+ abstract removeUser(user: User): bool
+ abstract addTraining(training: Training): bool
+ abstract removeTraining(training: Training): bool
}
Role *-- User
Role *-- Training
Role *-- TrainingRepository
class Training {
- int idTraining
- DateTime date
- float latitude
- float longitude
- String description
- String feedback
+ __construct(idTraining: int, date: DateTime, latitude: float, longitude: float, description: ?String = null, feedback: ?String = null)
+ getId(): int
+ getDate(): DateTime
+ getLocation(): String
+ getDescription(): String
+ getFeedback(): String
+ __toString(): String
}
class User {
- int id
- String username
- string nom
- string prenom
- string email
- string motDePasse
- string sexe
- float taille
- float poids
- DateTime dateNaissance
- Role role
+ __construct(id: int, username: String, nom: string, prenom: string, email: string, motDePasse: string, sexe: string, taille: float, poids: float, dateNaissance: DateTime, role: Role)
+ getId(): int
+ setId(id: int): void
+ getUsername(): String
+ setUsername(username: int): void
+ getNom(): string
+ setNom(nom: string): void
+ getPrenom(): string
+ setPrenom(prenom: string): void
+ getEmail(): string
+ setEmail(email: string): void
+ getMotDePasse(): string
+ setMotDePasse(motDePasse: string): void
+ getSexe(): string
+ setSexe(sexe: string): void
+ getTaille(): float
+ setTaille(taille: float): void
+ getPoids(): float
+ setPoids(poids: float): void
+ getDateNaissance(): DateTime
+ setDateNaissance(dateNaissance: DateTime): void
+ getRole(): Role
+ setRole(role: Role): void
+ isValidPassword(password: string): bool
+ __toString(): String
}
User *-- Role
````

@ -0,0 +1,22 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
## Diagramme de séquence systeme
- Création de compte
```plantuml
actor User as u
u->Systeme : demandePageConnexion()
alt User déjà connecté
Systeme-->u : redirectionPageCompte()
end
Systeme-->u : PageConnexion()
alt User possède déjà un compte
u->Systeme:InfosConnexion()
else
u->Systeme:CreerCompte()
Systeme-->u :PageCreationCompte()
u->Systeme:InfosCreationCompte()
end
Systeme-->u :Connecter()
```

@ -0,0 +1,153 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
## Diagramme de classe
- Ajout d'amis
```plantuml
class User {
+ name : string
}
User "1" --> "*" User: friends
User "1" --> "*" Notification: notifications
User "1" --> "*" Ask: friendRequests
class Notification {
- text : string
}
interface INotifier {
+ notify() : void
}
INotifier --|> Observer
abstract class UserManager {
- currentUser : User
+ deleteFriend(userId : int) : void
+ addFriend(userId : int) : void
+ respondToFriendRequest(requestId : int, choice : bool) : void
+ getFriends(userId : int) : User[]
}
class Ask {
- fromUser : int
- toUser : int
}
Ask --|> Subject
abstract class Subject {
+ attach(o : Observer) : void
+ detach(o : Observer) : void
+ notify() : void
}
Subject "1" --> "*" Observer
interface Observer {
+ update() : void
}
UserManager ..> User
UserManager o-- IUserRepository
UserManager o-- INotifier
interface IUserRepository {
+ findByUsername(username : string) : User
+ addUser(user : User) : bool
}
IUserRepository ..> User
```
## Diagrammes de séquence
- Envoi de demande d'ami :
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
u->v:/Friend
v->c:Get : /Friends
c->m:getFriends(userId)
m-->c::friends : User[]
c-->v:renderView(Friends)
v-->u:
u->v:input : name
v->c:Get : searchFriends? pseudo=name
c->m:searchUser(name:string)
m->m:notify(from : user, to : user, action : action)
m-->c:OK
c-->v:OK
v-->u:OK
```
- Accepter une demande d'ami :
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
m->c:RecevoirDemandeAmi(idUser)
c->v:AfficherDemandeAmi(idUser)
v->u:PageDemandeAmi(idUser)
u-->v:RepondreDemandeAmi(bool)
v-->c:EnregistrerReponse(bool)
c-->m:EnvoyerReponse(bool)
```
- Supprimer un ami :
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
u->v: Request Friends Page
v->c: Get /Friends
c->m: getFriends(userId)
alt successful retrieval
m-->c: friendsList: User[]
else retrieval failed
m-->c: error
end
c-->v: renderView(friendsList)
v-->u: Display Friends
u->v: clickDeleteFriend(idUser)
v->c: Post: deleteFriend(idUser)
c->m: deleteFriend(idUser)
alt successful deletion
m-->c: updatedFriendsList: User[]
else deletion failed
m-->c: error
end
c-->v: renderView(updatedFriendsList)
v-->u: Display Updated Friends
```
## Diagrammes de cas d'utilisation
- Gestion du compte et des amitiés
```plantuml
left to right direction
:Athlete: as a
a --> (Ajouter un ami)
a --> (Supprimer un ami)
a --> (Voir mes amis)
a --> (Modifier mes informations)
(Ajouter un ami)->(Saisir le nom de l'ami)
(Supprimer un ami)..>(S'authentifier) : <<include>>
(Ajouter un ami)..>(S'authentifier) : <<include>>
(Voir mes amis)..>(S'authentifier) : <<include>>
(Voir mes amis)..>(Lister les amis) : <<include>>
(Modifier mes informations)..>(Informations personnelles) : <<extends>>
(Modifier mes informations)..>(Informations de connexion) : <<extends>>
(Lister les amis)..>(Voir son profil) : <<include>>
(Voir son profil)..>(Voir ses activités) : <<extends>>
(Voir son profil)..>(Voir ses statistiques) : <<extends>>
(S'authentifier)..>(S'inscrire) : <<extends>>
(S'authentifier)..>(Se connecter) : <<include>>
(S'inscrire)..>(Inscription Athlète) : <<include>>
```

@ -0,0 +1,137 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# 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.
**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.
**Entités Clés :**
- Activité (Activity) : Représente une session d'activité physique, avec des détails tels que le type, la date, la durée, et plus encore.
- Gestionnaires (Managers) : Gérant différentes facettes de l'application, notamment les utilisateurs, les activités et les fichiers.
**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.
**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.
**Objectif :**
Offrir aux utilisateurs, en particulier aux athlètes, la possibilité d'enrichir leur profil et de suivre leur performance en important des données détaillées à partir de fichiers .fit.
```plantuml
@startuml issue028_DiagrammeDeClasses
class Activite {
-idActivite:int
-type:String
-date:Date
-heureDebut:Date
-heureFin:Date
-effortRessenti:int
-variability:float
-variance:float
-standardDeviation:float
-average:float
-maximum:int
-minimum:int
-avrTemperature:float
-hasAutoPause:boolean
+getIdActivite():int
+getType():String
+getDate():Date
+getHeureDebut():Date
+getHeureFin():Date
+getEffortRessenti():int
+getVariability():float
+getVariance():float
+getStandardDeviation():float
+getAverage():float
+getMaximum():int
+getMinimum():int
+getAvrTemperature():float
+setType(type:String):void
+setEffortRessenti(effortRessenti:int):void
+__toString():String
}
class Role {
-id:int
}
class Athlete {
+getActivities():array
+addActivity(myActivity:Activity):boolean
}
class User {
-id:int
-username:String
-nom:String
-prenom:String
-email:String
-motDePasse:String
-sexe:String
-taille:float
-poids:float
-dateNaissance:Date
+getId():int
+setId(id:int):void
+getUsername():String
+setUsername(username:String):void
+getNom():String
+setNom(nom:String):void
+getPrenom():String
+setPrenom(prenom:String):void
+getEmail():String
+setEmail(email:String):void
+getMotDePasse():String
+setMotDePasse(motDePasse:String):void
+getSexe():String
+setSexe(sexe:String):void
+getTaille():float
+setTaille(taille:float):void
+getPoids():float
+setPoids(poids:float):void
+getDateNaissance():Date
+setDateNaissance(dateNaissance:Date):void
+getRole():Role
+setRole(role:Role):void
+isValidPassword(password:String):boolean
+__toString():String
}
class AthleteManager {
+getActivities():array
}
class ActivityManager {
+saveFitFileToJSON(monFichierFit:object):boolean
+uploadFile(type:string, effortRessenti:int, file_path_or_data:string|resource, options:array):boolean
}
class DataManager {
}
class UserManager {
+login(loginUser:string, passwordUser:string):boolean
+register(loginUser:string, passwordUser:string, data:array):boolean
+deconnecter():boolean
}
User -> Role: role
Athlete -|> Role
DataManager -> UserManager: -userMgr
DataManager -> AthleteManager: -athleteMgr
DataManager -> ActivityManager: -activityMgr
UserManager -> AuthService: -authService
UserManager -> User: -currentUser
ActivityManager -> AuthService: -authService
Athlete -> Activite: listActivite
AthleteManager -> AuthService: -authService
@enduml
```

@ -0,0 +1,41 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Diagramme de Séquence : Gestion des Demandes d'Amis
Bienvenue dans le processus dynamique de gestion des demandes d'amis au sein de notre application ! Ce diagramme de séquence met en évidence les étapes clés impliquées dans la gestion des demandes d'amis entre utilisateurs.
**Acteurs Principaux :**
- **Utilisateur (u) :** L'individu interagissant avec l'application, recevant et répondant aux demandes d'amis.
**Flux d'Interaction :**
1. **Réception d'une Demande d'Ami :** Lorsqu'un utilisateur reçoit une demande d'ami, le modèle (Model) notifie le contrôleur (Controller) de la nouvelle demande, spécifiant l'identifiant de l'utilisateur émetteur.
2. **Affichage de la Demande d'Ami :** Le contrôleur transmet l'information à la vue (View), qui affiche la demande d'ami à l'utilisateur.
3. **Affichage de la Page des Demandes d'Amis :** L'utilisateur visualise la page des demandes d'amis dans l'interface utilisateur.
4. **Réponse à la Demande d'Ami :** L'utilisateur prend une décision quant à la demande d'ami, en répondant par un choix binaire (accepter ou refuser).
5. **Enregistrement de la Réponse :** La vue (View) transmet la réponse de l'utilisateur au contrôleur, qui enregistre cette réponse.
6. **Envoi de la Réponse :** Le contrôleur communique avec le modèle pour envoyer la réponse, indiquant si la demande a été acceptée (true) ou refusée (false).
À travers ce diagramme de séquence, découvrez comment notre application gère efficacement le processus de gestion des demandes d'amis, offrant aux utilisateurs une expérience transparente et réactive lors de l'établissement de connexions sociales au sein de la plateforme.
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
m->c:RecevoirDemandeAmi(idUser)
c->v:AfficherDemandeAmi(idUser)
v->u:PageDemandeAmi(idUser)
u-->v:RepondreDemandeAmi(bool)
v-->c:EnregistrerReponse(bool)
c-->m:EnvoyerReponse(bool)
```

@ -0,0 +1,50 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Diagramme de Séquence : Recherche d'Amis
Bienvenue dans le processus dynamique de recherche d'amis au sein de notre application ! Ce diagramme de séquence met en lumière les étapes clés impliquées lorsque les utilisateurs recherchent des amis en utilisant un pseudo spécifique.
**Acteurs Principaux :**
- **Utilisateur (u) :** L'individu interagissant avec l'application, initié à la recherche d'amis.
**Flux d'Interaction :**
1. **Accès à la Fonctionnalité de Recherche :** L'utilisateur déclenche la fonctionnalité de recherche d'amis depuis son interface utilisateur.
2. **Saisie du Pseudo :** L'utilisateur entre le pseudo de l'ami qu'il souhaite rechercher.
3. **Requête de Recherche :** La vue (View) transmet la demande de recherche au contrôleur (Controller), qui déclenche une requête GET au serveur pour récupérer la liste des amis correspondant au pseudo saisi.
4. **Traitement de la Requête :** Le modèle (Model) récupère la liste d'amis correspondante en utilisant l'identifiant de l'utilisateur et notifie le contrôleur du résultat.
5. **Notification des Utilisateurs :** Le modèle informe également les utilisateurs concernés (émetteur et destinataire) de l'action de recherche effectuée.
6. **Rendu de la Vue :** Le contrôleur reçoit la liste d'amis du modèle et rend cette liste à la vue.
7. **Affichage des Résultats :** La vue affiche les résultats de la recherche à l'utilisateur, montrant les amis qui correspondent au pseudo saisi.
À travers ce diagramme de séquence, découvrez comment notre application facilite le processus de recherche d'amis, fournissant aux utilisateurs une interface conviviale et réactive pour élargir leur réseau social au sein de la plateforme.
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
u->v:/Friend
v->c:Get : /Friends
c->m:getFriends(userId)
m-->c::friends : User[]
c-->v:renderView(Friends)
v-->u:
u->v:input : name
v->c:Get : searchFriends? pseudo=name
c->m:searchUser(name:string)
m->m:notify(from : user, to : user, action : action)
m-->c:OK
c-->v:OK
v-->u:OK
```

@ -0,0 +1,64 @@
[retour au README.md](../../../README.md)
[Retour aux Documents](../../README_DOCUMENTS.md)
[Retour au diagramme de classes](../README_DIAGRAMMES.md)
# Introduction au Diagramme de Séquence : Gestion des Amis
Bienvenue dans le processus dynamique de gestion des amis au sein de notre application ! Ce diagramme de séquence met en lumière les interactions entre l'utilisateur et l'application, ainsi que le flux d'informations entre les différentes composantes du système.
**Acteurs Principaux :**
- **Utilisateur (u) :** L'individu interagissant avec l'application, souhaitant consulter et gérer sa liste d'amis.
**Flux d'Interaction :**
1. **Demande de la Page d'Amis :** L'utilisateur déclenche la demande de la page d'amis, amorçant le processus d'affichage de sa liste d'amis.
2. **Récupération des Amis :** Le contrôleur (Controller) reçoit la demande et interagit avec le modèle (Model) pour récupérer la liste d'amis associée à l'identifiant de l'utilisateur.
- *Cas de Récupération Réussi :* Si la récupération est réussie, le modèle transmet la liste d'amis au contrôleur.
- *Cas d'Échec de Récupération :* En cas d'échec, une notification d'erreur est renvoyée.
3. **Affichage de la Liste d'Amis :** Le contrôleur rend la vue (View) en utilisant la liste d'amis récupérée, qui est ensuite affichée à l'utilisateur.
4. **Suppression d'un Ami :** L'utilisateur décide de supprimer un ami spécifique en cliquant sur l'option correspondante.
5. **Traitement de la Suppression :** Le contrôleur, en réponse à la demande de suppression, envoie une requête au modèle pour effectuer la suppression de l'ami identifié par son identifiant utilisateur (idUser).
- *Cas de Suppression Réussie :* Si la suppression est réussie, le modèle renvoie la liste d'amis mise à jour.
- *Cas d'Échec de Suppression :* En cas d'échec, une notification d'erreur est renvoyée.
6. **Affichage de la Liste d'Amis Mise à Jour :** La vue est mise à jour avec la nouvelle liste d'amis, qui est ensuite affichée à l'utilisateur.
À travers ce diagramme de séquence, découvrez comment notre application gère de manière fluide et réactive les interactions de l'utilisateur avec sa liste d'amis, garantissant une expérience utilisateur cohérente et sans heurts.
```plantuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
u->v: Request Friends Page
v->c: Get /Friends
c->m: getFriends(userId)
alt successful retrieval
m-->c: friendsList: User[]
else retrieval failed
m-->c: error
end
c-->v: renderView(friendsList)
v-->u: Display Friends
u->v: clickDeleteFriend(idUser)
v->c: Post: deleteFriend(idUser)
c->m: deleteFriend(idUser)
alt successful deletion
m-->c: updatedFriendsList: User[]
else deletion failed
m-->c: error
end
c-->v: renderView(updatedFriendsList)
v-->u: Display Updated Friends
```

@ -0,0 +1,113 @@
@startuml
skinparam classAttributeIconSize 0
package MLD{
entity "Athlète" as athlete {
{static} idAthlete
nom
prénom
email
sexe
taille
poids
motDePasse
dateNaissance
}
entity "Amitié" as friendship{
{static}# idAthlete1
{static}# idAthlete2
début
}
entity "Notification" as notif {
{static} idNotif
message
date
statut
urgence
#athleteId
}
entity "Coach" as coach {
{static} idCoach
// attributs spécifiques au coach
#athleteId
}
entity "Statistique" as stats {
{static} idStatistique
poids
fcMoyenne
fcMax
caloriesBrûléesMoy
date
#athleteId
}
entity "Entraînement" as training {
{static} idEntrainement
date
description
// Exercices
latitude
longitude
feedback
#coachId
}
entity "Participe" as takepart {
{static} #athleteId
{static} #entrainementId
}
entity "SourceDonnée" as source {
{static} idSource
type
modèle
précision
#athleteId
}
entity "Activité" as activity {
{static} idActivité
type
date
heureDeDébut
heureDeFin
effortRessent
variabilité
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
coach --> athlete
athlete <-- source
stats --> athlete
takepart --> athlete
takepart --> training
friendship --> athlete
notif --> athlete
coach <-- training
athlete <-- friendship
@enduml

@ -0,0 +1,26 @@
[retour au README.md](../../README.md)
[Retour aux Documents](../README_DOCUMENTS.md)
# Diagrammes nécéssaires à notre projet
## Diagrammes de classes
- [issue016 - Statistiques coach ](DiagrammeDeClasses/README_issue016.md)
- [issue020 - Stub authentification ](DiagrammeDeClasses/README_issue020.md)
- [issue021 - Authentification ](DiagrammeDeClasses/README_issue021.md)
- [issue022 - Ajout des amis ](DiagrammeDeClasses/README_issue022.md)
- [issue023 - User Gateway ](DiagrammeDeClasses/README_issue023.md)
- [issue027 - Framework ](DiagrammeDeClasses/README_issue027.md)
- [issue028 - Importation de fichiers .fit](DiagrammeDeClasses/README_issue028.md)
- [issue030 - Cookies ](DiagrammeDeClasses/README_issue030.md)
- [couche d'accès aux données](DiagrammeDeClasses/README_accesDonnees.md)
- [Diagramme de classe pour l'ajout d'amis](DiagrammeDeClasses/README_ajoutAmi.md)
## Diagrammes de séquence
- [Envoi de demande d'ami](DiagrammeDeSequence/README_demandeAmi.md)
- [Accepter une demande d'ami](DiagrammeDeSequence/README_accepterAmi.md)
- [Supprimer un ami](DiagrammeDeSequence/README_suppressionAmi.md)
## 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)

@ -0,0 +1,55 @@
@startuml
class User {
+ name : string
}
User "1" --> "*" User: friends
User "1" --> "*" Notification: notifications
User "1" --> "*" Ask: friendRequests
class Notification {
- text : string
}
interface INotifier {
+ notify() : void
}
INotifier --|> Observer
abstract class UserManager {
- currentUser : User
+ deleteFriend(userId : int) : void
+ addFriend(userId : int) : void
+ respondToFriendRequest(requestId : int, choice : bool) : void
+ getFriends(userId : int) : User[]
}
class Ask {
- fromUser : int
- toUser : int
}
Ask --|> Subject
abstract class Subject {
+ attach(o : Observer) : void
+ detach(o : Observer) : void
+ notify() : void
}
Subject "1" --> "*" Observer
interface Observer {
+ update() : void
}
UserManager ..> User
UserManager o-- IUserRepository
UserManager o-- INotifier
interface IUserRepository {
+ findByUsername(username : string) : User
+ addUser(user : User) : bool
}
IUserRepository ..> User
@enduml

@ -0,0 +1,20 @@
@startuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
m-->c: pendingRequests: Request[]
c-->v: DisplayPendingRequests(pendingRequests)
v-->u: Show Friend Requests
u->v: RespondToRequest(requestId, response)
v-->c: RecordResponse(requestId, response)
c->m: UpdateRequestStatus(requestId, response)
m-->c: updateStatus: success/failure
c-->v: NotifyUpdateResult(updateStatus)
v-->u: Show Response Result
@enduml

@ -0,0 +1,28 @@
@startuml
actor User as u
boundary View as v
control Controller as c
entity Model as m
u->v: Request Friends Page
v->c: Get /Friends
c->m: getFriends(userId)
alt successful retrieval
m-->c: friendsList: User[]
else retrieval failed
m-->c: error
end
c-->v: renderView(friendsList)
v-->u: Display Friends
u->v: clickDeleteFriend(idUser)
v->c: Post: deleteFriend(idUser)
c->m: deleteFriend(idUser)
alt successful deletion
m-->c: updatedFriendsList: User[]
else deletion failed
m-->c: error
end
c-->v: renderView(updatedFriendsList)
v-->u: Display Updated Friends
@enduml

@ -15,12 +15,12 @@
"src/data/stub/repository"
],
"Console\\": "src/console",
"Shared\\": "src/shared",
"App\\Router\\": "src/app/router",
"App\\Controller\\": "src/app/controller",
"App\\Router\\Response\\" : "src/app/router/response",
"App\\Router\\Middleware\\" : "src/app/router/middleware",
"App\\Router\\Request\\" : "src/app/router/request",
"Shared\\": "src/shared/",
"Shared\\Exception\\": "src/shared/exception",
"Shared\\Attributes\\": "src/shared/attributes",
"App\\Views\\Directives\\" : "src/app/views/directives",

@ -4,8 +4,46 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
"content-hash": "c8acec96dcc23612616eedff9886528e",
"content-hash": "1887e85fc3cfddacf8d7e17588dae6f1",
"packages": [
{
"name": "adriangibbons/php-fit-file-analysis",
"version": "v3.2.4",
"source": {
"type": "git",
"url": "https://github.com/adriangibbons/php-fit-file-analysis.git",
"reference": "8efd36b1b963f01c42dc5329626519c040dec664"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/adriangibbons/php-fit-file-analysis/zipball/8efd36b1b963f01c42dc5329626519c040dec664",
"reference": "8efd36b1b963f01c42dc5329626519c040dec664",
"shasum": ""
},
"require-dev": {
"phpunit/phpunit": "4.8.*",
"satooshi/php-coveralls": "^2.0",
"squizlabs/php_codesniffer": "2.*"
},
"type": "library",
"autoload": {
"psr-4": {
"adriangibbons\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"description": "A PHP class for analysing FIT files created by Garmin GPS devices",
"homepage": "https://github.com/adriangibbons/php-fit-file-analysis",
"keywords": [
"Fit",
"garmin"
],
"support": {
"issues": "https://github.com/adriangibbons/php-fit-file-analysis/issues",
"source": "https://github.com/adriangibbons/php-fit-file-analysis/tree/master"
},
"time": "2019-11-20T06:58:56+00:00"
},
{
"name": "altorouter/altorouter",
"version": "v1.1.0",

@ -1,10 +1,6 @@
<?php
use Dotenv\Dotenv;
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
use Shared\Log;
$dotenv = Dotenv::createUnsafeImmutable(__DIR__,'.env');
@ -22,4 +18,4 @@ const DB_USER = 'toto';
const DB_PASSWORD = 'achanger';
//const APP_ENV = 'console';
const DSN = "mysql:host=" . DB_HOST . ";dbname=" . DB_DATABASE;
const DSN = "mysql:host=" . DB_HOST . ";dbname=" . DB_DATABASE;

@ -6,14 +6,54 @@ require_once __DIR__ . '/../config/config.php';
use App\AppCreator;
use App\Router\Middleware\LoggingMiddleware;
use App\Router\Request\RequestFactory;
use Manager\UserManager;
use Manager\DataManager;
use Repository\IUserRepository;
use Shared\ArgumentControllerResolver;
use Shared\IArgumentResolver;
use Stub\AuthService;
use Stub\NotificationRepository;
use Stub\TrainingRepository;
use Stub\UserRepository;
use Stub\RelationshipRequestRepository;
use Repository\INotificationRepository;
use App\Router\Middleware\AuthMiddleware;
use Network\IAuthService;
use Network\IFriendRequestService;
use Network\RelationshipService;
use Network\INotificationService;
use Stub\NotificationService;
use Stub\StubData;
use Twig\Environment;
use Twig\Loader\FilesystemLoader;
use Shared\Log;
use Shared\IHashPassword;
use Shared\HashPassword;
$appFactory = new AppCreator();
$appFactory->registerService(IArgumentResolver::class, ArgumentControllerResolver::class);
$appFactory->registerService(UserManager::class, UserManager::class);
$appFactory->registerService(DataManager::class, StubData::class);
$appFactory->registerService(IAuthService::class, AuthService::class);
$appFactory->registerService(IFriendRequestService::class, RelationshipService::class);
$appFactory->registerService(IHashPassword::class, HashPassword::class);
$appFactory->registerService(INotificationService::class, NotificationService::class);
$appFactory->registerService(INotificationRepository::class, NotificationRepository::class);
$appFactory->registerService(IUserRepository::class, UserRepository::class);
$appFactory->registerService(\Twig\Loader\LoaderInterface::class, function() {
return new FilesystemLoader(__DIR__ . '/../src/app/views/Templates');
@ -29,7 +69,7 @@ $app = $appFactory->create();
if (!is_null($app)){
// Ajout des Middleware
/*$app->use(new LoggingMiddleware());*/
$app->use(new AuthMiddleware());
$app->mapControllers();
$app->run(RequestFactory::createFromGlobals());
}

@ -29,6 +29,9 @@ class App
private FrontController $frontController;
private Session $session;
public function __construct(string $appName, int $version, \App\Container $diContainer)
{
$this->appName = $appName;
@ -36,6 +39,7 @@ class App
$this->container = $diContainer;
$this->router = new Router("");
$this->frontController = new FrontController($this->router,$this->container);
$this->session = Session::getInstance();
}
public function use(IHttpMiddleware $middleware)

@ -13,14 +13,13 @@ class Container implements ContainerInterface
public function get(string $id)
{
if ($this->has($id)) {
$entry = $this->entries[$id];
if (is_callable($entry)) {
if (is_callable($entry)) {
return $entry($this);
}
$id = $entry;
}

@ -12,12 +12,11 @@ use Shared\Log;
class AthleteController extends BaseController
{
#[Route(path: '/search-user', name: 'search-user', methods: ['GET'])]
#[Route(path: '/search-ath', name: 'search-ath', methods: ['GET'])]
public function searchUser(string $username, IRequest $req): Response
{
$taberror = [];
// FILTER
$utiliArray = [
[
'nom' => 'John',
@ -34,145 +33,144 @@ class AthleteController extends BaseController
];
// if(!Validation::val_string($name)){
try {
//code...
$model->userMgr->addFriend($username);
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 ]);
}
//code...
// $model->userMgr->getUser($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: '/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: '/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: '/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: '/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: '/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: '/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: '/delete-friend', name: 'delete-friend', methods: ['POST'])]
// #[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',
// ],
// ];
// // $this->Auth->getUser->role->getFriends
// 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: '/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' => [],
]);
}
}

@ -1,82 +1,147 @@
<?php
// namespace App\Controller;
// use App\Container;
// use App\Router\Request\IRequest;
// use App\Router\Response\Response;
// use Shared\Attributes\Route;
// use Twig\Environment;
// use Data\Core\Preferences;
// use Shared\Log;
// class AuthController extends BaseController
// {
// #[Route('/login', name: 'login')]
// public function login(?string $username, ?string $password ,IRequest $request): Response {
// // if user is already logged in, don't display the login page again
// if ($user) {
// return $this->redirectToRoute('blog_index');
// }
// // this statement solves an edge-case: if you change the locale in the login
// // page, after a successful login you are redirected to a page in the previous
// // locale. This code regenerates the referrer URL whenever the login page is
// // browsed, to ensure that its locale is always the current one.
// $this->saveTargetPath($request->getSession(), 'main', $this->generateUrl('admin_index'));
// return $this->render('security/login.html.twig', [
// // last username entered by the user (if any)
// 'last_username' => $helper->getLastUsername(),
// // last authentication error (if any)
// 'error' => $helper->getLastAuthenticationError(),
// ]);
// }
// #[Route('/login', name: 'login')]
// public function login(?string $username, ?string $password ,IRequest $request): Response {
// // if user is already logged in, don't display the login page again
// if ($user) {
// return $this->redirectToRoute('blog_index');
// }
// // this statement solves an edge-case: if you change the locale in the login
// // page, after a successful login you are redirected to a page in the previous
// // locale. This code regenerates the referrer URL whenever the login page is
// // browsed, to ensure that its locale is always the current one.
// $this->saveTargetPath($request->getSession(), 'main', $this->generateUrl('admin_index'));
// return $this->render('security/login.html.twig', [
// // last username entered by the user (if any)
// 'last_username' => $helper->getLastUsername(),
// // last authentication error (if any)
// 'error' => $helper->getLastAuthenticationError(),
// ]);
// }
namespace App\Controller;
use App\Container;
use App\Router\Request\IRequest;
use App\Router\Response\Response;
use App\Router\Response\IResponse;
use Couchbase\UserManager;
use Shared\Attributes\Route;
use Shared\Validation;
use Twig\Environment;
use Data\Core\Preferences;
use Shared\Log;
class AuthController extends BaseController
{
#[Route('/login', name: 'login',methods: ['POST'])]
public function login(IRequest $request): IResponse {
$error = [];
try {
$log=Validation::clean_string($request->getBody()['email']);
$mdp=Validation::clean_string($request->getBody()['password']);
} catch (\Throwable $th) {
$error = "Wrong cred";
}
if($this->container->get(UserManager::class)->login($log,$mdp)){
return $this->redirectToRoute('/');
}
else{
$error [] = "Erreur de connexion. Essayez encore";
}
return $this->render('./page/login.html.twig', ['error' => $error]);
}
#[Route('/log', name: 'baseLog',methods: ['GET'])]
public function index(IRequest $request): IResponse {
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('/register', name: 'register' , methods:['GET'])]
public function register(IRequest $request): IResponse
{
if ($request->getMethod() == 'POST') {
$nom = $request->getBody()['nom'];
$prenom = $request->getBody()['prenom'];
$username = $request->getBody()['username'];
// function inscription() {
// $model = new ModelVisitor();
// $log=Validation::clean_string($_POST['pseudo']);
// $mdp=Validation::clean_string($_POST['password']);
// if($model->createAUser($log,$mdp)){
// if(ModelUser::login($log, $mdp)){
// UserControler::displayView();
// }
// }
// }
// function login() {
// $model = new ModelVisitor();
// if(!isset($_POST['pseudo']) || !isset($_POST['password'])) throw new Exception(" some wrong with credentials !!!!!");
// $log=Validation::clean_string($_POST['pseudo']);
// $mdp=Validation::clean_string($_POST['password']);
// if(ModelUser::login($log, $mdp)){
// UserControler::displayView();
// }
$email = $request->getBody()['email'];
$motDePasse = $request->getBody()['motDePasse'];
$sexe = $request->getBody()['sexe'];
$taille = $request->getBody()['taille'];
$poids = $request->getBody()['poids'];
$dateNaissanceStr = $request->getBody()['nom'];
$dateNaissance = new \DateTime($dateNaissanceStr);
if (!$dateNaissance) {
throw new \Exception("Date de naissance non valide. Format attendu : YYYY-MM-DD");
}
$roleName = $request->getBody()['roleName'];
$registrationData = [
'nom' => $nom,
'prenom' => $prenom,
'username' => $username,
'email' => $email,
'sexe' => $sexe,
'taille' => $taille,
'poids' => $poids,
'dateNaissance' => $dateNaissance,
'roleName' => $roleName
];
try {
if ($this->container->get(UserManager::class)->register($email, $motDePasse, $registrationData)) {
return $this->redirectToRoute('/');
} else {
$error [] = 'L\'inscription a échoué. Veuillez réessayer.';
}
} catch (\Exception $e) {
$error [] = 'Erreur lors de l\'inscription: ' . $e->getMessage();
}
}
return $this->render('/register.html.twig');
}
#[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' => []
]);
}
// }
}
?>

@ -1,6 +1,7 @@
<?php
namespace App\Controller;
use Data\Core\Preferences;
use App\Container;
use App\Router\Response\RedirectResponse;
@ -10,6 +11,12 @@ use Psr\Container\ContainerInterface;
abstract class BaseController
{
protected Preferences $preference;
public function __construct(){
$this->preference = new Preferences();
}
protected ContainerInterface $container;
public function setContainer(ContainerInterface $container)

@ -1,31 +1,31 @@
<?php
namespace App\Controller;
// namespace App\Controller;
use App\Container;
use App\Router\Request\IRequest;
use App\Router\Response\Response;
use App\Router\Response\IResponse;
// use App\Container;
// use App\Router\Request\IRequest;
// use App\Router\Response\Response;
// use App\Router\Response\IResponse;
use Shared\Attributes\Route;
use Twig\Environment;
use Data\Core\Preferences;
use Shared\Log;
// use Shared\Attributes\Route;
// use Twig\Environment;
// use Data\Core\Preferences;
// use Shared\Log;
#[Route(path: '/coach', name: 'coach')]
class CoachController extends BaseController
{
// #[Route(path: '/coach', name: 'coach')]
// class CoachController extends BaseController
// {
private ICoachManager $coachManager;
private $security;
// private ICoachManager $coachManager;
// private $security;
public function __construct(DataManager $dataManager, Security $security)
{
$this->coachManager = $dataManager->coachMgr;
$this->security = $security;
}
// public function __construct(DataManager $dataManager, Security $security)
// {
// $this->coachManager = $dataManager->coachMgr;
// $this->security = $security;
// }
// #[Route(path: '/', name: 'home', methods: ['GET'])]
// public function index(): Response
@ -44,7 +44,6 @@
// 'member' => []
// ]);
// }
//
// #[Route('/global-stats', name: 'coach_global_stats', methods: ['GET'])]
// public function globalStats(): Response
// {
@ -52,194 +51,10 @@
// return $this->render('coach/global_stats.html.twig');
// }
#[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-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: '/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: '/coaching', name: 'coaching', methods: ['GET'])]
// public function coaching(): Response
// #[Route(path: '/exercice', name: 'exercice', methods: ['GET'])] // 8
// public function exercice(): Response
// {
// return $this->render('./page/coaching.html.twig',[
// return $this->render('./page/exercice.html.twig',[
// 'css' => $this->preference->getCookie(),
// 'pp' => "test2",
// 'user' => "Doe",
@ -253,13 +68,30 @@
// '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('/list-athletes', name: 'coach_list_athletes')]
// public function listAthletes(): Response
// {
// $coach = $this->security->getUser();
// $athletes = $this->coachManager->getAthletesForCoach($coach);
//
// return $this->render('coach/list_athletes.html.twig', [
// 'athletes' => $athletes,
// ]);
@ -272,23 +104,21 @@
// 'athleteId' => $athleteId,
// ]);
// }
//
// #[Route('/add-athlete/{athleteId}', name: 'coach_add_athlete', methods: ['POST'])]
// public function addAthlete(IRequest $request, $athleteId): IResponse
// {
// // Implement logic to add athlete
// // ...
//
// return $this->redirectToRoute('coach_list_athletes');
// }
// #[Route('/remove-athlete', name: 'coach_remove_athlete', methods: ['POST'])]
// public function removeAthlete(int $athleteId, IRequest $request): IResponse
// {
// return $this->redirectToRoute("/athletes");
// }
// // #[Route('/remove-athlete', name: 'coach_remove_athlete', methods: ['POST'])]
// // public function removeAthlete(int $athleteId, IRequest $request): IResponse
// // {
// // return $this->redirectToRoute("/athletes");
// // }
}
?>
// }

@ -14,7 +14,7 @@ use Shared\Log;
class Controller extends BaseController
{
private Environment $twig;
private Preferences $preference;
protected Preferences $preference;
public function __construct()
{
@ -76,187 +76,83 @@ class Controller extends BaseController
]);
}
// #[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: '/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
#[Route(path: '/search-member', name: 'search-member', methods: ['GET'])]
public function searchMember(string $username, IRequest $req): Response
{
$taberror = [];
// FILTER
$utiliArray = [
[
'nom' => 'John',
@ -271,23 +167,34 @@ class Controller extends BaseController
'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' => [],
]);
// 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-friend', name: 'add-friend', methods: ['POST'])]
public function addFriend(string $username, IRequest $req): Response
#[Route(path: '/add-member', name: 'add-member', methods: ['POST'])]
public function addmember(string $username, IRequest $req): Response
{
$taberror = [];
$utiliArray = [
@ -308,7 +215,7 @@ class Controller extends BaseController
try {
//code...
// $model->userMgr->addFriend($name);
return $this->render('./page/addfriend.html.twig',[
return $this->render('./page/addmember.html.twig',[
'css' => $this->preference->getCookie(),
'pp' => "test2",
'user' => "Doe",
@ -330,8 +237,8 @@ class Controller extends BaseController
}
#[Route(path: '/friend', name: 'friend', methods: ['GET'])]
public function friend(): Response
#[Route(path: '/member', name: 'member', methods: ['GET'])]
public function member(): Response
{
$utiliArray = [
[
@ -347,7 +254,7 @@ class Controller extends BaseController
'username' => 'alicesmith',
],
];
return $this->render('./page/addfriend.html.twig',[
return $this->render('./page/addmember.html.twig',[
'css' => $this->preference->getCookie(),
'pp' => "test2",
'user' => "Doe",
@ -362,6 +269,7 @@ class Controller extends BaseController
]);
}
#[Route(path: '/friendlist', name: 'friendlist', methods: ['POST'])]
public function friendlist(string $username, IRequest $req): Response
{
@ -432,28 +340,10 @@ class Controller extends BaseController
]);
}
// #[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
#[Route(path: '/coaching', name: 'coaching', methods: ['GET'])]
public function coaching(): Response
{
return $this->render('./page/mail.html.twig',[
return $this->render('./page/coaching.html.twig',[
'css' => $this->preference->getCookie(),
'pp' => "test2",
'user' => "Doe",
@ -468,10 +358,10 @@ class Controller extends BaseController
]);
}
#[Route(path: '/import', name: 'import', methods: ['GET'])]
public function import(): Response
#[Route(path: '/mail', name: 'mail', methods: ['GET'])]
public function mail(): Response
{
return $this->render('./page/import.html.twig',[
return $this->render('./page/mail.html.twig',[
'css' => $this->preference->getCookie(),
'pp' => "test2",
'user' => "Doe",
@ -486,10 +376,10 @@ class Controller extends BaseController
]);
}
#[Route(path: '/settings', name: 'settings', methods: ['GET'])]
public function settings(IRequest $req): Response
#[Route(path: '/import', name: 'import', methods: ['GET'])]
public function import(): Response
{
return $this->render('./page/settings.html.twig',[
return $this->render('./page/import.html.twig',[
'css' => $this->preference->getCookie(),
'pp' => "test2",
'user' => "Doe",
@ -504,6 +394,7 @@ class Controller extends BaseController
]);
}
#[Route(path: '/profile', name: 'profile', methods: ['GET'])]
public function profile(): Response
{
@ -522,28 +413,6 @@ class Controller extends BaseController
]);
}
#[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
@ -565,26 +434,6 @@ class Controller extends BaseController
]);
}
#[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
@ -711,5 +560,4 @@ class Controller extends BaseController
'member' => []
]);
}
}

@ -47,6 +47,9 @@ class FrontController {
} catch (NotFoundHttpException $e) {
$this->handleError(404, $e->getMessage());
}
catch(\Throwable $e){
$this->handleError(501, $e->getMessage());
}
}
private function getController($controllerSpec) {

@ -1,17 +1,19 @@
<!-- #[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' => []
]);
} -->
<?php
// namespace App\Controller;
// use App\Container;
// use App\Router\Request\IRequest;
// use App\Router\Response\Response;
// use App\Router\Response\IResponse;
// use Shared\Attributes\Route;
// use Twig\Environment;
// use Data\Core\Preferences;
// use Shared\Log;
// #[Route(path: '/coach', name: 'coach')]
// class CoachController extends BaseController
// {

@ -1,80 +1,78 @@
<?php
// namespace App\Controller;
namespace App\Controller;
// use App\Container;
// use App\Router\Request\IRequest;
// use App\Router\Response\Response;
// use Shared\Attributes\Route;
// use Twig\Environment;
// use Data\Core\Preferences;
// use Shared\Log;
use App\Container;
use App\Router\Request\IRequest;
use App\Router\Response\Response;
use Shared\Attributes\Route;
use Twig\Environment;
use Data\Core\Preferences;
use Shared\Log;
// class UserController extends BaseController
// {
class UserController extends BaseController
{
#[Route(path: '/', name: 'home', methods: ['GET'])]
public function index(): 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: '/', name: 'home', methods: ['GET'])]
// public function index(): 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: '/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: '/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: '/preferences', name: 'preferences', methods: ['POST'])]
public function preferences(string $theme, IRequest $req): Response
{
// #[Route(path: '/preferences', name: 'preferences', methods: ['POST'])]
// public function preferences(string $theme, IRequest $req): Response
// {
// /*TODO*/
// // VALIDER LES DONNEES
// $this->preference->majCookie($theme);
// 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' => []
// ]);
// }
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' => []
]);
}
// }
}

@ -0,0 +1,27 @@
<?php
namespace App\Router\Middleware;
use App\Router\Session;
use Shared\Log;
use App\Router\Request\IRequest;
use App\Router\Response\RedirectResponse;
class AuthMiddleware extends Middleware {
public function handle(IRequest $request, callable $next) {
// if (isset($_SESSION['user'])) {
// $resp =new RedirectResponse("/");
// $resp->send();
// exit;
// }
// La page nest pas redirigée correctement
// Firefox a détecté que le serveur redirige la demande pour cette adresse dune manière qui naboutira pas.
// La cause de ce problème peut être la désactivation ou le refus des cookies.
// if (!isset($_SESSION['user'])) {
// $resp =new RedirectResponse("/log");
// $resp->send();
// exit;
// }
return parent::handle($request, $next);
}
}

@ -54,7 +54,7 @@ class RedirectResponse implements IResponse
foreach ($this->headers as $name => $value) {
header("$name: $value");
}
header("Location: " . $this->url);
// Optionally echo content if any

@ -11,27 +11,27 @@
<div class="card shadow-lg border-0 rounded-lg mt-5">
<div class="card-header"><h3 class="text-center font-weight-light my-4">Connexion</h3></div>
<div class="card-body">
<form method="post" action="/login">
<form>
<div class="form-floating mb-3">
<input class="form-control" id="username" name="username" type="text" placeholder="Nom d'utilisateur" />
<label for="username">Nom d'utilisateur</label>
<input class="form-control" id="inputEmail" type="email" placeholder="nom@exemple.com" />
<label for="inputEmail">Adresse eMail</label>
</div>
<div class="form-floating mb-3">
<input class="form-control" id="mdp" name="mdp" type="password" placeholder="Mot de passe" />
<label for="mdp">Mot de passe</label>
<input class="form-control" id="inputPassword" type="password" placeholder="Mot de passe" />
<label for="inputPassword">Mot de passe</label>
</div>
<div class="form-check mb-3">
<input class="form-check-input" id="inputRememberPassword" type="checkbox" value="" />
<label class="form-check-label" for="inputRememberPassword">Mémoriser le mot de passe</label>
</div>
<div class="d-flex align-items-center justify-content-between mt-4 mb-0">
<a class="small" href="/pass">Mot de passe oublié ?</a>
<button class="btn btn-primary" type="submit">Se connecter</a>
<a class="small" href="password.html">Mot de passe oublié ?</a>
<a class="btn btn-primary" href="index.html">Se connecter</a>
</div>
</form>
</div>
<div class="card-footer text-center py-3">
<div class="small"><a href="/regist">Besoin d'un compte ? Inscrivez-vous !</a></div>
<div class="small"><a href="register.html">Besoin d'un compte ? Inscrivez-vous !</a></div>
</div>
</div>
</div>

@ -15,81 +15,78 @@
<div class="row mb-3">
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="nom" name="nom" type="text" placeholder="Entrez votre nom" />
<label for="nom">Nom de famille</label>
<input class="form-control" id="inputFirstName" type="text" placeholder="Entrez votre nom" />
<label for="inputFirstName">Nom de famille</label>
</div>
</div>
<div class="col-md-6">
<div class="form-floating">
<input class="form-control" id="prenom" name="prenom" type="text" placeholder="Entrez votre prénom" />
<label for="prenom">Prénom</label>
<input class="form-control" id="inputLastName" type="text" placeholder="Entrez votre prénom" />
<label for="inputLastName">Prénom</label>
</div>
</div>
</div>
<div class="row mb-3">
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="username" name="username" type="text" placeholder="Entrez votre pseudonyme" />
<label for="username">Nom d'utilisateur</label>
<label for="inputUsername"></label><input class="form-control" id="inputUsername" type="text" placeholder="Entrez votre pseudonyme" />
<label for="inputFirstName">Nom d'utilisateur</label>
</div>
</div>
<div class="col-md-6">
<div class="form-floating">
<input class="form-control" id="sexe" name="sexe" type="hidden">
<select id="sexe" name="sexe">
<label for="inputLastName">Sexe</label>
<label for="gender"></label><select id="gender" name="gender">
<option value="male">Homme</option>
<option value="female">Femme</option>
<option value="unknown">Ne se prononce pas</option>
</select>
</input>
</div>
</div>
</div>
<div class="form-floating mb-3">
<input class="form-control" id="mail" type="mail" placeholder="nom@exemple.com" />
<label for="mail">Adresse eMail</label>
<input class="form-control" id="inputEmail" type="email" placeholder="nom@exemple.com" />
<label for="inputEmail">Adresse eMail</label>
</div>
<div class="form-floating mb-3">
<input class="form-control" id="dateNaissance" name="dateNaissance" type="date" placeholder="" />
<label for="dateNaissance">Date de naissance</label>
<input class="form-control" id="inputDateNaissance" type="date" placeholder="" />
<label for="inputEmail">Date de naissance</label>
</div>
<div class="row mb-3">
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="taille" name="taille" type="text" placeholder="Entrez votre taille" />
<label for="taille">Taille</label>
<input class="form-control" id="inputTaille" type="text" placeholder="Entrez votre taille" />
<label for="inputPassword">Taille</label>
</div>
</div>
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="poids" name="poids" type="text" placeholder="Entrez votre poids" />
<label for="poids">Poids</label>
<label for="inputPoids"></label><input class="form-control" id="inputPoids" type="text" placeholder="Entrez votre poids" />
<label for="inputPasswordConfirm">Poids</label>
</div>
</div>
</div>
<div class="row mb-3">
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="mdp" name="mdp" type="password" placeholder="Créez un mot de passe" />
<label for="mdp">Mot de passe</label>
<input class="form-control" id="inputPassword" type="password" placeholder="Créez un mot de passe" />
<label for="inputPassword">Mot de passe</label>
</div>
</div>
<div class="col-md-6">
<div class="form-floating mb-3 mb-md-0">
<input class="form-control" id="confirmMdp" name="confirmMdp" type="password" placeholder="Confirmez votre mot de passe" />
<label for="confirmMdp">Confirmer le mot de passe</label>
<input class="form-control" id="inputPasswordConfirm" type="password" placeholder="Confirmez votre mot de passe" />
<label for="inputPasswordConfirm">Confirmer le mot de passe</label>
</div>
</div>
</div>
<div class="mt-4 mb-0">
<div class="d-grid">
<button type="submit" class="btn btn-primary btn-block">Créer un compte</a>
</div>
<div class="d-grid"><a class="btn btn-primary btn-block" href="login.html.twig">Créer un compte</a></div>
</div>
</form>
</div>
<div class="card-footer text-center py-3">
<div class="small"><a href="/log">Avez-vous déjà un compte ? Connectez-vous ?</a></div>
<div class="small"><a href="login.html.twig">Avez-vous déjà un compte ? Connectez-vous ?</a></div>
</div>
</div>
</div>

@ -4,12 +4,16 @@ namespace Console;
use DateTime;
use Model\Athlete;
use Model\Coach;
use Model\RelationshipRequest;
use Model\Role;
use Model\Training;
use Model\User;
use Manager\DataManager;
use Stub\StubData;
$model = new StubData(); // Couche d'accès au model
$model = new Model(); // Couche d'accès au model
function clearScreen()
{
system('clear || cls');
@ -50,7 +54,6 @@ function displayProfileMenu()
echo "\n--- Profil ---\n";
echo "1. Informations de l'utilisateur\n";
echo "2. Historique d'activité\n";
echo "Voir les statistiques de condition physique Général";
echo "3. Liste d'amis\n";
echo "4. Paramètres de confidentialité et visibilité\n";
echo "5. Ajouter une activité\n";
@ -77,7 +80,6 @@ function displayCoachMenu()
clearScreen();
echo "\n--- Menu Coach ---\n";
echo "1. Liste des athlètes\n";
echo "2. Statistiques globales\n";
echo "3. Analyses par athlète\n";
echo "4. Gérer la liste de mes athlètes\n";
// Gérer les athlètes (comprend : Ajouter un athlète, Supprimer un athlète, Consulter les statistiques d'un athlète)
@ -86,19 +88,24 @@ function displayCoachMenu()
echo "Choisissez une option: ";
}
function displaySocialManagementMenu()
{
function displaySocialManagementMenu() {
clearScreen();
echo "\n--- Gestion sociale ---\n";
echo "1. Rechercher des coach\n";
echo "2. Rechercher des athletes\n";
echo "3. Gérer la liste d'amis\n";
// Ajouter des amis
// Supprimer des amis ...
echo "4. Options de partage\n";
echo "0. Retour au menu principal\n";
echo "Choisissez une option: ";
}
function displaySubSocialManagementMenu(){
clearScreen();
echo "\n--- Gestion sociale Sub 3---\n";
echo " 3.1. Voir les demandes d'amitié\n";
echo " 3.2. Répondre à une demande d'amitié\n";
echo " 3.3. Ajouter un ami\n";
echo " 3.4. Supprimer un ami\n";
}
function displaySettingsMenu()
{
@ -134,21 +141,22 @@ function displayManagementArrayTraining()
echo "0. Retour au menu du coach\n";
echo "Choisissez une option: ";
}
/**
* Fonction permettant à un utilisateur de se connecter.
*
* @param DataManager $model La couche d'accès au modèle de données.
* @param Model $model La couche d'accès au modèle de données.
* @return bool Retourne true si l'utilisateur s'est connecté avec succès, sinon false.
*/
function loginUser(DataManager $model)
function loginUser(Model $model): bool
{
try {
echo "\nEntrez votre nom d'utilisateur: ";
$username = trim(fgets(STDIN));
echo "\nEntrez votre nom email: ";
$emailUser = trim(fgets(STDIN));
echo "Entrez votre mot de passe: ";
$password = trim(fgets(STDIN));
if ($model->userMgr->login($username, $password)) {
if ($model->userMgr->login($emailUser, $password)) {
return true;
} else {
echo "Erreur de connexion. Essayez encore.\n";
@ -163,13 +171,148 @@ function loginUser(DataManager $model)
}
}
function addFriend(Model $model) {
clearScreen();
echo "\nEntrez le nom d'utilisateur de la personne que vous recherchez : ";
$nom = trim(fgets(STDIN));
$userList = $model->userMgr->searchUsersByName($nom);
if (empty($userList)) {
echo "Aucun utilisateur trouvé.\n";
return;
}
/** @var User $user */
foreach ($userList as $index => $user) {
echo ($index + 1) . ". " . $user->getNom() . " " . $user->getPrenom() . "\n";
}
echo "\nEntrez le numéro de la personne que vous voulez ajouter ou 0 pour annuler : ";
$choice = trim(fgets(STDIN));
if ($choice === '0') {
echo "Ajout d'ami annulé.\n";
return;
}
$selectedIndex = intval($choice) - 1;
if (!isset($userList[$selectedIndex])) {
echo "Sélection invalide.\n";
return;
}
$user = $userList[$selectedIndex];
echo "Ajout de " . $user->getPrenom() . " " . $user->getNom() . "\n";
if ($model->userMgr->addFriend($user->getUsername())) {
echo $userList[0]->getRole()->getUsersRequests()[0];
echo $userList[0]->getNotifications()[0]->getType();
sleep(2);
echo "Notification envoyée.\n";
} else {
echo "Problème à l'envoi de la notification, veuillez vérifier votre connexion ou réessayer plus tard.\n";
}
}
function deleteFriend(Model $model) {
echo "\nListe de vos amis :\n";
$friendList = $model->userMgr->getCurrentUser()->getRole()->getUsersList();
if (empty($friendList)) {
echo "Vous n'avez aucun ami à supprimer.\n";
return;
}
/** @var User $friend */
foreach ($friendList as $index => $friend) {
echo ($index + 1) . ". " . $friend->getNom() . " " . $friend->getPrenom() . "\n";
}
echo "\nEntrez le numéro de l'ami que vous voulez supprimer ou 0 pour annuler : ";
$choice = trim(fgets(STDIN));
if ($choice === '0') {
echo "Suppression d'ami annulée.\n";
return;
}
$selectedIndex = intval($choice) - 1;
if (!isset($friendList[$selectedIndex])) {
echo "Sélection invalide.\n";
return;
}
$friend = $friendList[$selectedIndex];
if ($model->userMgr->deleteFriend($friend->getId())) { // Supposition que deleteFriend utilise l'ID de l'ami
echo "Ami " . $friend->getPrenom() . " " . $friend->getNom() . " supprimé.\n";
} else {
echo "Problème lors de la suppression, veuillez réessayer plus tard.\n";
}
}
function answerAdd(Model $model) {
echo "\nListe des demandes d'ami en attente :\n";
$friendRequests = $model->userMgr->getCurrentUser()->getRole()->getUsersRequests();
if (empty($friendRequests)) {
echo "Aucune demande d'ami en attente.\n";
return;
}
foreach ($friendRequests as $index => $request) {
echo ($index + 1) . ". Demande de : " . $request->getId() . "\n";
}
echo "\nEntrez le numéro de la demande à répondre ou 0 pour annuler : ";
$choice = trim(fgets(STDIN));
if ($choice === '0') {
echo "Aucune action effectuée.\n";
return;
}
$selectedIndex = intval($choice) - 1;
if (!isset($friendRequests[$selectedIndex])) {
echo "Sélection invalide.\n";
return;
}
/** @var RelationshipRequest $request */
$request = $friendRequests[$selectedIndex];
echo "Répondre à la demande de " . $request->getFromUser() . " " . $request->getToUser() . ". Accepter (oui) ou refuser (non) ? ";
$response = strtolower(trim(fgets(STDIN)));
if ($response === 'oui') {
if ($model->userMgr->respondToFriendRequest($request->getId(),true)) { // Supposition de la méthode acceptFriendRequest
echo $model->userMgr->getCurrentUser()->getRole()->getUsersList()[0];
echo "Demande d'ami acceptée.\n";
} else {
echo "Problème lors de l'acceptation de la demande, veuillez réessayer plus tard.\n";
}
} elseif ($response === 'non') {
if ($model->userMgr->respondToFriendRequest($request->getId(),false)) { // Supposition de la méthode rejectFriendRequest
echo "Demande d'ami refusée.\n";
} else {
echo "Problème lors du refus de la demande, veuillez réessayer plus tard.\n";
}
} else {
echo "Réponse non reconnue. Aucune action effectuée.\n";
}
}
/**
* Fonction permettant à un utilisateur de s'inscrire.
*
* @param DataManager $model La couche d'accès au modèle de données.
* @param Model $model La couche d'accès au modèle de données.
* @return bool Retourne true si l'inscription a réussi, sinon false.
*/
function registerUser(DataManager $model)
function registerUser(Model $model)
{
try {
@ -179,6 +322,9 @@ function registerUser(DataManager $model)
echo "Entrez votre prénom: ";
$prenom = trim(fgets(STDIN));
echo "Entrez votre username: ";
$username = trim(fgets(STDIN));
echo "Entrez votre adresse email: ";
$email = trim(fgets(STDIN));
@ -209,6 +355,7 @@ function registerUser(DataManager $model)
$registrationData = [
'nom' => $nom,
'prenom' => $prenom,
'username' => $username,
'email' => $email,
'sexe' => $sexe,
'taille' => $taille,
@ -225,14 +372,360 @@ function registerUser(DataManager $model)
}
} catch (\Exception $e) {
echo "Erreur lors de l'inscription : " . $e->getMessage() . "\n";
sleep(2);
return false;
}
}
function profileMenu(DataManager $model)
function ArrayAthleteMenu(Model $model)
{
do {
displayManagementArrayAthlete();
$coachChoice = trim(fgets(STDIN));
switch ($coachChoice) {
case '1':
echo "Renseignez le surnom de l'utilisateur : ";
$username = trim(fgets(STDIN));
if($model->coachMgr->addUser($username)){
echo "Ajout avec succès !";
} else {
echo "Le user ne peut pas être ajouter en tant que athlete !";
}
sleep(2);
break;
case '2':
echo "Renseignez le surnom de l'utilisateur : ";
$username = trim(fgets(STDIN));
if($model->coachMgr->removeUser($username)){
echo "Suppression avec succès !";
} else {
echo "Pb suppression ou aucun utilisateur de ce nom !";
}
sleep(2);
break;
case '3':
$usersArray = $model->coachMgr->getUsersList();
if (!empty($usersArray)) {
foreach ($usersArray as $value) {
echo $value->__toString() . "\n";
}
} else {
echo "Aucun utilisateur dans la liste\n";
}
sleep(2);
break;
case '0':
return;
default :
echo "Option invalide. Veuillez réessayer.\n";
sleep(2);
break;
}
} while($coachChoice);
}
function ArrayTrainingMenu(Model $model)
{
do {
displayManagementArrayTraining();
$coachChoice = trim(fgets(STDIN));
switch ($coachChoice) {
case '1':
$existingTrainings = $model->coachMgr->getTrainingsList();
$lastTraining = end($existingTrainings);
$lastTrainingId = $lastTraining ? $lastTraining->getId() : 0;
$newTrainingId = $lastTrainingId + 1;
echo "L'ID de l'entraînement sera automatiquement défini sur : $newTrainingId\n";
$date = new DateTime();
echo "Renseignez la latitude de l'entraînement : ";
$latitude = trim(fgets(STDIN));
echo "Renseignez la longitude de l'entraînement : ";
$longitude = trim(fgets(STDIN));
echo "Renseignez la description de l'entraînement : ";
$description = trim(fgets(STDIN));
$training = new Training($newTrainingId, $date, $latitude, $longitude, $description, null);
if($model->coachMgr->addTraining($training)){
echo "Ajout avec succès !";
} else {
echo "Pb ajout !";
}
sleep(2);
break;
case '2':
echo "Renseignez l'id de l'entrainement : ";
$idTraining = trim(fgets(STDIN));
if($model->coachMgr->removeTraining($idTraining)){
echo "Suppression avec succès !";
} else {
echo "Pb suppression ou aucun entrainement de cet id !";
}
sleep(2);
break;
case '3':
$trainingArray = $model->coachMgr->getTrainingsList();
if (!empty($trainingArray)) {
foreach ($trainingArray as $value) {
echo $value->__toString() . "\n";
}
} else {
echo "Aucun entrainement dans la liste\n";
}
sleep(2);
break;
case '0':
return;
default :
echo "Option invalide. Veuillez réessayer.\n";
sleep(2);
break;
}
} while($coachChoice);
}
function ArrayFriendManagementMenu(Model $model) {
do {
displaySubSocialManagementMenu();
$userChoice = trim(fgets(STDIN));
switch ($userChoice) {
case '3.1': // Voir les demandes d'amitié
$friendRequests = $model->userMgr->getCurrentUser()->getRole()->getUsersRequests();
if (!empty($friendRequests)) {
foreach ($friendRequests as $request) {
echo $request->__toString() . "\n";
}
} else {
echo "Aucune demande d'amitié.\n";
}
sleep(2);
break;
case '3.2': // Répondre une demande d'amitié
answerAdd($model);
break;
case '3.3': // Ajouter un ami
addFriend($model);
sleep(2);
break;
case '3.4': // Supprimer un ami
deleteFriend($model);
sleep(2);
break;
case '0': // Retour au menu principal
return;
default:
echo "Option invalide. Veuillez réessayer.\n";
sleep(2);
break;
}
} while ($userChoice);
}
//function displayCoachMenu()
//{
// clearScreen();
// echo "\n--- Menu Coach ---\n";
// echo "1. Liste des athlètes\n";
// echo "2. Statistiques globales\n";
// echo "3. Analyses par athlète\n";
// echo "4. Gérer la liste de mes athlètes\n";
// // Gérer les athlètes (comprend : Ajouter un athlète, Supprimer un athlète, Consulter les statistiques d'un athlète)
// echo "5. Gérer la liste de mes exercices\n";
// echo "0. Retour au menu principal\n";
// echo "Choisissez une option: ";
//}
function CoachMenu(Model $model)
{
do {
displayCoachMenu();
$coachChoice = trim(fgets(STDIN));
switch ($coachChoice) {
case '1': // echo "1. Liste des athlètes\n";
$arrayUsers = $model->coachMgr->getUsersList();
if (isset($arrayUsers) && !empty($arrayUsers)) {
foreach ($arrayUsers as $value) {
echo $value->__toString() . "\n";
}
} else {
echo "Aucun utilisateur dans la liste\n";
}
sleep(2);
break;
// case '2': // echo "2. Statistiques globales\n";
// $arrayUsers = $model->coachMgr->getUsersList();
//
// if (!empty($arrayUsers)) {
// do {
// clearScreen();
// $cpt = 0;
// foreach ($arrayUsers as $value) {
// echo $cpt . " - " . $value->__toString() . "\n";
// $cpt = $cpt + 1;
// }
//
// echo "Renseignez le numéro de l'utilisateur choisi : ";
// $usernameNumber = trim(fgets(STDIN));
//
// // Vérifier si l'index saisi est valide
// if (isset($arrayUsers[$usernameNumber])) {
// $selectedUser = $arrayUsers[$usernameNumber];
// if (($arrayStats = $model->coachMgr->getStatistics($selectedUser))) {
// foreach ($arrayStats as $value) {
// echo $value->__toString() . "\n";
// }
// } else {
// echo "Pas de statistiques valides présentent !\n";
// }
// } else {
// echo "Numéro d'utilisateur non valide.\n";
// $cpt = 0;
// }
// } while($cpt == 0);
// } else {
// echo "Aucun utilisateur dans la liste.\n";
// }
// sleep(2);
// break;
case '3': // echo "3. Analyses par athlète\n";
$arrayUsers = $model->coachMgr->getUsersList();
if (!empty($arrayUsers)) {
do {
clearScreen();
$cpt = 0;
foreach ($arrayUsers as $value) {
echo $cpt . " - " . $value->__toString() . "\n";
$cpt = $cpt + 1;
}
echo "Renseignez le numéro de l'utilisateur choisi : ";
$usernameNumber = trim(fgets(STDIN));
// Vérifier si l'index saisi est valide
if (isset($arrayUsers[$usernameNumber])) {
$selectedUser = $arrayUsers[$usernameNumber];
if (($arrayStats = $model->coachMgr->getAnalyse($selectedUser))) {
foreach ($arrayStats as $value) {
echo $value->__toString() . "\n";
}
} else {
echo "Pas d'Analyses valides présentent !\n";
}
} else {
echo "Numéro d'utilisateur non valide.\n";
$cpt = 0;
}
} while($cpt == 0);
} else {
echo "Aucun utilisateur dans la liste.\n";
}
sleep(2);
break;
case '4': // echo "4. Gérer la liste de mes athlètes\n";
ArrayAthleteMenu($model);
break;
case '5': // echo "5. Gérer la liste de mes exercices\n";
ArrayTrainingMenu($model);
break;
case '0': // Quitter
return;
default:
echo "Option invalide. Veuillez réessayer.\n";
sleep(2);
break;
}
} while($coachChoice);
}
//function displaySocialManagementMenu()
//{
// clearScreen();
// echo "\n--- Gestion sociale ---\n";
// echo "1. Rechercher des coach\n";
// echo "2. Rechercher des athletes\n";
// echo "3. Gérer la liste d'amis\n";
// // Ajouter des amis
// // Supprimer des amis ...
// echo "4. Options de partage\n";
// echo "0. Retour au menu principal\n";
// echo "Choisissez une option: ";
//}
// TODO athlteMgr
function socialManagementMenu(Model $model) {
do {
displaySocialManagementMenu();
$managementChoice = trim(fgets(STDIN));
switch ($managementChoice) {
case '1':
echo "Renseignez le surnom du coach que vous recherchez : ";
$coachUsername = trim(fgets(STDIN));
$users = $model->userMgr->searchUsersByName($coachUsername);
if (!empty($users)) {
$foundCoaches = false;
foreach ($users as $user) {
if ($user->getRole() instanceof Coach) {
echo $user->__toString();
$foundCoaches = true;
}
}
if (!$foundCoaches) {
echo "Aucun coach de ce nom : $coachUsername\n";
}
} else {
echo "Aucun utilisateur trouvé avec le surnom : $coachUsername\n";
}
sleep(2);
break;
case '2':
echo "Renseignez le surnom de l'athlete que vous recherchez : ";
$athleteUsername = trim(fgets(STDIN));
$users = $model->userMgr->searchUsersByName($athleteUsername);
if (!empty($users)) {
$foundAthletes = false;
foreach ($users as $user) {
if ($user->getRole() instanceof Athlete) {
echo $user->__toString();
$foundAthletes = true;
}
}
if (!$foundAthletes) {
echo "Aucun athlete de ce nom : $athleteUsername\n";
}
} else {
echo "Aucun utilisateur trouvé avec le surnom : $athleteUsername\n";
}
sleep(2);
break;
case '3': // 3. Gérer la liste d'amis
ArrayFriendManagementMenu($model);
return;
case '0': // echo "0. Retour au menu principal\n";
return;
default:
echo "Option invalide. Veuillez réessayer.\n";
sleep(2);
break;
}
} while($managementChoice);
}
function profileMenu(Model $model)
{
do {
displayProfileMenu();
@ -240,20 +733,28 @@ function profileMenu(DataManager $model)
switch ($athleteChoice) {
case '1':
echo "Impossible pour l'instant";
echo $model->userMgr->getCurrentUser();
sleep(2);
break;
case '2':
if($model->athleteMgr->getActivities()) {
foreach ($model->athleteMgr->getActivities() as $activity) {
echo $activity->__toString();
if($model->userMgr->getCurrentUser()->getRole() instanceof Athlete) {
$activities = $model->athleteMgr->getActivities();
if($activities !== null && count($activities) > 0) {
foreach ($activities as $activity) {
echo $activity->__toString();
}
} else {
echo "No activities found";
}
} else {
echo "Aucune activité sur votre profil";
echo "Vous etes pas un athléte";
}
sleep(2);
break;
case '5':
case '3': // Liste d'amis
sleep(2);
break;
case '4': // Importer des données (FIT/GPX/TCX)
echo "Veuillez renseigner le chemin du fichier :\n";
$passFile = trim(fgets(STDIN));
echo "Veuillez renseigner le type d'activité :\n";
@ -282,18 +783,18 @@ while (true) {
$choice = trim(fgets(STDIN));
switch ($choice) {
case '1': // Se connecter
$model->userMgr->login("Doe", "password123");
$loggedIn = true;
case '1': // Se connecter
if($model->userMgr->login("john.doe@example.com", "password123"))
$loggedIn = true;
// if (loginUser($model)) {
// $loggedIn = true;
// }
/* if (loginUser($model)) {
$loggedIn = true;
}*/
break;
case '2': // S'inscrire
$model->userMgr->login("athlete", "hello321");
$loggedIn = true;
if($model->userMgr->login("bruce.lee@example.com", "hello321"))
$loggedIn = true;
// if (registerUser($model)) {
// $loggedIn = true;
// }
@ -307,7 +808,7 @@ while (true) {
echo "Option invalide. Veuillez réessayer.\n";
break;
}
}
}
if ($loggedIn){
while ($loggedIn) {
displayMainMenu();
@ -319,22 +820,27 @@ while (true) {
break;
case '2': // Profil
profileMenu($model);
profileMenu( $model);
break;
case '3': // Analyse de la fréquence cardiaque
displayHeartRateAnalysisMenu();
$analysisChoice = trim(fgets(STDIN));
// TODO: Ajouter la logique pour les options d'analyse ici.
// TODO WEB
break;
case '4': // Gestion sociale
displaySocialManagementMenu($model);
socialManagementMenu($model);
// TODO: Ajouter la logique pour les options de gestion sociale ici.
break;
case '5': // Athlètes (pour les Coachs seulement)
displayCoachMenu();
case '5': // Coach
if($model->userMgr->getCurrentUser()->getRole() instanceof \Model\Coach) {
CoachMenu($model);
} else {
echo "Vous n'avez pas accès à cette section ! (il faut etre coach)\n";
sleep(2);
}
break;
case '6': // Paramètres
@ -344,6 +850,7 @@ while (true) {
break;
case '7': // Notifications
echo "Affichage des notifications...\n";
break;

@ -0,0 +1,86 @@
<?php
namespace Data\Core;
use Model\User;
use Model\Athlete;
use Model\CoachAthlete;
use Repository\IUserRepository;
use Shared\IHashPassword;
class AuthService implements IAuthService {
private IUserRepository $userRepository;
private IHashPassword $passwordHacher;
private ?User $currentUser = null;
public function __construct(IUserRepository $userRepository, IHashPassword $passwordHacher) {
$this->userRepository = $userRepository;
$this->passwordHacher = $passwordHacher;
}
public function login(string $email, string $password): bool {
$user = $this->userRepository->getItemByEmail($email);
if ($user === null || !$this->validatePassword($password, $user->getPasswordHash())) {
return false;
}
$this->currentUser = $user;
// Add session handling logic here
return true;
}
public function register(string $email, string $password, array $data): bool {
if ($this->userRepository->getItemByEmail($email)) {
throw new \Exception('User already exists');
}
$hashedPassword = $this->passwordHacher->hashPassword($password);
$prenom = $data['prenom'];
$username = $data['username'];
$nom = $data['nom'];
$email = $data['email'];
$sexe = $data['sexe'];
$taille = $data['taille'];
$poids = $data['poids'];
$dateNaissance = $data['dateNaissance'] ;
$roleName = $data['roleName'];
$role = null;
if($roleName == "Coach"){
$role = new CoachAthlete();
}
else if($roleName == "Athlete"){
$role = new Athlete();
}
// Create a new user instance (you should expand on this with more data as needed)
$user = new User(
random_int(0, 100),
$nom,
$prenom,
$username,
$email,
$hashedPassword,
$sexe,
$taille,
$poids,
$dateNaissance,
//should use reflexion
$role
);
$this->userRepository->addItem($user);
$this->currentUser = $user;
// Add session handling logic here
return true;
}
public function logout(): void {
$this->currentUser = null;
// Add session handling logic here
}
public function getCurrentUser(): ?User {
return $this->currentUser;
}
private function validatePassword(string $password, string $hash): bool {
// Implement password validation logic (e.g., using password_verify if using bcrypt)
}
}

@ -25,8 +25,8 @@
$this->cookie = $maj;
setcookie('preferences', $maj);
}
} catch (Exception $e){
throw new ValueError;
} catch (\Exception $e){
throw new \ValueError;
}
}

@ -8,15 +8,27 @@ use Model\User;
* It's recommended to keep this interface focused on authentication-related functionality.
*/
interface IAuthService {
/**
* Get the currently authenticated user.
*
* This method returns an instance of the User model representing
* the currently authenticated user. If no user is authenticated,
* the behavior of this method is implementation-dependent: it could return null,
* throw an exception, etc.
*
* @return User|null The currently authenticated user, or null if no user is authenticated.
*/
public function getCurrentUser(): ?User;
/**
* Authenticate a user.
*
* @param string $username The username of the user.
* @param string $emailUser The emailUser of the user.
* @param string $password The password of the user.
*
* @return ?User True if authentication is successful, false otherwise.
*/
public function login(string $username, string $password): bool;
public function login(string $emailUser, string $password): bool;
/**
* Register a new user.
@ -34,6 +46,6 @@ interface IAuthService {
*
* @return void
*/
public function logoutUser(): void;
public function logoutUser(): bool;
}

@ -20,93 +20,11 @@ use Stub\TrainingRepository;
*/
class Athlete extends Role {
// Attributs spécifiques à l'athlète si nécessaire
private array $statsList = [];
// private array $statsList = [];
private array $activityList = [];
private array $dataSourcesList = [];
// private array $dataSourcesList = [];
/**
* Constructeur de la classe Athlete.
*
* @param TrainingRepository|null $trainingRepository Le repository des entraînements (optionnel).
*/
public function __construct(?TrainingRepository $trainingRepository) {
$this->trainingRepository = $trainingRepository;
}
/**
* Obtient l'instance d'athlète.
*
* @return Athlete L'instance d'athlète.
*/
public function getAthlete(): Athlete {
return $this;
}
/**
* Obtient la liste des statistiques de l'athlète.
*
* @return array|null La liste des statistiques de l'athlète, ou null si aucune.
*/
public function getStatistic(): ?array {
return $this->statsList;
}
/**
* Obtient la liste des sources de données de l'athlète.
*
* @return array|null La liste des sources de données de l'athlète, ou null si aucune.
*/
public function getDataSource(): ?array {
return $this->dataSourcesList;
}
/**
* Obtient la liste des utilisateurs associés à l'athlète.
*
* @return array La liste des utilisateurs associés à l'athlète.
*/
public function getUsersList(): array {
return $this->usersList;
}
/**
* Obtient un utilisateur spécifique associé à l'athlète.
*
* @param User $user L'utilisateur recherché.
* @return User L'utilisateur recherché.
*/
public function getUserList(User $user): User {
return $user;
}
/**
* Obtient le repository des entraînements de l'athlète.
*
* @return TrainingRepository|null Le repository des entraînements de l'athlète, ou null.
* @throws NotImplementedException Si la méthode n'est pas implémentée.
*/
public function getTraining(): ?TrainingRepository {
throw new NotImplementedException("Pas de get Training");
}
/**
* Obtient la liste des entraînements de l'athlète.
*
* @param Training $training L'entraînement recherché.
* @return Training|null L'entraînement recherché, ou null si non trouvé.
*/
public function getTrainingList(Training $training): ?Training {
return $training;
}
/**
* Modifie la liste des entraînements de l'athlète.
*
* @param array $newTrainingsList La nouvelle liste des entraînements.
*/
public function setTrainingsList(array $newTrainingsList): void {
$this->trainingRepository->setTrainingsList($newTrainingsList);
}
/**
* Obtient la liste des activités de l'athlète.
@ -117,72 +35,6 @@ class Athlete extends Role {
return $this->activityList;
}
/**
* Vérifie si un utilisateur peut être ajouté en tant qu'athlète.
*
* @param User $user L'utilisateur à vérifier.
* @return bool True si l'utilisateur peut être ajouté, sinon false.
*/
public function CheckAdd(User $user): bool {
if ($user instanceof Athlete) {
return true;
} else {
return false;
}
}
/**
* Vérifie si un entraînement peut être ajouté à l'athlète.
*
* @param Training $training L'entraînement à vérifier.
* @return bool False (toujours, car l'athlète ne peut pas avoir d'entraînement).
*/
public function CheckAddTraining(Training $training): bool {
return false;
}
/**
* Ajoute un utilisateur à la liste des utilisateurs associés à l'athlète.
*
* @param User $user L'utilisateur à ajouter.
* @return bool True si l'ajout est réussi, sinon false.
*/
public function addUser(User $user): bool {
if ($this->CheckAdd($user)) {
$this->usersList[] = $user;
return true;
}
return false;
}
/**
* Supprime un utilisateur de la liste des utilisateurs associés à l'athlète.
*
* @param User $user L'utilisateur à supprimer.
* @return bool True si la suppression est réussie, sinon false.
*/
public function removeUser(User $user): bool {
if ($this->CheckAdd($user)) {
$this->usersList[] = $user;
return true;
}
return false;
}
/**
* Supprime un utilisateur de la liste des utilisateurs associés à l'athlète (méthode fictive).
*
* @param User $user L'utilisateur à supprimer.
* @return bool True si la suppression est réussie, sinon false.
*/
public function delUser(User $user): bool {
if ($this->CheckAdd($user)) {
$this->usersList[] = null;
return true;
}
return false;
}
/**
* Ajoute une activité à la liste des activités de l'athlète.
*
@ -197,19 +49,16 @@ class Athlete extends Role {
return false;
}
public function getTrainingsList(): ?array
{
// TODO: Implement getTrainingsList() method.
}
public function addTraining(Training $training): bool
public function CheckAdd(User $user): bool
{
// TODO: Implement addTraining() method.
if($user->getRole() instanceof Athlete){
return true;
} else {
return false;
}
}
public function removeTraining(Training $training): bool
{
// TODO: Implement removeTraining() method.
}
}
?>

@ -20,98 +20,90 @@ use Stub\TrainingRepository;
abstract class Role {
protected int $id;
protected array $usersList = [];
protected ?TrainingRepository $trainingRepository;
/**
* Constructeur abstrait de la classe Role.
*
* @param TrainingRepository|null $trainingRepository Le repository des entraînements (optionnel).
*/
public abstract function __construct(?TrainingRepository $trainingRepository);
protected array $usersRequests = [];
protected array $trainingList = [];
// Attributs spécifiques au Coach si nécessaire
/**
* Obtient la liste des utilisateurs associés au rôle.
*
* @return array|null La liste des utilisateurs associés au rôle, ou null si aucune.
*/
public abstract function getUsersList(): ?array;
/**
* Obtient un utilisateur spécifique associé au rôle.
*
* @param User $user L'utilisateur recherché.
* @return User L'utilisateur recherché.
*/
public abstract function getUserList(User $user): User;
public function getUsersList(): ?array
{
return $this->usersList;
}
public function getUsersRequests(): ?array
{
return $this->usersRequests;
}
public function addUsersRequests(RelationshipRequest $request): void
{
$this->usersRequests [] = $request;
}
public function removeRequest(RelationshipRequest $req): bool
{
/**
* Obtient le repository des entraînements associé au rôle.
*
* @return TrainingRepository|null Le repository des entraînements associé au rôle, ou null.
*/
public abstract function getTraining(): ?TrainingRepository;
/**
* Obtient la liste des entraînements associés au rôle.
*
* @return array|null La liste des entraînements associés au rôle, ou null si aucune.
*/
public abstract function getTrainingsList(): ?array;
/**
* Obtient un entraînement spécifique associé au rôle.
*
* @param Training $training L'entraînement recherché.
* @return Training|null L'entraînement recherché, ou null si non trouvé.
*/
public abstract function getTrainingList(Training $training): ?Training;
$key = array_search($req, $this->usersRequests);
if ($key !== false) {
array_splice($this->usersRequests, $key, 1);
return true;
}
return false;
}
/**
* Vérifie si un utilisateur peut être ajouté au rôle.
*
* @param User $user L'utilisateur à vérifier.
* @return bool True si l'utilisateur peut être ajouté, sinon false.
*/
public abstract function CheckAdd(User $user): bool;
/**
* Vérifie si un entraînement peut être ajouté au rôle.
*
* @param Training $training L'entraînement à vérifier.
* @return bool True si l'entraînement peut être ajouté, sinon false.
*/
public abstract function CheckAddTraining(Training $training): bool;
public abstract function CheckAdd(User $user) : bool;
/**
* Ajoute un utilisateur à la liste des utilisateurs associés au rôle.
*
* @param User $user L'utilisateur à ajouter.
* @return bool True si l'ajout est réussi, sinon false.
*/
public abstract function addUser(User $user): bool;
public function addUser(User $user): bool
{
if($this->CheckAdd($user)){
array_push($this->usersList, $user);
return true;
}
return false;
}
/**
* Supprime un utilisateur de la liste des utilisateurs associés au rôle.
*
* @param User $user L'utilisateur à supprimer.
* @return bool True si la suppression est réussie, sinon false.
*/
public abstract function removeUser(User $user): bool;
public function removeUser(User $user): bool
{
if($this->CheckAdd($user)){
$key = array_search($user, $this->usersList);
if ($key !== false) {
array_splice($this->usersList, $key, 1);
return true;
}
}
return false;
}
/**
* Ajoute un entraînement à la liste des entraînements associés au rôle.
*
* @param Training $training L'entraînement à ajouter.
* @return bool True si l'ajout est réussi, sinon false.
*/
public abstract function addTraining(Training $training): bool;
/**
* Supprime un entraînement de la liste des entraînements associés au rôle.
*
* @param Training $training L'entraînement à supprimer.
* @return bool True si la suppression est réussie, sinon false.
*/
public abstract function removeTraining(Training $training): bool;
public function addTraining(Training $training)
{
$this->trainingList [] = $training;
return true;
}
public function getTrainingsList(): array
{
return $this->trainingList;
}
}
?>

@ -27,39 +27,35 @@ class User {
private float $poids;
private \DateTime $dateNaissance;
private Role $role;
protected array $notifications = [];
/**
* Constructeur de la classe User.
*
* @param int $id L'identifiant de l'utilisateur.
* @param string $username Le nom d'utilisateur de l'utilisateur.
* @param string $nom Le nom de l'utilisateur.
* @param string $prenom Le prénom de l'utilisateur.
* @param string $email L'adresse e-mail de l'utilisateur.
* @param string $motDePasse Le mot de passe haché de l'utilisateur.
* @param string $sexe Le sexe de l'utilisateur.
* @param float $taille La taille de l'utilisateur.
* @param float $poids Le poids de l'utilisateur.
* @param \DateTime $dateNaissance La date de naissance de l'utilisateur.
* @param Role $role Le rôle de l'utilisateur.
* @return array
*/
public function getNotifications(): array
{
return $this->notifications;
}
/**
* @param int $id
* @param string $nom
* @param string $prenom
* @param string $username
* @param string $email
* @param string $motDePasse
* @param string $sexe
* @param float $taille
* @param float $poids
* @param \DateTime $dateNaissance
* @param \Model\Role $role
*/
public function __construct(
int $id,
String $username,
string $nom,
string $prenom,
string $email,
string $motDePasse,
string $sexe,
float $taille,
float $poids,
\DateTime $dateNaissance,
Role $role
) {
public function __construct(int $id, string $nom, string $prenom, string $username, string $email, string $motDePasse, string $sexe, float $taille, float $poids, \DateTime $dateNaissance, Role $role)
{
$this->id = $id;
$this->username = $username;
$this->nom = $nom;
$this->prenom = $prenom;
$this->username = $username;
$this->email = $email;
$this->motDePasse = $motDePasse;
$this->sexe = $sexe;
@ -69,6 +65,16 @@ class User {
$this->role = $role;
}
public function addNotification($notification): void {
$this->notifications[] = $notification;
}
// Method to delete a notification by its index
public function deleteNotification($index): void {
if (array_key_exists($index, $this->notifications)) {
unset($this->notifications[$index]);
}
}
/**
* Obtient l'identifiant de l'utilisateur.
*
@ -77,38 +83,35 @@ class User {
public function getId(): int {
return $this->id;
}
/**
* Définit l'identifiant de l'utilisateur.
*
* @param int $id Le nouvel identifiant de l'utilisateur.
* @return string
*/
public function setId(int $id): void {
$this->id = $id;
public function getUsername(): string
{
return $this->username;
}
/**
* Obtient le nom d'utilisateur de l'utilisateur.
*
* @return string Le nom d'utilisateur de l'utilisateur.
* @param string $username
*/
public function getUsername(): string {
return $this->username;
public function setUsername(string $username): void
{
$this->username = $username;
}
/**
* Définit le nom d'utilisateur de l'utilisateur.
* Définit l'identifiant de l'utilisateur.
*
* @param string $username Le nouveau nom d'utilisateur de l'utilisateur.
* @param int $id Le nouvel identifiant de l'utilisateur.
*/
public function setUsername(string $username): void {
$this->username = $username;
public function setId(int $id): void {
$this->id = $id;
}
/**
* Obtient le nom de l'utilisateur.
* Obtient le nom d'utilisateur de l'utilisateur.
*
* @return string Le nom de l'utilisateur.
* @return string Le nom d'utilisateur de l'utilisateur.
*/
public function getNom(): string {
return $this->nom;
@ -283,8 +286,8 @@ class User {
*
* @return string La représentation textuelle de l'utilisateur.
*/
public function __toString(): string {
return "Utilisateur [ID: {$this->id}, Nom: {$this->nom}, Prénom: {$this->prenom}, Email: {$this->email}]";
public function __toString() {
return "Athlete [ID: {$this->id}, Username : $this->username, Nom: {$this->nom}, Prénom: {$this->prenom}, Email: {$this->email}]";
}
}
?>

@ -13,6 +13,7 @@ namespace Manager;
use adriangibbons\phpFITFileAnalysis;
use Exception;
use Model\Activity;
use Network\IAuthService;
use Stub\AuthService;
/**
@ -21,14 +22,17 @@ use Stub\AuthService;
*/
class ActivityManager
{
private AuthService $authService;
/**
* @var AuthService|IAuthService
*/
private IAuthService $authService;
/**
* Constructeur de la classe ActivityManager.
*
* @param AuthService $authService Le service d'authentification utilisé pour vérifier l'utilisateur actuel.
* @param IAuthService $authService Le service d'authentification utilisé pour vérifier l'utilisateur actuel.
*/
public function __construct(AuthService $authService)
public function __construct(DataManager $dataManager,IAuthService $authService)
{
$this->authService = $authService;
}
@ -148,7 +152,7 @@ class ActivityManager
);
// Ajout de l'activité et enregistrement du fichier FIT en JSON
if ($this->authService->currentUser->getRole()->addActivity($newActivity) && $this->saveFitFileToJSON($monFichierFit)) {
if ($this->authService->getCurrentUser()->getRole()->addActivity($newActivity) && $this->saveFitFileToJSON($monFichierFit)) {
return true;
}
} catch (\Exception $e) {

@ -10,6 +10,7 @@
*/
namespace Manager;
use Network\IAuthService;
use Stub\AuthService;
/**
@ -17,16 +18,18 @@ use Stub\AuthService;
* @brief Classe pour gérer les opérations liées aux athlètes.
*/
class AthleteManager {
private AuthService $authService;
private IAuthService $authService;
private DataManager $dataManager;
/**
* Constructeur de la classe AthleteManager.
*
* @param AuthService $authService Le service d'authentification utilisé pour vérifier l'utilisateur actuel.
*/
function __construct(AuthService $authService)
public function __construct(DataManager $dataManager,IAuthService $authService)
{
$this->authService = $authService;
$this->dataManager = $dataManager;
}
/**
@ -35,8 +38,8 @@ class AthleteManager {
* @return array|null Retourne un tableau d'objets Activity en cas de succès, sinon null.
*/
public function getActivities(): ?array {
if ($this->authService->currentUser && $this->authService->currentUser->getRole()->getActivities()) {
return $this->authService->currentUser->getRole()->getActivities();
if ($this->authService->getCurrentUser() && $this->authService->getCurrentUser()->getRole()->getActivities()) {
return $this->authService->getCurrentUser()->getRole()->getActivities();
}
return null;
}

@ -1,11 +1,16 @@
<?php
namespace Manager;
abstract class DataManager {
public $userMgr;
public $activityMgr;
public $athleteMgr;
use Repository\INotificationRepository;
use Repository\IRelationshipRequestRepository;
use Repository\ITrainingRepository;
use Repository\IUserRepository;
abstract class DataManager {
public IUserRepository $userRepository;
public IRelationshipRequestRepository $relationshipRequestRepository;
public ITrainingRepository $trainingRepository;
public INotificationRepository $notificationRepository;
}
?>

@ -11,27 +11,37 @@
namespace Manager;
use Model\Athlete;
use Model\Coach;
use Model\RelationshipRequest;
use Model\User;
use Network\IAuthService;
use Network\IFriendRequestService;
use Shared\Validation;
use Stub\AuthService;
use Stub\UserRepository;
/**
* @class UserManager
* @brief Classe pour gérer les opérations liées aux utilisateurs.
*/
class UserManager
{
private AuthService $authService;
public User $currentUser;
private IAuthService $authService;
/**
* Constructeur de la classe UserManager.
*
* @param AuthService $authService Le service d'authentification utilisé pour gérer les utilisateurs.
*/
public function __construct(AuthService $authService)
private ?User $currentUser;
private DataManager $dataManager;
private IFriendRequestService $relationshipService;
public function __construct(DataManager $dataManager, IAuthService $authService, IFriendRequestService $relationshipService)
{
$this->authService = $authService;
$this->dataManager = $dataManager;
$this->relationshipService = $relationshipService;
}
public function getCurrentUser(): ?User
{
return $this->currentUser;
}
/**
@ -42,18 +52,117 @@ class UserManager
* @return bool Retourne true en cas de connexion réussie, sinon false.
* @throws \Exception En cas d'erreur dans les informations d'identification.
*/
public function login($loginUser, $passwordUser): bool
public function login($emailUser, $passwordUser): bool
{
// Validate data format
if (!Validation::val_email($emailUser)) {
// The email is not valid
return false;
}
if (!Validation::val_password($passwordUser)) {
// The email is not valid
return false;
}
if ($this->authService->login($emailUser, $passwordUser)) {
$this->currentUser = $this->authService->getCurrentUser();
// Check if the current user is correctly set
if ($this->currentUser === null) {
return false;
}
return true;
} else {
// Handle unsuccessful login (e.g., log error, throw exception, etc.)
return false;
}
}
public function addFriend(string $newFriend): bool
{
if (!Validation::val_string($passwordUser) || !Validation::val_string($loginUser))
throw new \Exception("Erreur dans les informations d'identification.");
$newFriend = $this->dataManager->userRepository->getItemByName($newFriend, 0, 1);
if ($newFriend === null) {
throw new \Exception("User not found.");
}
if ($this->authService->login($loginUser, $passwordUser)) {
$this->currentUser = $this->authService->currentUser;
if (in_array($newFriend, $this->currentUser->getRole()->getUsersList())) {
throw new \Exception("Already friend");
}
var_dump("====================1=========================");
if($this->relationshipService->sendRequest($this->currentUser, $newFriend)){
return true;
};
return false;
}
public function respondToFriendRequest(int $requestId, bool $choice): bool
{
foreach ($this->currentUser->getRole()->getUsersRequests() as $key => $friendRequest) {
/** @var RelationshipRequest $friendRequest */
if ($friendRequest->getId() === $requestId) {
/** @var User $userToAdd */
$userToAdd = $this->dataManager->userRepository->getItemById($friendRequest->getToUser());
if ($userToAdd === null) {
throw new \Exception("User not found with ID: " . $friendRequest->getFromUser());
}
if ($choice) {
try {
if($this->currentUser->getRole()->addUser($userToAdd)){
$this->dataManager->userRepository->addFriend($this->currentUser->getId(),$userToAdd->getId());
$this->relationshipService->acceptRequest($friendRequest);
$this->currentUser->getRole()->removeRequest($friendRequest);
};
}catch (\Exception $e){
$this->currentUser->getRole()->removeUser($userToAdd);
throw new \Exception("Failed to add friend" . $userToAdd->getUsername() );
}
} else {
$this->relationshipService->declineRequest($friendRequest);
}
return true;
}
}
return false;
}
public function searchUsersByName(string $name): array
{
return $this->dataManager->userRepository->getItemsByName($name, 0, 10);
}
public function getFriends(): array{
return $this->currentUser->getRole()->getUsersList();
}
// NEED TO PERSIST
public function deleteFriend(int $id): bool
{
/** @var User $userToRemove */
$userToRemove = $this->dataManager->userRepository->getItemById($id);
if ($userToRemove === null) {
throw new \Exception("User not found with ID: " . $id);
}
if (!$this->currentUser->getRole()->removeUser($userToRemove)) {
throw new \Exception("User with ID: " . $id . " is not in the current user's friends list.");
}
try {
$this->dataManager->userRepository->deleteFriend($this->currentUser->getId(),$userToRemove->getId() );
}catch (\Exception $e){
throw new \Exception("Failed to delete friend" . $userToRemove->getUsername() );
}
return true;
}
// NEED TO PERSIST
/**
* Enregistre un nouvel utilisateur avec les informations fournies.
*
@ -65,33 +174,24 @@ class UserManager
*/
public function register($loginUser, $passwordUser, $data): bool
{
// Validation des champs
$fieldsToValidate = [
'nom' => 'Nom non valide',
'prenom' => 'Prénom non valide',
'taille' => 'Taille non valide',
'poids' => 'Poids non valide',
];
foreach ($fieldsToValidate as $fieldName => $errorMessage) {
if (!Validation::val_string($data[$fieldName])) {
throw new \Exception($errorMessage);
}
}
// foreach ($data as $entry) {
// $isValid = Validation::val_string($entry);
// if (!$isValid) {
// throw new \Exception( "Entry '$entry' is not a valid string.");
// }
// }
// Validation du rôle
$roleName = $data['roleName'];
if ($roleName !== "Athlete" && $roleName !== "Coach") {
throw new \Exception("Rôle non valide");
}
// Validation du sexe
if ($data['sexe'] !== "M" && $data['sexe'] !== "H") {
throw new \Exception("Sexe non valide");
}
// Enregistrement de l'utilisateur
if ($this->authService->register($loginUser, $passwordUser, $data)) {
$this->currentUser = $this->authService->getCurrentUser();
return true;
}
return false;
@ -109,5 +209,6 @@ class UserManager
}
return false;
}
}
?>

@ -6,7 +6,7 @@ interface IGenericRepository
public function getItemById(int $id);
public function getNbItems(): int;
public function getItems(int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): array;
public function getItemsByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): ?array;
public function getItemsByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): array;
public function getItemByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false);
public function updateItem($oldItem, $newItem) : void;
public function addItem($item) : void;

@ -2,7 +2,7 @@
namespace Repository;
interface ITrainingRepository extends IGenericRepository {
}
interface ITrainingRepository extends IGenericRepository
{
?>
}

@ -2,6 +2,9 @@
namespace Repository;
interface IUserRepository extends IGenericRepository {
}
public function addFriend(int $user1,int $user2);
public function deleteFriend(int $user1,int $user2);
}
?>

@ -28,7 +28,7 @@ use Stub\UserRepository;
* @date YYYY-MM-DD
* @author OpenAI
*/
class StubData extends DataManager {
class StubData extends DataManager{
/**
* @brief Constructeur de la classe StubData.
* @details Initialise les dépôts, les services d'authentification et les gestionnaires nécessaires.
@ -37,21 +37,11 @@ class StubData extends DataManager {
* @date YYYY-MM-DD
* @author OpenAI
*/
public function __construct()
{
// Initialisation du dépôt d'utilisateurs
$userRepository = new UserRepository();
// Initialisation du service d'authentification
$authService = new AuthService($userRepository, new HashPassword());
// Initialisation du gestionnaire d'utilisateurs
$this->userMgr = new UserManager($authService);
// Initialisation du gestionnaire d'athlètes
$this->athleteMgr = new AthleteManager($authService);
// Initialisation du gestionnaire d'activités
$this->activityMgr = new ActivityManager($authService);
public function __construct(){
$this->userRepository = new UserRepository();
$this->relationshipRequestRepository = new RelationshipRequestRepository();
$this->trainingRepository = new TrainingRepository();
$this->notificationRepository = new NotificationRepository();
}
}

@ -12,6 +12,7 @@
namespace Stub;
use Model\Athlete;
use Model\CoachAthlete;
use Model\User;
use Repository\IUserRepository;
@ -26,14 +27,11 @@ class UserRepository implements IUserRepository {
* Constructeur de la classe UserRepository.
*/
public function __construct() {
// Initialisation de quelques utilisateurs pour des besoins de démonstration.
// $this->users[] = new User(1, "Doe", "Doe", "John", "john.doe@example.com", "password123", 'M', 1.80, 75, new \DateTime("1985-05-15"), new CoachAthlete($training));
$this->users[] = new User(2, "Smith", "Smith", "Jane", "jane.smith@example.com", "secure456", 'F', 1.65, 60, new \DateTime("1990-03-10"), new Athlete(null));
// $this->users[] = new User(3, "Martin", "Martin", "Paul", "paul.martin@example.com", "super789", 'M', 1.75, 68, new \DateTime("1988-08-20"), new CoachAthlete($training));
$this->users[] = new User(4, "Brown", "Brown", "Anna", "anna.brown@example.com", "test000", 'F', 1.70, 58, new \DateTime("1992-11-25"), new Athlete(null));
$this->users[] = new User(5, "Lee", "Lee", "Bruce", "bruce.lee@example.com", "hello321", 'M', 1.72, 70, new \DateTime("1970-02-05"), new Athlete(null));
// $this->users[] = new User(6, "c", "c", "c", "coach@example.com", "c1", 'M', 1.80, 75, new \DateTime("1985-05-15"), new CoachAthlete($training));
$this->users[] = new User(7, "athlete", "athlete", "a", "athlete@example.com", "hello321", 'F', 1.55, 67, new \DateTime("1999-09-30"), new Athlete(null));
$this->users[] = new User(1, "Doe", "John", "Doe","john.doe@example.com", "password123", 'M', 1.80, 75, new \DateTime("1985-05-15"), new CoachAthlete());
$this->users[] = new User(2, "Smith", "Jane","Smith", "jane.smith@example.com", "secure456", 'F', 1.65, 60, new \DateTime("1990-03-10"), new Athlete());
$this->users[] = new User(3, "Martin", "Paul","Martin", "paul.martin@example.com", "super789", 'M', 1.75, 68, new \DateTime("1988-08-20"), new CoachAthlete());
$this->users[] = new User(4, "Brown", "Anna","Brown", "anna.brown@example.com", "test000", 'F', 1.70, 58, new \DateTime("1992-11-25"), new Athlete());
$this->users[] = new User(5, "Lee", "Bruce","Lee", "bruce.lee@example.com", "hello321", 'M', 1.72, 70, new \DateTime("1970-02-05"), new Athlete());
}
/**
@ -80,27 +78,17 @@ class UserRepository implements IUserRepository {
return null;
}
// ... (Les autres méthodes)
/**
* Obtient le nombre total d'utilisateurs dans le dépôt.
*
* @return int Le nombre total d'utilisateurs.
*/
public function GetNbItems(): int {
public function getNbItems(): int {
return count($this->users);
}
/**
* Obtient un tableau d'utilisateurs en fonction des paramètres spécifiés.
*
* @param int $index L'indice de départ dans le tableau.
* @param int $count Le nombre d'utilisateurs à récupérer.
* @param string|null $orderingPropertyName Le nom de la propriété pour l'ordonnancement (facultatif).
* @param bool $descending Indique si l'ordonnancement doit être effectué en ordre descendant (facultatif, par défaut false).
* @return array Le tableau d'utilisateurs.
*/
public function GetItems(int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): array {
public function getItems(int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): array {
// Cette méthode est un exemple simple, on ne gère pas l'ordonnancement ici
return array_slice($this->users, $index, $count);
}
@ -115,9 +103,9 @@ class UserRepository implements IUserRepository {
* @param bool $descending Indique si l'ordonnancement doit être effectué en ordre descendant (facultatif, par défaut false).
* @return array|null Le tableau d'utilisateurs filtré, ou null s'il n'y a aucun utilisateur correspondant.
*/
public function GetItemsByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): ?array {
public function getItemsByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): array {
$filteredUsers = array_filter($this->users, function ($user) use ($substring) {
return strpos(strtolower($user->getNom()), strtolower($substring)) !== false || strpos(strtolower($user->getPrenom()), strtolower($substring)) !== false;
return str_contains(strtolower($user->getNom()), strtolower($substring)) || str_contains(strtolower($user->getPrenom()), strtolower($substring));
});
return array_slice($filteredUsers, $index, $count);
}
@ -132,9 +120,9 @@ class UserRepository implements IUserRepository {
* @param bool $descending Indique si l'ordonnancement doit être effectué en ordre descendant (facultatif, par défaut false).
* @return User|null L'utilisateur filtré, ou null s'il n'y a aucun utilisateur correspondant.
*/
public function GetItemByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): ?User {
public function getItemByName(string $substring, int $index, int $count, ?string $orderingPropertyName = null, bool $descending = false): ?User {
$filteredUsers = $this->GetItemsByName($substring, $index, $count, $orderingPropertyName, $descending);
return isset($filteredUsers[0]) ? $filteredUsers[0] : null;
return $filteredUsers[0] ?? null;
}
/**
* Met à jour un utilisateur existant dans le dépôt.
@ -143,8 +131,8 @@ class UserRepository implements IUserRepository {
* @param User $newItem La nouvelle instance de l'utilisateur.
* @return void
*/
public function UpdateItem($oldItem, $newItem): void {
$index = array_search($oldItem, $this->users);
public function updateItem($oldUser, $newUser): void {
$index = array_search($oldUser, $this->users);
if ($index !== false) {
$this->users[$index] = $newItem;
}
@ -156,8 +144,8 @@ class UserRepository implements IUserRepository {
* @param User $user L'instance de l'utilisateur à ajouter.
* @return void
*/
public function AddItem($item): void {
$this->users[] = $item;
public function addItem( $user): void {
$this->users[] = $user;
}
/**
@ -166,13 +154,24 @@ class UserRepository implements IUserRepository {
* @param User $user L'instance de l'utilisateur à supprimer.
* @return bool Retourne true si la suppression a réussi, sinon false.
*/
public function DeleteItem($item): bool {
$index = array_search($item, $this->users);
public function deleteItem( $user): bool {
$index = array_search($user, $this->users);
if ($index !== false) {
unset($this->users[$index]);
return true;
}
return false;
}
public function addFriend(int $user1, int $user2)
{
return true;
}
public function deleteFriend(int $user1, int $user2)
{
return true;
}
}
?>

@ -1,32 +1,27 @@
<?php
namespace Stub;
use Model\Coach;
use Model\Athlete;
use Model\CoachAthlete;
use Model\User;
use Repository\IUserRepository;
use Shared\Exception\NotImplementedException;
use Network\IAuthService;
use Shared\IHashPassword;
use Stub\UserRepository;
class AuthService implements IAuthService {
private $userRepository;
private $passwordHasher;
private IUserRepository $userRepository;
private IHashPassword $passwordHacher;
private ?User $currentUser;
public ?User $currentUser = null ;
public function __construct(UserRepository $userRepository, IHashPassword $passwordHasher) {
public function __construct(UserRepository $userRepository, IHashPassword $passwordHacher) {
$this->userRepository = $userRepository;
$this->passwordHasher = $passwordHasher;
$this->passwordHacher = $passwordHacher;
}
public function getUserRepository():UserRepository {
return $this->userRepository;
}
public function login(string $username,string $password): bool {
$user = $this->userRepository->GetItemByName($username,0,1);
if ($user == null || !$user instanceof User) {
public function login(string $emailUser,string $password): bool {
$user = $this->userRepository->getItemByEmail($emailUser);
if (!$user instanceof User) {
throw new \Exception('Unable to find user with that name');
}
if ($user->isValidPassword($password)) {
@ -35,19 +30,19 @@ class AuthService implements IAuthService {
}
return false;
}
public function register(string $loginUser, string $password, $data): bool
public function register(string $username, string $password, $data): bool
{
$hashedPassword = $this->passwordHasher->hashPassword($password);
$existingUser = $this->userRepository->getItemByEmail($loginUser);
$hashedPassword = $this->passwordHacher->hashPassword($password);
$existingUser = $this->userRepository->getItemByEmail($username);
if ($existingUser != null || $existingUser instanceof User ) {
throw new \Exception('User already exists');
}
$username = $data['username'];
$prenom = $data['prenom'];
$username = $data['username'];
$nom = $data['nom'];
$email = $data['email'];
$sexe = $data['sexe'];
@ -64,9 +59,9 @@ class AuthService implements IAuthService {
}
$user = new User(
random_int(0, 100),
$username,
$nom,
$prenom,
$username,
$email,
$hashedPassword,
$sexe,
@ -76,16 +71,21 @@ class AuthService implements IAuthService {
//should use reflexion
$role
);
$this->userRepository->addItem($user);
$this->currentUser = $user;
return true;
}
public function logoutUser(): void
public function logoutUser(): bool
{
$this->currentUser = null;
return true;
}
public function getCurrentUser(): ?User
{
print("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! logout method not implemented !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
return;
return $this->currentUser;
}
}

@ -56,7 +56,7 @@ final class Validation {
* @throws Exception Si le mot de passe n'est pas valide.
*/
public static function val_password(string $password) : bool {
if ($password === null) {
if (!isset($password)) {
throw new Exception("Le mot de passe ne peut être vide.");
} else {
if (!preg_match('/^.{6,}$/', $password)) {
@ -65,6 +65,24 @@ final class Validation {
return Validation::val_string($password);
}
}
/**
* Valide un mail.
*
* @param string $email Le mail à valider.
* @return bool True si le mail est valide, sinon false.
* @throws Exception Si le mail n'est pas valide.
*/
public static function val_email(string $email) : bool {
if (!isset($email)) {
throw new Exception("L'adresse e-mail ne peut être vide.");
} else {
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
throw new Exception("L'adresse e-mail n'est pas valide.");
}
return true;
}
}
/**
* Valide un booléen.

@ -22,4 +22,4 @@ if (PHP_VERSION_ID < 50600) {
require_once __DIR__ . '/composer/autoload_real.php';
return ComposerAutoloaderInitb084bad56d99d613841073027e5f5e7e::getLoader();
return ComposerAutoloaderInit1887e85fc3cfddacf8d7e17588dae6f1::getLoader();

@ -24,12 +24,14 @@ return array(
'Psr\\Container\\' => array($vendorDir . '/psr/container/src'),
'PhpParser\\' => array($vendorDir . '/nikic/php-parser/lib/PhpParser'),
'PhpOption\\' => array($vendorDir . '/phpoption/phpoption/src/PhpOption'),
'Repository\\' => array($baseDir . '/src/data/model/repository'),
'Network\\' => array($baseDir . '/src/data/core/network'),
'Hearttrack\\' => array($baseDir . '/src'),
'GrahamCampbell\\ResultType\\' => array($vendorDir . '/graham-campbell/result-type/src'),
'Dotenv\\' => array($vendorDir . '/vlucas/phpdotenv/src'),
'Doctrine\\Instantiator\\' => array($vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator'),
'DeepCopy\\' => array($vendorDir . '/myclabs/deep-copy/src/DeepCopy'),
'Data\\Core\\' => array($baseDir . '/src/data/core'),
'Data\\' => array($baseDir . '/src/data'),
'Console\\' => array($baseDir . '/src/console'),
'App\\Views\\Directives\\' => array($baseDir . '/src/app/views/directives'),
'App\\Router\\Response\\' => array($baseDir . '/src/app/router/response'),

@ -2,7 +2,7 @@
// autoload_real.php @generated by Composer
class ComposerAutoloaderInitb084bad56d99d613841073027e5f5e7e
class ComposerAutoloaderInit1887e85fc3cfddacf8d7e17588dae6f1
{
private static $loader;
@ -24,16 +24,16 @@ class ComposerAutoloaderInitb084bad56d99d613841073027e5f5e7e
require __DIR__ . '/platform_check.php';
spl_autoload_register(array('ComposerAutoloaderInitb084bad56d99d613841073027e5f5e7e', 'loadClassLoader'), true, true);
spl_autoload_register(array('ComposerAutoloaderInit1887e85fc3cfddacf8d7e17588dae6f1', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
spl_autoload_unregister(array('ComposerAutoloaderInitb084bad56d99d613841073027e5f5e7e', 'loadClassLoader'));
spl_autoload_unregister(array('ComposerAutoloaderInit1887e85fc3cfddacf8d7e17588dae6f1', 'loadClassLoader'));
require __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInitb084bad56d99d613841073027e5f5e7e::getInitializer($loader));
call_user_func(\Composer\Autoload\ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1::getInitializer($loader));
$loader->register(true);
$filesToLoad = \Composer\Autoload\ComposerStaticInitb084bad56d99d613841073027e5f5e7e::$files;
$filesToLoad = \Composer\Autoload\ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1::$files;
$requireFile = \Closure::bind(static function ($fileIdentifier, $file) {
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
$GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;

@ -4,7 +4,7 @@
namespace Composer\Autoload;
class ComposerStaticInitb084bad56d99d613841073027e5f5e7e
class ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1
{
public static $files = array (
'320cde22f66dd4f5d3fd621d3e88b98f' => __DIR__ . '/..' . '/symfony/polyfill-ctype/bootstrap.php',
@ -163,7 +163,7 @@ class ComposerStaticInitb084bad56d99d613841073027e5f5e7e
array (
0 => __DIR__ . '/..' . '/vlucas/phpdotenv/src',
),
'Doctrine\\Instantiator\\' =>
'Doctrine\\Instantiator\\' =>
array (
0 => __DIR__ . '/..' . '/graham-campbell/result-type/src',
),
@ -171,18 +171,18 @@ class ComposerStaticInitb084bad56d99d613841073027e5f5e7e
array (
0 => __DIR__ . '/..' . '/vlucas/phpdotenv/src',
),
'DeepCopy\\' =>
'DeepCopy\\' =>
array (
0 => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy',
),
'Data\\' =>
array (
0 => __DIR__ . '/../..' . '/src/data',
),
'Data\\Core\\' =>
array (
0 => __DIR__ . '/../..' . '/src/data/core',
),
'Data\\' =>
array (
0 => __DIR__ . '/../..' . '/src/data',
),
'Console\\' =>
array (
0 => __DIR__ . '/../..' . '/src/console',
@ -211,7 +211,7 @@ class ComposerStaticInitb084bad56d99d613841073027e5f5e7e
array (
0 => __DIR__ . '/../..' . '/src/app/controller',
),
'App\\' =>
'App\\' =>
array (
0 => __DIR__ . '/../..' . '/src/app',
),
@ -1387,9 +1387,9 @@ class ComposerStaticInitb084bad56d99d613841073027e5f5e7e
public static function getInitializer(ClassLoader $loader)
{
return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInitb084bad56d99d613841073027e5f5e7e::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInitb084bad56d99d613841073027e5f5e7e::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInitb084bad56d99d613841073027e5f5e7e::$classMap;
$loader->prefixLengthsPsr4 = ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInit1887e85fc3cfddacf8d7e17588dae6f1::$classMap;
}, null, ClassLoader::class);
}

@ -4,6 +4,44 @@
"name": "adriangibbons/php-fit-file-analysis",
"version": "v3.2.4",
"version_normalized": "3.2.4.0",
"source": {
"type": "git",
"url": "https://github.com/adriangibbons/php-fit-file-analysis.git",
"reference": "8efd36b1b963f01c42dc5329626519c040dec664"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/adriangibbons/php-fit-file-analysis/zipball/8efd36b1b963f01c42dc5329626519c040dec664",
"reference": "8efd36b1b963f01c42dc5329626519c040dec664",
"shasum": ""
},
"require-dev": {
"phpunit/phpunit": "4.8.*",
"satooshi/php-coveralls": "^2.0",
"squizlabs/php_codesniffer": "2.*"
},
"time": "2019-11-20T06:58:56+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"adriangibbons\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"description": "A PHP class for analysing FIT files created by Garmin GPS devices",
"homepage": "https://github.com/adriangibbons/php-fit-file-analysis",
"keywords": [
"Fit",
"garmin"
],
"support": {
"issues": "https://github.com/adriangibbons/php-fit-file-analysis/issues",
"source": "https://github.com/adriangibbons/php-fit-file-analysis/tree/master"
},
"install-path": "../adriangibbons/php-fit-file-analysis"
},
{
"name": "altorouter/altorouter",
"version": "v1.1.0",
"version_normalized": "1.1.0.0",
@ -232,6 +270,71 @@
],
"install-path": "../graham-campbell/result-type"
},
{
"name": "graham-campbell/result-type",
"version": "v1.1.2",
"version_normalized": "1.1.2.0",
"source": {
"type": "git",
"url": "https://github.com/GrahamCampbell/Result-Type.git",
"reference": "fbd48bce38f73f8a4ec8583362e732e4095e5862"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/GrahamCampbell/Result-Type/zipball/fbd48bce38f73f8a4ec8583362e732e4095e5862",
"reference": "fbd48bce38f73f8a4ec8583362e732e4095e5862",
"shasum": ""
},
"require": {
"php": "^7.2.5 || ^8.0",
"phpoption/phpoption": "^1.9.2"
},
"require-dev": {
"phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2"
},
"time": "2023-11-12T22:16:48+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"GrahamCampbell\\ResultType\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Graham Campbell",
"email": "hello@gjcampbell.co.uk",
"homepage": "https://github.com/GrahamCampbell"
}
],
"description": "An Implementation Of The Result Type",
"keywords": [
"Graham Campbell",
"GrahamCampbell",
"Result Type",
"Result-Type",
"result"
],
"support": {
"issues": "https://github.com/GrahamCampbell/Result-Type/issues",
"source": "https://github.com/GrahamCampbell/Result-Type/tree/v1.1.2"
},
"funding": [
{
"url": "https://github.com/GrahamCampbell",
"type": "github"
},
{
"url": "https://tidelift.com/funding/github/packagist/graham-campbell/result-type",
"type": "tidelift"
}
],
"install-path": "../graham-campbell/result-type"
},
{
"name": "myclabs/deep-copy",
"version": "1.11.1",
@ -550,8 +653,8 @@
},
{
"name": "phpunit/php-code-coverage",
"version": "9.2.29",
"version_normalized": "9.2.29.0",
"version": "10.1.9",
"version_normalized": "10.1.9.0",
"source": {
"type": "git",
"url": "https://github.com/schmittjoh/php-option.git",
@ -1122,6 +1225,62 @@
},
"install-path": "../psr/container"
},
{
"name": "sebastian/cli-parser",
"version": "2.0.0",
"version_normalized": "2.0.0.0",
"source": {
"type": "git",
"url": "https://github.com/php-fig/container.git",
"reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/php-fig/container/zipball/c71ecc56dfe541dbd90c5360474fbc405f8d5963",
"reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963",
"shasum": ""
},
"require": {
"php": ">=7.4.0"
},
"time": "2021-11-05T16:47:00+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "2.0.x-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Psr\\Container\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "PHP-FIG",
"homepage": "https://www.php-fig.org/"
}
],
"description": "Common Container Interface (PHP FIG PSR-11)",
"homepage": "https://github.com/php-fig/container",
"keywords": [
"PSR-11",
"container",
"container-interface",
"container-interop",
"psr"
],
"support": {
"issues": "https://github.com/php-fig/container/issues",
"source": "https://github.com/php-fig/container/tree/2.0.2"
},
"install-path": "../psr/container"
},
{
"name": "sebastian/cli-parser",
"version": "2.0.0",

@ -3,7 +3,7 @@
'name' => 'hearttrack/package',
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'reference' => '79311b1041e6dc02c8f58f9bc46bc20ba368ed58',
'reference' => 'eb625309ce4a814abafb1d0ded3d0d5937ddc905',
'type' => 'library',
'install_path' => __DIR__ . '/../../',
'aliases' => array(),
@ -18,6 +18,7 @@
'install_path' => __DIR__ . '/../adriangibbons/php-fit-file-analysis',
'aliases' => array(),
'dev_requirement' => false,
),
'altorouter/altorouter' => array(
'pretty_version' => 'v1.1.0',
'version' => '1.1.0.0',
@ -54,10 +55,19 @@
'aliases' => array(),
'dev_requirement' => false,
),
'graham-campbell/result-type' => array(
'pretty_version' => 'v1.1.2',
'version' => '1.1.2.0',
'reference' => 'fbd48bce38f73f8a4ec8583362e732e4095e5862',
'type' => 'library',
'install_path' => __DIR__ . '/../graham-campbell/result-type',
'aliases' => array(),
'dev_requirement' => false,
),
'hearttrack/package' => array(
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'reference' => '79311b1041e6dc02c8f58f9bc46bc20ba368ed58',
'reference' => 'eb625309ce4a814abafb1d0ded3d0d5937ddc905',
'type' => 'library',
'install_path' => __DIR__ . '/../../',
'aliases' => array(),

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save