Skip to main content

Shared library for OpenShell (OSAM/OSA/OSAC)

Project description

OpenShell Shared

Librería compartida usada por los componentes de OpenShell (OSAM, OSA, OSAC).

Contiene:

  • identity/ — Identidad lógica de las entidades (EntityIdentity, Identification) y su persistencia (store.py).
  • cryptography/ — Primitivas Ed25519 (keys.py, signatures.py), identidad criptográfica (identity.py) y certificados (certificate.py). encoding.py y utils.py son módulos reservados para trabajo futuro (actualmente sin implementación).
  • protocols/negotiation/ — Protocolo de challenge-response (challenge.py) y sus modelos.
  • domain/ — Modelo de dominio (Domain, Membership, Permission) y políticas de autorización. policies.py es un stub pendiente de implementación real.
  • standards/ — Enumeraciones y contratos compartidos entre componentes: tipos de entidad, certificados, eventos, roles, permisos, passports y transportes.
  • modules/shell/ — Implementación del subsistema de shell remoto (cliente, servidor, sesión y protocolo de framing) usado por OSA y OSAC.
  • api/manager/v1/ — SDK oficial async para consumir la API HTTP de OSAM (OSAMClient). Todo el sistema (OSAC, OSA, herramientas internas) debe consumir OSAM exclusivamente a través de este paquete; ningún otro componente debe importar httpx/requests directamente para hablar con OSAM.

Notas de la fusión (v2.1.0)

Esta versión unifica dos ramas que habían divergido:

  • Se conserva la estructura de empaquetado (pyproject.toml, layout src) y los módulos domain/ y standards/, introducidos en la rama de refactor v2.
  • Se restaura modules/shell/ y se sustituye el cliente HTTP monolítico (api/manager/1/osam_client.py) por el SDK modular (api/manager/v1/), que es la versión vigente y más completa (excepciones tipadas, dataclasses, suite de tests con mock transport).

Deuda técnica pendiente identificada durante la fusión

  1. domain/permissions.py y standards/permissions/types.py definen dos enums Permission distintos y no compatibles entre sí (AGENT_READ/AGENT_EXECUTE/DOMAIN_ADMIN/PROXY_USE vs. DOMAIN_READ/DOMAIN_WRITE/ENTITY_REGISTER/ENTITY_REVOKE/PROXY_USE). No se han unificado automáticamente porque implica una decisión de diseño (cuál es la fuente de verdad de permisos). Requiere consolidación manual.
  2. cryptography/encoding.py, cryptography/utils.py y domain/policies.py son placeholders vacíos o triviales (Policy.evaluate siempre retorna True). No implementan lógica real.
  3. El SDK (api/manager/v1/) no reexpone los helpers de alto nivel full_connect / open_and_link que existían en el cliente monolítico anterior (composición de autenticación + túnel + sesión en una sola llamada). Si se siguen usando, conviene reimplementarlos como métodos de conveniencia sobre OSAMClient.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openshell_shared-0.1.4.tar.gz (2.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openshell_shared-0.1.4-py3-none-any.whl (2.6 kB view details)

Uploaded Python 3

File details

Details for the file openshell_shared-0.1.4.tar.gz.

File metadata

  • Download URL: openshell_shared-0.1.4.tar.gz
  • Upload date:
  • Size: 2.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for openshell_shared-0.1.4.tar.gz
Algorithm Hash digest
SHA256 1215a409d94a6126eb21584d654dd9c146e84c68a477d1c8211de0db8d342208
MD5 894d1590fd6684763b83fec533541574
BLAKE2b-256 32bd289ac640f4147d570bc7153f45c4e4c36d7c9a63e32ab1536205c50d3952

See more details on using hashes here.

File details

Details for the file openshell_shared-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for openshell_shared-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 73b1b19c208a7e181bc4b72dd73056ae17d5884bbb0e299a47e4b2d2a0fab622
MD5 1d79b8edaafd05b2b5a5bd3cdaf069a4
BLAKE2b-256 d8cf4ccf2d82249c8485696740e617207e6a5cf767ed1b99ee8488c45801591d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page