Пример #1
0
        public async Task <ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser {
                    UserName = model.Email, Email = model.Email, UserRole = model.SelectedAccountType
                };
                var result = await UserManager.CreateAsync(user, model.Password);

                if (result.Succeeded)
                {
                    UserManager.AddClaim(user.Id, new Claim(ClaimTypes.GivenName, model.FirstName));
                    var service = new CheckAccountServices(HttpContext.GetOwinContext().Get <ApplicationDbContext>());
                    service.CreateCheckAccount(model.FirstName, model.LastName, user.Id, 10);
                    await SignInManager.SignInAsync(user, isPersistent : false, rememberBrowser : false);

                    // For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771
                    // Send an email with this link
                    // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
                    // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
                    // await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");

                    return(RedirectToAction("Index", "Home"));
                }
                FillAccountNames(model);
                AddErrors(result);
            }

            // If we got this far, something failed, redisplay form
            return(View(model));
        }
Пример #2
0
        protected override void Seed(MVCBank.Models.ApplicationDbContext context)
        {
            //var userStore = new UserStore<ApplicationUser>(context);
            //var userManager = new UserManager<ApplicationUser>(userStore);

            //var currentAdmin = context.Users.Where(user => user.UserName == "*****@*****.**").FirstOrDefault();

            ////var isAdminExisting = context.Users.Any(user => user.UserName == "*****@*****.**");

            //if (currentAdmin == null)
            //{
            //    var adminUser = new ApplicationUser { UserName = "******", Email = "*****@*****.**", UserRole = "Admin" };
            //    userManager.Create(adminUser, "12345Ut.");

            //    var service = new CheckAccountServices(context);
            //    service.CreateCheckAccount("admin", "user", adminUser.Id, 1000);

            //    context.Roles.AddOrUpdate(res => res.Name, new IdentityRole { Name = "Admin" });
            //    context.SaveChanges();

            //    userManager.AddToRole(adminUser.Id, "Admin");
            //}

            var userStore   = new UserStore <ApplicationUser>(context);
            var userManager = new UserManager <ApplicationUser>(userStore);

            var currentAdmin = context.Users.Where(user => user.UserName == "*****@*****.**").FirstOrDefault();

            if (currentAdmin == null)
            {
                var adminUser = new ApplicationUser {
                    UserName = "******", Email = "*****@*****.**", UserRole = Services.AccountTypes.Admin.ToString()
                };
                userManager.Create(adminUser, "12345Ut.");

                var service = new CheckAccountServices(context);
                service.CreateCheckAccount("admin", "user", adminUser.Id, 1000);

                context.SaveChanges();
            }
            else if (context.Users.Any(user => user.UserName == "*****@*****.**" && (user.UserRole == null || user.UserRole != Services.AccountTypes.Admin.ToString())))
            {
                currentAdmin.UserRole             = Services.AccountTypes.Admin.ToString();
                context.Entry(currentAdmin).State = EntityState.Modified;
                context.SaveChanges();
            }



            //  This method will be called after migrating to the latest version.

            //  You can use the DbSet<T>.AddOrUpdate() helper extension method
            //  to avoid creating duplicate seed data. E.g.
            //
            //    context.People.AddOrUpdate(
            //      p => p.FullName,
            //      new Person { FullName = "Andrew Peters" },
            //      new Person { FullName = "Brice Lambson" },
            //      new Person { FullName = "Rowan Miller" }
            //    );
            //
        }