public IHttpActionResult PostBitacora(Bitacora bitacora)
        {
            Bitacora objBitacora = new Bitacora();
            Usuario user = db.Usuarios.Find(bitacora.usuario.UsuarioId);

            if (user != null)
            {
                db.Usuarios.Attach(user);
                db.Roles.Attach(user.RolId);

                foreach (Permiso permiso in user.RolId.permisos.ToList())
                {
                    db.Permisos.Attach(permiso);
                }

                objBitacora.fecha = bitacora.fecha;
                objBitacora.idPermiso = bitacora.idPermiso;
                objBitacora.usuario = user;
            }

            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }

            db.Bitacoras.Add(objBitacora);
            db.SaveChanges();

            return CreatedAtRoute("DefaultApi", new { id = objBitacora.id }, objBitacora);
        }
        public IHttpActionResult PutBitacora(int id, Bitacora bitacora)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }

            if (id != bitacora.id)
            {
                return BadRequest();
            }

            db.Entry(bitacora).State = EntityState.Modified;

            try
            {
                db.SaveChanges();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!BitacoraExists(id))
                {
                    return NotFound();
                }
                else
                {
                    throw;
                }
            }

            return StatusCode(HttpStatusCode.NoContent);
        }