//--ADMINISTRADORES-- public void AgregarAdministrador(Administrador admin) { try { if (admin == null) throw new Exception("Debe pasar un administrador."); using (var context = ChebayDBPublic.CreatePublic()) { var query = from adm in context.administradores where adm.AdministradorID == admin.AdministradorID select adm; if (query.Count() == 0) { context.administradores.Add(admin); context.SaveChanges(); Debug.WriteLine("Administrador " + admin.AdministradorID + " creado correctamente"); } else throw new Exception("Ya existe un administrador " + admin.AdministradorID); } } catch (Exception e) { Debug.WriteLine(e.Message); throw e; } }
public void AgregarAdministrador() { Debug.WriteLine("\n1. AgregarAdministrador"); Debug.WriteLine("1.1. Crea un Administrador nuevo TestAdmin con pass: pass123."); Administrador a = new Administrador(); a.AdministradorID = adminTest; a.password = "******"; a.tiendas = new HashSet<Tienda>(); it.AgregarAdministrador(a); }
public async Task<ActionResult> ExternalLoginCallback(string returnUrl) { var loginInfo = await AuthenticationManager.GetExternalLoginInfoAsync(); if (loginInfo == null) { return RedirectToAction("Login"); } // Si el usuario ya tiene un inicio de sesión, iniciar sesión del usuario con este proveedor de inicio de sesión externo var result = await SignInManager.ExternalSignInAsync(loginInfo, isPersistent: false); switch (result) { case SignInStatus.Success: IDALTienda dalT = new DALTiendaEF(); Administrador admin; try { admin = dalT.ObtenerAdministrador(loginInfo.Email); } catch (Exception e) { admin = new Administrador {AdministradorID=loginInfo.Email, password="" }; try { dalT.AgregarAdministrador(admin); } catch (Exception e2) { Debug.WriteLine(e2.Message); } } return RedirectToLocal(returnUrl); case SignInStatus.LockedOut: return View("Lockout"); case SignInStatus.RequiresVerification: return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = false }); case SignInStatus.Failure: default: // Si el usuario no tiene ninguna cuenta, solicitar que cree una ViewBag.ReturnUrl = returnUrl; ViewBag.LoginProvider = loginInfo.Login.LoginProvider; return View("ExternalLoginConfirmation", new ExternalLoginConfirmationViewModel { Email = loginInfo.Email }); } }
public async Task<ActionResult> Register(RegisterViewModel model) { if (ModelState.IsValid) { IDALTienda idalt = new DALTiendaEF(); Administrador admin = new Administrador { AdministradorID= model.Email, password=model.Password}; idalt.AgregarAdministrador(admin); var user = new ApplicationUser { UserName = model.Email, Email = model.Email }; var result = await UserManager.CreateAsync(user, model.Password); if (result.Succeeded) { await SignInManager.SignInAsync(user, isPersistent:false, rememberBrowser:false); // Para obtener más información sobre cómo habilitar la confirmación de cuenta y el restablecimiento de contraseña, visite http://go.microsoft.com/fwlink/?LinkID=320771 // Enviar correo electrónico con este vínculo // 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, "Confirmar cuenta", "Para confirmar la cuenta, haga clic <a href=\"" + callbackUrl + "\">aquí</a>"); return RedirectToAction("Index", "Home"); } AddErrors(result); } // Si llegamos a este punto, es que se ha producido un error y volvemos a mostrar el formulario return View(model); }