public static void UserRoleSeeder(this ModelBuilder builder)
        {
            var hesher = new PasswordHasher <CarInsClaimsUser>();

            CarInsClaimsUser admin = new CarInsClaimsUser
            {
                Id                 = "5b239911-19a9-40c0-80ff-4f6bb4436bc6",
                UserName           = "******",
                NormalizedUserName = "******",
                NormalizedEmail    = "*****@*****.**",
                Email              = "*****@*****.**",
                LockoutEnabled     = true,
                SecurityStamp      = "HUC6SK7LPI4HSIDDF5JK7WCAIRFHV4ZP"
            };

            admin.PasswordHash = hesher.HashPassword(admin, "admin12");

            builder.Entity <IdentityRole>()
            .HasData(new IdentityRole
            {
                Id             = "ebdcd4f6-5eb6-4b3e-86b3-f8d62dc65616",
                Name           = "Admin",
                NormalizedName = "ADMIN"
            });

            builder.Entity <CarInsClaimsUser>().HasData(admin);
            builder.Entity <IdentityUserRole <string> >().HasData(new IdentityUserRole <string>
            {
                RoleId = "ebdcd4f6-5eb6-4b3e-86b3-f8d62dc65616",
                UserId = admin.Id
            });
        }
示例#2
0
        public async Task <CarInsClaimsUser> CreateUserAsync(string email)
        {
            email.ValidateIfNull(ExceptionMessages.EmailIsNull);

            var user = await this.FindUserAsync(email);

            if (user == null)
            {
                var newUser = new CarInsClaimsUser {
                    Email = email
                };
                await this.context.Users.AddAsync(newUser);

                await this.context.SaveChangesAsync();

                return(newUser);
            }

            return(user);
        }
        public async Task <IActionResult> OnPostAsync(string returnUrl = null)
        {
            returnUrl = returnUrl ?? Url.Content("~/");
            if (ModelState.IsValid)
            {
                var user = new CarInsClaimsUser {
                    UserName = Input.Email, Email = Input.Email
                };
                var result = await _userManager.CreateAsync(user, Input.Password);

                if (result.Succeeded)
                {
                    _logger.LogInformation("User created a new account with password.");

                    var code = await _userManager.GenerateEmailConfirmationTokenAsync(user);

                    var callbackUrl = Url.Page(
                        "/Account/ConfirmEmail",
                        pageHandler: null,
                        values: new { userId = user.Id, code = code },
                        protocol: Request.Scheme);

                    await _emailSender.SendEmailAsync(Input.Email, "Confirm your email",
                                                      $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>.");

                    await _signInManager.SignInAsync(user, isPersistent : false);

                    return(LocalRedirect(returnUrl));
                }
                foreach (var error in result.Errors)
                {
                    ModelState.AddModelError(string.Empty, error.Description);
                }
            }

            // If we got this far, something failed, redisplay form
            return(Page());
        }