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.2.tar.gz (34.3 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.2-py3-none-any.whl (47.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: openshell_shared-0.1.2.tar.gz
  • Upload date:
  • Size: 34.3 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.2.tar.gz
Algorithm Hash digest
SHA256 eb13e5f0a423cc996bbbbd586fdba60c27765f9beb1a85d41739a0e9a28aeee3
MD5 780f1d5d9831aec0a833e8bd8976bac2
BLAKE2b-256 4f439af69aad8893507c4ec7367be00f5c7626fe9517bb8d51945d8b1d285400

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for openshell_shared-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bc41b444e65f3658815d8afb79728b9c433e87790448151e50ece203c284ab6b
MD5 14085eea8ad13e27452faec5fca5e182
BLAKE2b-256 5c57a0eec075f0b3485cb362f22eb6af96e8dc1aa7bb13a740d7d6bd9855c3bd

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