This repository has been archived on 2026-03-14. You can view files and clone it, but cannot push or open issues or pull requests.
php-api/src/Api/Routes/api.php

104 lines
5.3 KiB
PHP
Raw Normal View History

2026-01-26 20:57:08 +00:00
<?php
declare(strict_types=1);
use Core\Api\Controllers\EntitlementApiController;
use Core\Api\Controllers\McpApiController;
use Core\Api\Controllers\SeoReportController;
use Core\Api\Controllers\UnifiedPixelController;
2026-01-26 20:57:08 +00:00
use Core\Mod\Mcp\Middleware\McpApiKeyAuth;
use Illuminate\Support\Facades\Route;
/*
|--------------------------------------------------------------------------
| Core API Routes
|--------------------------------------------------------------------------
|
| Core API routes for cross-cutting concerns: SEO, unified pixel tracking,
| MCP HTTP bridge, and entitlements.
|
*/
// ─────────────────────────────────────────────────────────────────────────────
// SEO Report Endpoints (authenticated)
// ─────────────────────────────────────────────────────────────────────────────
Route::middleware('auth')->prefix('seo')->group(function () {
Route::post('/report', [SeoReportController::class, 'receive'])
->name('api.seo.report');
Route::get('/issues/{workspace}', [SeoReportController::class, 'issues'])
->name('api.seo.issues');
Route::post('/task/generate', [SeoReportController::class, 'generateTask'])
->name('api.seo.generate-task');
});
// ─────────────────────────────────────────────────────────────────────────────
// Unified Pixel API (public - high rate limit for tracking)
// ─────────────────────────────────────────────────────────────────────────────
Route::middleware('throttle:300,1')->prefix('pixel')->group(function () {
Route::get('/config', [UnifiedPixelController::class, 'config'])
->name('api.pixel.config');
Route::post('/track', [UnifiedPixelController::class, 'track'])
->name('api.pixel.track');
});
// ─────────────────────────────────────────────────────────────────────────────
// Entitlements API (authenticated)
// ─────────────────────────────────────────────────────────────────────────────
Route::middleware('auth')->prefix('entitlements')->group(function () {
// Check feature access (for external apps)
Route::get('/check', [EntitlementApiController::class, 'check'])
->name('api.entitlements.check');
// Record usage (for external apps)
Route::post('/usage', [EntitlementApiController::class, 'recordUsage'])
->name('api.entitlements.usage');
// Get usage summary for current user's workspace
Route::get('/summary', [EntitlementApiController::class, 'mySummary'])
->name('api.entitlements.summary');
// Get usage summary for a specific workspace (admin)
Route::get('/summary/{workspace}', [EntitlementApiController::class, 'summary'])
->name('api.entitlements.summary.workspace');
});
// ─────────────────────────────────────────────────────────────────────────────
// MCP HTTP Bridge (API key auth)
// ─────────────────────────────────────────────────────────────────────────────
Route::middleware(['throttle:120,1', McpApiKeyAuth::class, 'api.scope.enforce'])
->prefix('mcp')
->name('api.mcp.')
->group(function () {
// Scope enforcement: GET=read, POST=write
// Server discovery (read)
Route::get('/servers', [McpApiController::class, 'servers'])
->name('servers');
Route::get('/servers/{id}', [McpApiController::class, 'server'])
->name('servers.show');
Route::get('/servers/{id}/tools', [McpApiController::class, 'tools'])
->name('servers.tools');
// Tool version history (read)
Route::get('/servers/{server}/tools/{tool}/versions', [McpApiController::class, 'toolVersions'])
->name('tools.versions');
// Specific tool version (read)
Route::get('/servers/{server}/tools/{tool}/versions/{version}', [McpApiController::class, 'toolVersion'])
->name('tools.version');
// Tool execution (write)
Route::post('/tools/call', [McpApiController::class, 'callTool'])
->name('tools.call');
// Resource access (read)
Route::get('/resources/{uri}', [McpApiController::class, 'resource'])
->where('uri', '.*')
->name('resources.show');
});