77 lines
4.5 KiB
PHP
77 lines
4.5 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\AccountController;
|
|
use App\Http\Controllers\pages\HomeController;
|
|
use App\Http\Controllers\pages\VenueController;
|
|
use App\Http\Controllers\pages\BookingController;
|
|
use App\Http\Controllers\pages\BookingHistoryController;
|
|
use App\Http\Controllers\admin\BookingsController;
|
|
use App\Http\Controllers\admin\TableController;
|
|
use App\Http\Controllers\admin\AdminController;
|
|
use App\Http\Controllers\Auth\VerificationController;
|
|
use Illuminate\Support\Facades\Route;
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
// Authentication Routes (dengan verifikasi email aktif)
|
|
Auth::routes(['verify' => true]);
|
|
|
|
// Rute custom untuk verifikasi email
|
|
Route::get('/email/verified', [VerificationController::class, 'verified'])->name('verification.verified');
|
|
|
|
Route::get('/', [HomeController::class, "index"])->name('index');
|
|
Route::get('/venue/{venueName}', [VenueController::class, "venue"])->name('venue');
|
|
|
|
// Changed routes for the new booking flow
|
|
Route::post('/booking/payment-intent', [BookingController::class, 'createPaymentIntent'])->name('booking.payment-intent');
|
|
Route::post('/booking', [BookingController::class, 'store'])->name('booking.store');
|
|
Route::get('/booking/schedules', [BookingController::class, 'getBookedSchedules'])->name('booking.schedules');
|
|
Route::post('/payment/notification', [BookingController::class, 'handleNotification'])->name('payment.notification');
|
|
|
|
// Routes that require authentication but not email verification
|
|
Route::middleware(['auth'])->group(function () {
|
|
// Route untuk melihat halaman verifikasi email dan kirim ulang email verifikasi
|
|
// sudah ditangani oleh Auth::routes(['verify' => true])
|
|
|
|
// Profile route access without verification
|
|
Route::get('/profile', [AccountController::class, 'settings'])->name('profile');
|
|
|
|
// Account settings routes - moved from password confirmation middleware
|
|
Route::get('/account/settings', [AccountController::class, 'settings'])->name('account.settings');
|
|
Route::put('/account/update', [AccountController::class, 'update'])->name('account.update');
|
|
});
|
|
|
|
// Routes that require both authentication and email verification
|
|
Route::middleware(['auth', 'verified'])->group(function () {
|
|
// Booking history routes
|
|
Route::get('/booking/history', [BookingHistoryController::class, 'index'])->name('booking.history');
|
|
|
|
// Pending bookings routes
|
|
Route::get('/booking/pending', [BookingController::class, 'getPendingBookings'])->name('booking.pending');
|
|
Route::get('/booking/pending/{id}/resume', [BookingController::class, 'resumeBooking'])->name('booking.resume');
|
|
Route::delete('/booking/pending/{id}', [BookingController::class, 'deletePendingBooking'])->name('booking.pending.delete');
|
|
|
|
// Routes that require password confirmation - moved account settings out of this group
|
|
Route::middleware(['password.confirm'])->group(function () {
|
|
// Any sensitive operations that should still require password confirmation can go here
|
|
});
|
|
});
|
|
|
|
// Admin routes (admin tetap perlu verified untuk keamanan)
|
|
Route::middleware(['auth', 'verified', 'is_admin'])->prefix('admin')->group(function () {
|
|
Route::get('/', [AdminController::class, 'index'])->name('admin.dashboard');
|
|
Route::get('/bookings', [BookingsController::class, 'index'])->name('admin.bookings.index');
|
|
Route::get('/bookings/export', [BookingsController::class, 'export'])->name('admin.bookings.export');
|
|
Route::get('/bookings/{id}', [BookingsController::class, 'show'])->name('admin.bookings.show');
|
|
Route::get('/bookings/{id}/edit', [BookingsController::class, 'edit'])->name('admin.bookings.edit');
|
|
Route::put('/bookings/{id}', [BookingsController::class, 'update'])->name('admin.bookings.update');
|
|
Route::patch('/bookings/{id}/complete', [BookingsController::class, 'complete'])->name('admin.bookings.complete');
|
|
Route::patch('/bookings/{id}/cancel', [BookingsController::class, 'cancel'])->name('admin.bookings.cancel');
|
|
|
|
// CRUD routes untuk manajemen meja
|
|
Route::get('/tables', [TableController::class, 'index'])->name('admin.tables.index');
|
|
Route::get('/tables/create', [TableController::class, 'create'])->name('admin.tables.create');
|
|
Route::post('/tables', [TableController::class, 'store'])->name('admin.tables.store');
|
|
Route::get('/tables/{id}/edit', [TableController::class, 'edit'])->name('admin.tables.edit');
|
|
Route::put('/tables/{id}', [TableController::class, 'update'])->name('admin.tables.update');
|
|
Route::delete('/tables/{id}', [TableController::class, 'destroy'])->name('admin.tables.destroy');
|
|
}); |