public HttpResponseMessage Modificar(int idUsuarioWebAutenticado, [FromBody] UsuarioWebDTO dto) { // CAD, CEN, returnValue UsuarioWebAutenticadoRESTCAD usuarioWebAutenticadoRESTCAD = null; UsuarioWebCEN usuarioWebCEN = null; UsuarioWebAutenticadoDTOA returnValue = null; // HTTP response HttpResponseMessage response = null; string uri = null; try { SessionInitializeTransaction(); string token = ""; if (Request.Headers.Authorization != null) { token = Request.Headers.Authorization.ToString(); } int id = new UsuarioCEN().CheckToken(token); usuarioWebAutenticadoRESTCAD = new UsuarioWebAutenticadoRESTCAD(session); usuarioWebCEN = new UsuarioWebCEN(usuarioWebAutenticadoRESTCAD); // Modify usuarioWebCEN.Modificar(idUsuarioWebAutenticado, dto.Nombre , dto.Apellidos , dto.Email ); // Return modified object returnValue = UsuarioWebAutenticadoAssembler.Convert(usuarioWebAutenticadoRESTCAD.ReadOIDDefault(idUsuarioWebAutenticado), session); SessionCommit(); } catch (Exception e) { SessionRollBack(); if (e.GetType() == typeof(HttpResponseException)) { throw e; } else if (e.GetType() == typeof(ReciclaUAGenNHibernate.Exceptions.ModelException) && e.Message.Equals("El token es incorrecto")) { throw new HttpResponseException(HttpStatusCode.Forbidden); } else if (e.GetType() == typeof(ReciclaUAGenNHibernate.Exceptions.ModelException) || e.GetType() == typeof(ReciclaUAGenNHibernate.Exceptions.DataLayerException)) { throw new HttpResponseException(HttpStatusCode.BadRequest); } else { throw new HttpResponseException(HttpStatusCode.InternalServerError); } } finally { SessionClose(); } // Return 404 - Not found if (returnValue == null) { return(this.Request.CreateResponse(HttpStatusCode.NotFound)); } // Return 200 - OK else { response = this.Request.CreateResponse(HttpStatusCode.OK, returnValue); return(response); } }