ometra / apollo-sdk
Proteus API adapter
Requires
- php: ^8.2
- guzzlehttp/guzzle: ^7.9
- illuminate/database: ^12.0
- illuminate/http: ^12.0
- illuminate/routing: ^12.0
- illuminate/support: ^12.0
- league/flysystem-aws-s3-v3: ^3.0
- ometra/caronte-sdk: ^4.4.0
Requires (Dev)
- phpunit/phpunit: 11.5.55
README
Cliente Laravel/PHP modular para consumir Proteus y futuros modulos Pulse, Flare e Ignis con autenticacion compartida de Caronte.
Instalacion
composer require ometra/apollo-sdk
Publica la configuracion si necesitas sobrescribir las URLs de modulos:
php artisan vendor:publish --tag=apollo-config
El archivo publicado es config/apollo.php.
Configuracion
Apollo solo configura URLs por modulo; la autenticacion sigue viviendo en el SDK de Caronte.
PROTEUS_BASE_URL=https://proteus.example.com/api PULSE_BASE_URL=https://pulse.example.com/api FLARE_BASE_URL=https://flare.example.com/api IGNIS_BASE_URL=https://ignis.example.com/api
Las llamadas HTTP usan el contrato de Caronte y agregan, segun el tipo de request:
X-Application-TokenX-Group-Tokencuando existeX-User-Tokenen llamadas de usuarioX-Tenant-IddesdeTenantContextcuando existe
Uso modular
use Ometra\Apollo\Sdk\Facades\Apollo; $directories = Apollo::proteus()->directories()->index(); $media = Apollo::proteus()->media()->upload([ 'type' => 'image', 'directory_id' => $directoryId, 'media' => [$request->file('image')], 'metadata' => [ 'source' => 'apollo', ], ]); Apollo::proteus()->media()->setMetadata($mediaId, [ 'metadata' => [ 'title' => 'Hero image', ], ]); $images = Apollo::proteus()->media()->index(['type' => 'image']);
Tambien puedes inyectar el entrypoint principal:
use Ometra\Apollo\Sdk\Apollo; public function __invoke(Apollo $apollo): array { return $apollo->proteus()->media()->index(['type' => 'image']); }
Pulse, Flare e Ignis existen como modulos instanciables hasta que sus contratos de endpoints esten definidos.
API
El contrato completo esta en docs/api-contract.md.
Pruebas
composer test
La suite valida identidad Apollo, configuracion modular, autenticacion Caronte, rutas Proteus, ausencia de API flat y limpieza legacy.