Esempio n. 1
0
 public static Utilisateur registerToUtilisateur(RegisterModelPOST rmPost)
 {
     return(new Utilisateur()
     {
         //IdUtilisateur = rmPost.IdUtilisateur, // car  rmPOST n'en contient pas
         Nom = rmPost.Nom,
         Prenom = rmPost.Prenom,
         Courriel = rmPost.Courriel,
         MotDePasse = rmPost.MotDePasse,
         DateDeNaissance = rmPost.DateDeNaissance,
         Photo = rmPost.Photo,
         IsAdmin = Convert.ToBoolean(rmPost.IsAdmin),
         IdRole = rmPost.IdRole
     });
 }
Esempio n. 2
0
        public ActionResult Register(RegisterModelPOST rmPost, HttpPostedFileBase Photo)
        {
            UtilisateurRepository ur = new UtilisateurRepository(ConfigurationManager.ConnectionStrings["My_Asptest_Cnstr"].ConnectionString);

            if (!ModelState.IsValid)
            {
                foreach (ModelState each_modelState in ViewData.ModelState.Values)
                {
                    foreach (ModelError each_error in each_modelState.Errors)
                    {
                        ViewBag.ErrorMessage += each_error.ErrorMessage + "<br>";
                    }
                }
                return(RedirectToAction("Index", new { controller = "Home", area = "" }));
            }
            else
            {
                //is admin or not ?
                VerifAdminModel verifAdmin = new VerifAdminModel();
                if (rmPost.IsAdmin == verifAdmin.Code) // long string
                {
                    verifAdmin.IsAdmin = true;
                }
                else if (rmPost.IsAdmin == null || rmPost.IsAdmin != verifAdmin.Code)
                {
                    ViewBag.Message = "Not a administrator";
                }
                rmPost.IsAdmin = verifAdmin.IsAdmin.ToString();

                // 1. Ajouter MMembre sans photo
                ProfileModel pm = mapToVIEWmodels.utilisateurTOprofileModel(ur.insert(MapToDBModel.registerToUtilisateur(rmPost)));

                // 2. photo :
                if (pm == null)
                {
                    ViewBag.Message = "The profileModel is Null";
                    return(RedirectToAction("Index", new { controller = "Home", area = "" }));
                }
                else //if (pm != null)
                {
                    List <string> listeMIME = new List <string>()
                    {
                        "image/jpeg", "image/png", "image/gif"
                    };
                    if (!listeMIME.Contains(Photo.ContentType) || Photo.ContentLength > 80000)
                    {
                        ViewBag.ErrorMessage = "Votre photo ne possède pas une extension autorisée (choisissez parmis : png, jpg, gif)";
                        return(View("Index"));
                    }

                    string[] splitPhotoname = Photo.FileName.Split(new char[] { '.' }, StringSplitOptions.RemoveEmptyEntries);
                    string   ext            = splitPhotoname[splitPhotoname.Length - 1];
                    string   photoNew       = pm.IdUtilisateur + "." + ext; // <== save in DB
                    string   chemin         = Server.MapPath("~/photos/utilisateur");
                    string   photoToSave    = chemin + "/" + photoNew;
                    Photo.SaveAs(photoToSave);
                    pm.Photo = photoNew; // saved in DB via mapper
                    // try catch
                    bool reussi = ur.update(MapToDBModel.profileTOUtilisateur(pm));
                    //

                    if (!reussi)
                    {
                        ViewBag.Message = "The profileModel updating failed (no picture)";
                        return(RedirectToAction("Index", new { controller = "Home", area = "" }));
                    }
                    else // reussi
                    {
                        if (!pm.IsAdmin)
                        {
                            if (pm.IdRole == 0)
                            {
                                return(RedirectToAction("Index", new { controller = "Home", area = "Parrain" }));
                            }
                            else
                            {
                                return(RedirectToAction("Index", new { controller = "Home", area = "Personnel" }));
                            }
                        }
                        else // is admin
                        {
                            return(RedirectToAction("Index", new { controller = "Home", area = "Admin" }));
                        }
                    }
                }
            }
        }