Esempio n. 1
0
        public ActionResult EditProfile(int id)
        {
            DataContext    db   = new DataContext();
            UserCredential user = db.UserCredentials.FirstOrDefault(x => x.ID == id);

            return(View(user));
        }
Esempio n. 2
0
        public ActionResult PostEntry(EntriesViewModel model)
        {
            DataContext    db   = new DataContext();
            UserCredential user = new UserCredential();

            user = Session["Login"] as UserCredential;
            Entry entryUserId = new Entry();
            Entry entry       = new Entry();
            var   desc        = model.Entries.Description; //This is for edit text that we take from user for a better view

            user = Session["Login"] as UserCredential;
            if (ModelState.IsValid)
            {
                entry.Title       = model.Entries.Title;
                entry.Description = desc;
                entry.DropOffLoc  = model.Entries.DropOffLoc;
                entry.PickUpLoc   = model.Entries.PickUpLoc;
                entry.CreatedDate = DateTime.Now;
                entry.UserId      = user.ID;
                db.Entries.Add(entry);

                db.SaveChanges();
            }
            return(View());
        }
Esempio n. 3
0
        public ActionResult EditProfile(UserCredential model, HttpPostedFileBase file)
        {
            DataContext    db   = new DataContext();
            UserCredential user = db.UserCredentials.FirstOrDefault(x => x.ID == model.ID);

            model = user;

            if (ModelState.IsValid)
            {
                if (file != null)
                {
                    var size = file.ContentLength;          //Checking image size
                    var type = file.ContentType;
                    if (file.ContentLength > 2097152)
                    {
                        ModelState.AddModelError("", "Image size cannot be bigger than 2 mb.");
                        return(View(model));
                    }
                    if (file.ContentType.ToString() != "image/png" || file.ContentType.ToString() != "image/jpeg")
                    {
                        ModelState.AddModelError("", "Wrong Format");
                        return(View(model));
                    }

                    //Get width and height
                    System.IO.Stream stream    = file.InputStream;
                    Image            img       = Image.FromStream(stream);
                    Image            profImage = ResizeImage(img);
                    //saving image name
                    string fileName = $"user_{model.ID}.{file.ContentType.Split('/')[1]}";
                    profImage.Save(Server.MapPath($"~/images/{fileName}"), ImageFormat.Jpeg);
                    model.ProfileImage = fileName;
                }
                // Construct the viewmodel
                user.UserName = model.UserName;
                string cryptedPass = Crypto.HashPassword(model.UserPass);
                user.UserPass     = cryptedPass;
                user.ProfileImage = model.ProfileImage;
                try
                {
                    db.SaveChanges();
                }
                catch (DbEntityValidationException ex)
                {
                    foreach (var entityValidationErrors in ex.EntityValidationErrors)
                    {
                        foreach (var validationError in entityValidationErrors.ValidationErrors)
                        {
                            ModelState.AddModelError("", "Wrong Format");
                            return(View(model));
                        }
                    }
                }
            }

            return(RedirectToAction("ShowProfile"));
        }
Esempio n. 4
0
        public ActionResult ShowProfile(LoginViewModel model)
        {
            DataContext    db   = new DataContext();
            UserCredential user = db.UserCredentials.FirstOrDefault(x => x.UserName == model.UserName);

            user = Session["Login"] as UserCredential;

            return(View(user));
        }
Esempio n. 5
0
        public ActionResult UserActivation(Guid?id)
        {
            DataContext    db   = new DataContext();
            UserCredential user = db.UserCredentials.FirstOrDefault(x => x.ActiveGuid == id);

            if (id == user.ActiveGuid)
            {
                user.IsActive = true;
                db.SaveChanges();
            }

            return(View());
        }
