commit 12.01

This commit is contained in:
Владимир
2026-01-12 14:25:15 +00:00
parent 36084ba590
commit ae5ab2554b
26 changed files with 1116 additions and 1083 deletions

View File

@@ -1,51 +1,57 @@
<?php
use App\Http\Controllers\UserController;
use App\Http\Controllers\ServicesController;
use App\Http\Controllers\BookingsController;
use App\Http\Controllers\AvailabilitiesController;
use App\Http\Controllers\CategoriesController;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Route;
use App\Http\Controllers\AuthController;
use App\Http\Controllers\ServicesController;
use App\Http\Controllers\BookingsController; // ← ДОЛЖЕН БЫТЬ!
use App\Http\Controllers\AvailabilitiesController;
use App\Http\Controllers\CategoriesController;
Route::get('/user', function (Request $request) {
return $request->user();
})->middleware('auth:sanctum');
// РЕГИСТРАЦИЯ ТОЛЬКО КЛИЕНТОВ (публичный)
Route::post('/register', [UserController::class, 'register']);
Route::post('/login', [AuthController::class, 'login']);
// Существующие роуты categories
Route::get('/categories', [CategoriesController::class, 'index'])->middleware('auth:sanctum');
// === ПУБЛИЧНЫЕ РОУТЫ ===
Route::post('/register', [AuthController::class, 'register']);
Route::post('/login', [AuthController::class, 'login'])->name('login');
Route::get('/services', [ServicesController::class, 'publicIndex']);
Route::get('/availability', [AvailabilitiesController::class, 'publicAvailability']);
Route::get('/categories/{id}', [CategoriesController::class, 'show']);
Route::post('/categories', [CategoriesController::class, 'create']);
// ПУБЛИЧНЫЙ API доступности (без авторизации)
Route::get('/availability', [AvailabilitiesController::class, 'publicAvailability']);
// КЛИЕНТСКИЕ РОУТЫ БРОНИРОВАНИЙ (auth:sanctum)
Route::middleware('auth:sanctum', 'role:admin')->group(function () {
Route::post('/bookings', [BookingsController::class, 'store']);
Route::post('/bookings/{id}/cancel', [BookingsController::class, 'cancel']);
Route::post('/bookings/{id}/cancel', [BookingsController::class, 'adminCancel']);
// === ЗАЩИЩЁННЫЕ РОУТЫ ===
Route::middleware('auth:sanctum')->group(function () {
Route::get('/categories', [CategoriesController::class, 'index']);
Route::get('/bookings', [BookingsController::class, 'clientIndex']);
Route::get('/bookings', [BookingsController::class, 'adminIndex']);
Route::post('/bookings', [BookingsController::class, 'store']);
Route::post('/bookings/{id}/cancel', [BookingsController::class, 'cancel']);
// Получить сотрудников
Route::get('/users', function (Request $request) {
$role = $request->query('role', 'employee');
return \App\Models\User::where('role', $role)->get();
});
});
// АДМИН РОУТЫ - ТОЛЬКО employee/admin (role:employee)
Route::middleware(['auth:sanctum', 'role:employee'])->prefix('admin')->group(function () {
// CRUD услуги
// === АДМИНСКИЕ РОУТЫ ===
Route::middleware(['auth:sanctum', 'role:admin'])->prefix('admin')->group(function () {
// Услуги
Route::get('/services', [ServicesController::class, 'index']);
Route::post('/services', [ServicesController::class, 'store']);
Route::put('/services/{id}', [ServicesController::class, 'update']);
Route::delete('/services/{id}', [ServicesController::class, 'destroy']);
// CRUD расписание
// Расписание
Route::get('/availabilities', [AvailabilitiesController::class, 'index']);
Route::post('/availabilities', [AvailabilitiesController::class, 'store']);
Route::post('/availabilities/bulk', [AvailabilitiesController::class, 'bulkStore']);
Route::delete('/availabilities/{id}', [AvailabilitiesController::class, 'destroy']);
});
// Бронирования админа ← ЭТОТ БЛОК ОБЯЗАТЕЛЕН!
Route::get('/bookings', [BookingsController::class, 'adminIndex']);
Route::post('/bookings/{id}/assign', [BookingsController::class, 'assignEmployee']);
Route::post('/bookings/{id}/cancel', [BookingsController::class, 'adminCancel']);
});