public HttpResponseMessage DescartarItem(int p_oid) { // CAD, CEN, returnValue ItemRESTCAD itemRESTCAD = null; ItemCEN itemCEN = null; try { SessionInitializeTransaction(); string token = ""; if (Request.Headers.Authorization != null) { token = Request.Headers.Authorization.ToString(); } int id = new UsuarioCEN().CheckToken(token); itemRESTCAD = new ItemRESTCAD(session); itemCEN = new ItemCEN(itemRESTCAD); // Operation itemCEN.DescartarItem(p_oid); 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 200 - OK return(this.Request.CreateResponse(HttpStatusCode.OK)); }
public void WhenDescartoElItem() { try { itemCEN.DescartarItem(id); } catch (ModelException e) { ScenarioContext.Current.Add(exception, e); } }