public HttpResponseMessage Modify(int idDisability, [FromBody] DisabilityDTO dto)
        {
            // CAD, CEN, returnValue
            DisabilityRESTCAD disabilityRESTCAD = null;
            DisabilityCEN     disabilityCEN     = null;
            DisabilityDTOA    returnValue       = null;

            // HTTP response
            HttpResponseMessage response = null;
            string uri = null;

            try
            {
                SessionInitializeTransaction();


                disabilityRESTCAD = new DisabilityRESTCAD(session);
                disabilityCEN     = new DisabilityCEN(disabilityRESTCAD);

                // Modify
                disabilityCEN.Modify(idDisability,
                                     dto.Name
                                     ,
                                     dto.Type
                                     ,
                                     dto.Severity
                                     ,
                                     dto.Description
                                     );

                // Return modified object
                returnValue = DisabilityAssembler.Convert(disabilityRESTCAD.ReadOIDDefault(idDisability), session);

                SessionCommit();
            }

            catch (Exception e)
            {
                SessionRollBack();

                if (e.GetType() == typeof(HttpResponseException))
                {
                    throw e;
                }
                else if (e.GetType() == typeof(MoSIoTGenNHibernate.Exceptions.ModelException) && e.Message.Equals("El token es incorrecto"))
                {
                    throw new HttpResponseException(HttpStatusCode.Forbidden);
                }
                else if (e.GetType() == typeof(MoSIoTGenNHibernate.Exceptions.ModelException) || e.GetType() == typeof(MoSIoTGenNHibernate.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);
            }
        }
        public HttpResponseMessage New_([FromBody] DisabilityDTO dto)
        {
            // CAD, CEN, returnValue, returnOID
            DisabilityRESTCAD disabilityRESTCAD = null;
            DisabilityCEN     disabilityCEN     = null;
            DisabilityDTOA    returnValue       = null;
            int returnOID = -1;

            // HTTP response
            HttpResponseMessage response = null;
            string uri = null;

            try
            {
                SessionInitializeTransaction();


                disabilityRESTCAD = new DisabilityRESTCAD(session);
                disabilityCEN     = new DisabilityCEN(disabilityRESTCAD);

                // Create
                returnOID = disabilityCEN.New_(

                    //Atributo OID: p_patient
                    // attr.estaRelacionado: true
                    dto.Patient_oid                     // association role

                    , dto.Name                          //Atributo Primitivo: p_name
                    , dto.Type                          //Atributo Primitivo: p_type
                    , dto.Severity                      //Atributo Primitivo: p_severity
                    , dto.Description                   //Atributo Primitivo: p_description
                    );
                SessionCommit();

                // Convert return
                returnValue = DisabilityAssembler.Convert(disabilityRESTCAD.ReadOIDDefault(returnOID), session);
            }

            catch (Exception e)
            {
                SessionRollBack();

                if (e.GetType() == typeof(HttpResponseException))
                {
                    throw e;
                }
                else if (e.GetType() == typeof(MoSIoTGenNHibernate.Exceptions.ModelException) && e.Message.Equals("El token es incorrecto"))
                {
                    throw new HttpResponseException(HttpStatusCode.Forbidden);
                }
                else if (e.GetType() == typeof(MoSIoTGenNHibernate.Exceptions.ModelException) || e.GetType() == typeof(MoSIoTGenNHibernate.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);

            // Location Header

            /*
             * Dictionary<string, object> routeValues = new Dictionary<string, object>();
             *
             * // TODO: y rolPaths
             * routeValues.Add("id", returnOID);
             *
             * uri = Url.Link("GetOIDDisability", routeValues);
             * response.Headers.Location = new Uri(uri);
             */

            return(response);
        }