group(function () { // Público Route::post('login', [AuthController::class, 'login'])->middleware('throttle:10,1'); // Protegido: token Sanctum con ability 'mobile-sync' Route::middleware(['auth:sanctum', 'ability:mobile-sync'])->group(function () { Route::get('me', [AuthController::class, 'me']); Route::post('logout', [AuthController::class, 'logout']); // PULL Route::get('projects', [ProjectApiController::class, 'index']); Route::get('projects/{project}/bundle', [ProjectApiController::class, 'bundle']); // PUSH Route::post('sync', [SyncController::class, 'sync'])->middleware('throttle:60,1'); }); });