// PUT /webpages_Membership/token/ public HttpResponseMessage Put(string token, [FromBody] Models.Object.AlterarSenha param) { // Abre nova conexão using (painel_taxservices_dbContext _db = new painel_taxservices_dbContext()) { tbLogAcessoUsuario log = new tbLogAcessoUsuario(); try { HttpResponseMessage retorno = new HttpResponseMessage(); log = Bibliotecas.LogAcaoUsuario.New(token, JsonConvert.SerializeObject(param), "Put", _db); if (Permissoes.Autenticado(token, _db)) { GatewayWebpagesMembership.Update(token, param, _db); log.codResposta = (int)HttpStatusCode.OK; Bibliotecas.LogAcaoUsuario.Save(log, _db); return(Request.CreateResponse(HttpStatusCode.OK)); } else { log.codResposta = (int)HttpStatusCode.Unauthorized; Bibliotecas.LogAcaoUsuario.Save(log, _db); return(Request.CreateResponse(HttpStatusCode.Unauthorized)); } } catch (Exception e) { log.codResposta = (int)HttpStatusCode.InternalServerError; log.msgErro = e.Message; Bibliotecas.LogAcaoUsuario.Save(log); throw new HttpResponseException(HttpStatusCode.InternalServerError); } } }
/// <summary> /// Altera webpages_Membership /// Alterar senha do usuário logado /// </summary> /// <param name="param"></param> /// <returns></returns> public static void Update(string token, Models.Object.AlterarSenha param, painel_taxservices_dbContext _dbContext = null) { painel_taxservices_dbContext _db; if (_dbContext == null) { _db = new painel_taxservices_dbContext(); } else { _db = _dbContext; } try { Int32 idUser = 0; if (param.UserId == -1) { idUser = Permissoes.GetIdUser(token); } else { idUser = param.UserId; } var value = _db.webpages_Users .Where(e => e.id_users.Equals(idUser)) .FirstOrDefault(); if (value != null) { string resetToken = WebSecurity.GeneratePasswordResetToken(value.ds_login, 2); if (param.NovaSenha == "") { WebSecurity.ResetPassword(resetToken, "atos123"); } else if (param.SenhaAtual != null) { if (WebSecurity.Login(value.ds_login, param.SenhaAtual, persistCookie: false)) { WebSecurity.ResetPassword(resetToken, param.NovaSenha); } else { throw new Exception("Senha inválida!"); } } else { throw new Exception("Operação inválida!"); } } else { throw new Exception("Usuário inválido!"); } } catch (Exception e) { if (e is DbEntityValidationException) { string erro = MensagemErro.getMensagemErro((DbEntityValidationException)e); throw new Exception(erro.Equals("") ? "Falha ao alterar membership" : erro); } throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } finally { if (_dbContext == null) { // Fecha conexão _db.Database.Connection.Close(); _db.Dispose(); } } }