ometra/caronte-client
最新稳定版本:4.5.1
Composer 安装命令:
composer require ometra/caronte-client
包简介
Caronte SDK
README 文档
README
This documentation follows the project's Coding Standards and PHPDoc Style Guide.
Project Overview
ometra/caronte-sdk is a Laravel package that integrates a host Laravel application with a centralized Caronte authentication server.
Main capabilities:
- User authentication via Caronte (login, logout, 2FA, password recovery)
- User token validation and renewal middleware
- Management UI for users and role synchronization
- Suite access management for application groups with non-root role synchronization
- Application-to-application authentication middleware
- Protected API access token validation and scope checks
- Tenant-aware behavior for single-tenant and multi-tenant modes
Primary audience: internal development teams integrating Caronte into Laravel applications.
Project Type & Tech Summary
- Project type: Laravel package (library), not a standalone app
- PHP version: ^8.2
- Laravel version: ^12.0
- JWT stack: lcobucci/jwt ^5.3 and lcobucci/clock ^3.2
- HTTP integration: Laravel HTTP client via package support classes
- Database: uses host app database connection; publishes package migrations for local user cache tables
- Cache: host app cache (OIDC JWKS cache uses Laravel Cache)
- Queue: no package-owned queue workers required
- External services: Caronte server HTTP API, optional OIDC issuer endpoints
Quick Start (High-Level)
- Install package dependencies in your host app with composer.
- Publish package configuration and migrations.
- Set required environment variables for CARONTE_URL, CARONTE_APP_CN, and CARONTE_APP_SECRET.
- Run migrations in the host application.
- Add package middleware to protected host routes.
- Synchronize configured roles and protected API scopes.
- Verify authentication and management routes in a local environment.
Full steps: see doc/deployment-instructions.md.
Suite Access
Applications that belong to a Caronte ApplicationGroup can use the SDK to manage tenant user access across the suite after the server grants these Caronte platform permissions to the application:
groups.roles.readgroups.users.readgroups.user_roles.write
The SDK exposes Ometra\Caronte\Api\GroupApi with:
showGroupRoles()showGroupUsers(string $search = '')syncGroupUserRoles(string $uriUser, string $appId, array $roleUris, ?string $actorToken = null)
The management UI includes a "Suite access" mode that lists tenant users, groups roles by application, and prevents selecting roles marked as non-manageable such as root.
Documentation Index
- Deployment Instructions
- API Documentation
- Routes Documentation
- Artisan Commands
- Tests Documentation
- Middleware Documentation
- Architecture Diagrams
- Monitoring
- Business Logic & Core Processes
- Open Questions & Assumptions
Standards Note
Examples and references in these docs follow the project instructions for coding conventions and PHPDoc style, using the package namespace and folder structure as the source of truth.
统计信息
- 总下载量: 1.16k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-11-27