public async void InitializeAdmin() { if (!db.Users.Any(u => u.UserName == "*****@*****.**")) { string password = "******"; var admin = new AdminViewModel() { Email = "*****@*****.**", FirstName = "admin", LastName = "admin", DtCreated = DateTime.UtcNow, DtUpdated = DateTime.UtcNow, Status = "Active", Name = "admin", UserName = "******" }; var result = await UserManager.CreateAsync(admin, password); if (!result.Succeeded) { throw new System.ArgumentOutOfRangeException("Operation did not succeed"); } if (result.Succeeded) { ApplicationUser currentUser = db.Users.Where(u => u.Email.Equals(admin.Email, StringComparison.CurrentCultureIgnoreCase)).FirstOrDefault(); if (admin != null) UserManager.AddToRole(admin.Id, "Admin"); } } }
public async Task<ActionResult> RegisterAdmin(RegisterAdminViewModel model) { if (ModelState.IsValid) { var admin = new AdminViewModel() { UserName = model.Email, Email = model.Email, DtCreated = DateTime.UtcNow, Name = model.Name }; var result = await UserManager.CreateAsync(admin, model.Password); if (result.Succeeded) { await SignInManager.SignInAsync(admin, isPersistent: false, rememberBrowser: false); ApplicationUser user = db.Users.Where(u => u.Email.Equals(model.Email, StringComparison.CurrentCultureIgnoreCase)).FirstOrDefault(); if (user != null) UserManager.AddToRole(user.Id, "Admin"); // 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", "Admin"); } AddErrors(result); } // If we got this far, something failed, redisplay form return View(model); }