Esempio n. 6
0
        public ActionResult Register(RegisterViewModel model)
        {
            DataContext    db      = new DataContext();
            UserCredential regUser = db.UserCredentials.FirstOrDefault(x => x.UserName == model.Username || x.UserMail == model.Email);
            bool           flag    = true;

            if (ModelState.IsValid)
            {
                if (regUser == null)
                {
                    UserCredential user = new UserCredential();
                    user.UserName = model.Username;
                    user.UserMail = model.Email;
                    string cryptedPass = Crypto.HashPassword(model.Password);
                    user.UserPass     = cryptedPass;
                    user.IsAdmin      = false;
                    user.IsActive     = false;
                    user.IsArchieved  = false;
                    user.IsDriver     = false;
                    user.ProfileImage = @"..\autoroad\images\profile image.png";
                    user.ActiveGuid   = Guid.NewGuid();
                    db.UserCredentials.Add(user);
                    db.SaveChanges();
                    Session["Login"] = user.UserName;
                    SendVerificationMail(user);

                    return(RedirectToAction("Index"));
                }
                if (model.Username == regUser.UserName)
                {
                    ModelState.AddModelError("", "This username or e-mail address is already registred.");
                    flag = false;
                }

                else if (model.Email == regUser.UserMail)
                {
                    ModelState.AddModelError("", "This username or e-mail address is already registred.");
                    flag = false;
                }

                if (flag == false)
                {
                    return(View(model));
                }
            }

            return(View(model));
        }
Esempio n. 7
0
        public ActionResult Login(LoginViewModel model)
        {
            //Session'a bilgi saklama
            DataContext    db   = new DataContext();
            UserCredential user = db.UserCredentials.FirstOrDefault(x => x.UserName == model.UserName);
            bool           flag = true;

            if (ModelState.IsValid)
            {
                if (user == null)
                {
                    ModelState.AddModelError("", "Wrong username or password.");
                    flag = false;
                    return(View(model));
                }

                if (Crypto.VerifyHashedPassword(user.UserPass, model.Password))
                {
                    flag = true;
                }
                else
                {
                    ModelState.AddModelError("", "Wrong username or password.");
                    flag = false;
                }
                if (user.IsActive == false)
                {
                    ModelState.AddModelError("", "Acoount isn't activated.");
                    flag = false;
                }
                if (flag == false)
                {
                    return(View(model));
                }
            }
            Session["Login"] = user;

            return(RedirectToAction("Index"));
        }
Esempio n. 8
0
        private void SendVerificationMail(UserCredential model)
        {
            DataContext    db             = new DataContext();
            UserCredential user           = db.UserCredentials.FirstOrDefault(x => x.UserName == model.UserName || x.UserMail == model.UserMail);
            Guid           guid           = (Guid)user.ActiveGuid;
            var            senderEmail    = new MailAddress("*****@*****.**", "");
            var            receivereEmail = new MailAddress(user.UserMail, "Receiver");
            var            password       = "******";
            var            body           = "Hi " + user.UserName + ",\n" + "\n Welcome to WayMate!\n\n Thanks for joining us. There is only one more step left! Please activate your account using activation link below.\n\n" +
                                            " Activation link: https://localhost:44365/Home/UserActivation/" + guid.ToString();
            var sub  = "Welcome to Way Mate";
            var smtp = new SmtpClient
            {
                Host                  = "smtp.gmail.com",
                Port                  = 587,
                EnableSsl             = true,
                DeliveryMethod        = SmtpDeliveryMethod.Network,
                UseDefaultCredentials = false,
                Credentials           = new NetworkCredential("*****@*****.**", password),
            };

            smtp.Send(senderEmail.ToString(), receivereEmail.ToString(), sub, body);
        }
Esempio n. 9
0
        public ActionResult Entries(CommentViewModel model)
        {
            DataContext    db   = new DataContext();
            UserCredential user = new UserCredential();

            user = Session["Login"] as UserCredential;
            Comment comment = new Comment();

            comment.Description = model.Comment.Description;
            comment.UserId      = user.ID;
            comment.EntryId     = model.Entry.ID;
            comment.UploadDate  = DateTime.Now;

            if (string.IsNullOrEmpty(model.Comment.Description))
            {
                ModelState.AddModelError("", "Boş bir yorum ekleyemezsiniz!");
            }
            else
            {
                db.Comments.Add(comment);
                db.SaveChanges();
            }
            return(RedirectToAction("Entries", new { id = model.Entry.ID }));
        }