public HttpResponseMessage CrearCP([FromBody] RespuestaDTO dto) { // CAD, CEN, returnValue, returnOID RespuestaRESTCAD respuestaRESTCAD = null; RespuestaCEN respuestaCEN = null; RespuestaDTOA returnValue = null; RespuestaCP respuestaCP = null; int returnOID = -1; // HTTP response HttpResponseMessage response = null; string uri = null; try { SessionInitializeTransaction(); respuestaRESTCAD = new RespuestaRESTCAD(session); respuestaCEN = new RespuestaCEN(respuestaRESTCAD); respuestaCP = new RespuestaCP(session); // Create returnOID = respuestaCEN.Crear(dto.Cuerpo, dto.Duda_oid, dto.Usuario_oid); respuestaCP.CrearAccionRespuesta(returnOID); SessionCommit(); // Convert return returnValue = RespuestaAssembler.Convert(respuestaRESTCAD.ReadOIDDefault(returnOID), session); } 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 201 - Created response = this.Request.CreateResponse(HttpStatusCode.Created, returnValue); return(response); }
public HttpResponseMessage ObtenerUltimaRespuesta(int p_oid) { // CP, returnValue RespuestaCP respuestaCP = null; RespuestaDTOA returnValue; RespuestaEN en; try { SessionInitializeTransaction(); string token = ""; if (Request.Headers.Authorization != null) { token = Request.Headers.Authorization.ToString(); } int id = new UsuarioCEN().CheckToken(token); respuestaCP = new RespuestaCP(session); // Operation en = respuestaCP.ObtenerUltimaRespuesta(p_oid); SessionCommit(); // Convert return returnValue = RespuestaAssembler.Convert(en, session); } 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 200 - OK return(this.Request.CreateResponse(HttpStatusCode.OK, returnValue)); }
public static RespuestaDTOA Convert(RespuestaEN en, NHibernate.ISession session = null) { RespuestaDTOA dto = null; RespuestaRESTCAD respuestaRESTCAD = null; RespuestaCEN respuestaCEN = null; RespuestaCP respuestaCP = null; if (en != null) { dto = new RespuestaDTOA(); respuestaRESTCAD = new RespuestaRESTCAD(session); respuestaCEN = new RespuestaCEN(respuestaRESTCAD); respuestaCP = new RespuestaCP(session); // // Attributes dto.Id = en.Id; dto.Cuerpo = en.Cuerpo; dto.Fecha = en.Fecha; dto.EsCorrecta = en.EsCorrecta; dto.Util = en.Util; // // TravesalLink /* Rol: Respuesta o--> UsuarioAdminAutenticado */ dto.UsuarioRespuesta = UsuarioAdminAutenticadoAssembler.Convert((UsuarioEN)en.Usuario, session); // // Service } return(dto); }