//Creer un nouveau compte utilisateur func (user *User) CreateAccount(login, email, password, password2 string) models.ListError { //on ajoute les variables envoyé dans la structure User user.login = helpers.NormalizeString(login) user.email = helpers.NormalizeString(email) user.password = password user.password2 = password2 //On appel la fonction propre au controller qui verifie la validité du password dans son format. err := user.checkPasswords() // on verifie la syntax du login et de l'email. if user.IsAConformLogin() == false { helpers.AddStringInArray(&err, "Votre login n'est pas au bon format. Il doit contenir entre 4 et 16 caractères et ne pas avoir de caractères spéciaux.") } if user.IsAConformEmail() == false { helpers.AddStringInArray(&err, "Votre email n'est pas au bon format.") } //Si aucune erreur, on ajoute les variables a la structure du model pour ensuite les poster dans la base de donné if len(err) == 0 { user.model.Email = user.email user.model.Login = user.login user.model.Password = user.hashedPassword //fonction qui post les data dans la DB errModel := user.model.CreateUser() //on join les deux tableaux d'erreus possiblement obtenu dans le controlleur et dans le model pour n'en faire plus qu'un. err = helpers.ArrayJoin(err, errModel) } return models.RenderErrorList(err) }
//cette fonction creer une nouvelle session. func (session *Session) CreateSession(emailOrLogin, password, ipAddr string) models.ListError { //initialisation du tableau d'erreur var errr []string //initialisation de notre structure user userModel := models.User{} //initialisation des variables dans la structure user avec celle qui ont été envoyé via la method post userModel.Login = helpers.NormalizeString(emailOrLogin) userModel.Email = userModel.Login userModel.Password = []byte(password) //if l'identifiant envoyé exist (cette identifiant peut etre un email ou login) if userModel.IsUserEmailExist() || userModel.IsUserLoginExist() { //si l'identifiant match avec le password associé if userModel.IsLoginOrEmailMatchWithPassword() { //on initialise une structure session du MODEL sessionModel := models.Session{} //on recuperer l'id de l'utilisateur et on le met dans session sessionModel.UserId = userModel.GetUserByLoginOrEmail() //si l'utilisateur est verifié if userModel.IsUserIsVerified() == true { //creation d'un nouveau token qui sera renvoyé en response json et egalement ajouté a la base de donnée session.Token = sessionModel.CreateSession(ipAddr) } else { helpers.AddStringInArray(&errr, "Votre compte n'est pas verifié, vous avez certainement reçu un email de comfirmation, verifiez dans vos spams ou demandez à en recevoir un nouveau.") } } else { helpers.AddStringInArray(&errr, "Le mot de passe ne correspond pas à celui du compte.") } } else { helpers.AddStringInArray(&errr, "Il n'existe aucun compte lié a cette identifiant") } //si la variable de la structure Session n'est pas vide (Si il est rentré dans la condition qui check que l'utilisateur est bien verifié) if session.Token != "" { session.Status = "OK" } return models.RenderErrorList(errr) }