Ejemplo n.º 1
0
        public async Task <IActionResult> Activate(string key, string code)
        {
            string thongbao = "";
            var    taikhoan = await _accountRepository.All.SingleOrDefaultAsync(x => x.Id == key);

            var checkCode = await _xacMinhRepository.All.FirstOrDefaultAsync(x => x.Code.Contains(code));

            if (taikhoan?.TinhTrang != "Chưa kích hoạt")
            {
                thongbao = "Tài khoản đã được kích hoạt";
            }
            else
            {
                if (checkCode != null)
                {
                    if (Sosanhngay(checkCode.Timer, DateTime.Now) >= 10)
                    {
                        _xacMinhRepository.Delete(checkCode);
                        await _xacMinhRepository.SaveAsync();

                        await HttpContext.SignOutAsync();

                        HttpContext.Session.Remove(SessionName);
                        HttpContext.Session.Remove(SessionId);
                        HttpContext.Session.Remove(SessionIdQuyen);
                        HttpContext.Session.Clear();
                        thongbao = "Quá thời gian xác nhận. Tài khoản của bạn đã bị xóa";
                    }
                    else
                    {
                        taikhoan.TinhTrang = "Không khoá";
                        _accountRepository.UpdateAsync(taikhoan);
                        _accountRepository.Save();
                        thongbao = "Kích hoạt thành công";
                    }
                }
                else
                {
                    thongbao = "Code đã sai.Vui lòng đăng ký hoặc đăng nhập lại";
                }
            }
            return(RedirectToAction("Index", "Home", new { thongbao = thongbao }));
        }
Ejemplo n.º 2
0
        //[Route("AddUser/{thongTinDangKy}")]
        public async Task <IActionResult> AddUser([FromBody] UserItem item)
        {
            string message;

            var checkRegister = _accountRepository.All.Count(u => u.Email == item.email);

            if (checkRegister == 0)
            {
                //string hashpass;
                //using (Md5 = MD5.Create())
                //{
                //    Encrypt = new EnCryptography();
                //    hashpass = Encrypt.GetMd5Hash(Md5, item.password);
                //}
                //string salt = EncryptionHelper.GetSalt();
                //Password = EncryptionHelper.GetHash(item.password + salt),
                var avatars = new string[] { "avatar1.png", "avatar2.png", "avatar3.png", "avatar4.png" };
                var index   = int.Parse(item.avatar);
                if (index < 0 || index > avatars.Count() - 1)
                {
                    index = 0;
                }

                var      avatarName = avatars[index];
                Customer customer   = new Customer()
                {
                    Id        = Guid.NewGuid().ToString(),
                    Email     = item.email,
                    Password  = StringHelper.stringToSHA512(item.password),
                    FullName  = item.fullName,
                    CreateAt  = DateTime.Now,
                    Avatar    = avatarName,
                    TinhTrang = "Chưa kích hoạt"
                };
                _accountRepository.Add(customer);
                await _accountRepository.SaveAsync();

                var quyen = _quyenRepository.All.FirstOrDefault(x => x.TenQuyen.Contains("Khách hàng"));
                if (quyen != null)
                {
                    var       maquyen   = quyen.MaQuyen;
                    PhanQuyen phanQuyen = new PhanQuyen()
                    {
                        MaQuyen    = maquyen,
                        MaTaiKhoan = customer.Id
                    };
                    await _phanQuyenRepository.AddAsync(phanQuyen);

                    await _phanQuyenRepository.SaveAsync();

                    HttpContext.Session.SetInt32(SessionIdQuyen, maquyen);
                    HttpContext.Session.SetString(SessionName, customer.Email);
                    HttpContext.Session.SetString(SessionId, customer.Id);
                    try
                    {
                        Random random = new Random();
                        var    code   = new string(Enumerable.Repeat(Chars, 9)
                                                   .Select(s => s[random.Next(s.Length)]).ToArray());
                        var taikhoan = await _accountRepository.All.FirstOrDefaultAsync(x => x.Email.Contains(item.email));

                        XacMinh xm = new XacMinh
                        {
                            Code    = code,
                            Id_User = taikhoan.Id,
                            Timer   = DateTime.Now
                        };
                        await _xacMinhRepository.AddAsync(xm);

                        await _xacMinhRepository.SaveAsync();

                        string kichhoat = "Để kích hoạt tài khoản, vui lòng nhấn vào link phía dưới: \n";
                        var    local    = HttpContext.Request.Host;
                        kichhoat += "https://" + local + "/TaiKhoan/Activate?key=" + taikhoan.Id + "&code=" + code;
                        var client = new SmtpClient
                        {
                            Host                  = "smtp.gmail.com",
                            Port                  = 587,
                            EnableSsl             = true,
                            UseDefaultCredentials = false,
                            Credentials           = new NetworkCredential("*****@*****.**", "irts mecn xoyz pngm")
                        };

                        using (var messagee = new MailMessage("*****@*****.**", taikhoan.Email)
                        {
                            Subject = "Email kích hoạt tài khoản",
                            Body = kichhoat,
                            Priority = MailPriority.High,
                            BodyEncoding = Encoding.UTF8
                        })
                        {
                            await client.SendMailAsync(messagee);
                        }
                        message = "Đăng ký thành công. Vui lòng kích hoạt email để mua sản phẩm";
                    }
                    catch (Exception)
                    {
                        message = "Hệ thống đang gặp lỗi";
                    }
                }
                else
                {
                    message = "Hệ thống đang gặp lỗi";
                }
            }
            else
            {
                message = "Tài khoản này đã được đăng ký";
            }

            return(Json(message));
        }