Files
app/routes/web.php

237 lines
14 KiB
PHP

<?php
use Illuminate\Support\Facades\Route;
use App\Http\Controllers\DashboardController;
use App\Http\Controllers\AuthController;
use App\Http\Controllers\CertificateController;
use App\Http\Controllers\UiController;
use App\Http\Controllers\ChartController;
use App\Http\Controllers\PageController;
use App\Http\Controllers\ProfileController;
use App\Http\Controllers\SettingsController;
use App\Http\Controllers\Auth\ForgotPasswordController;
use App\Http\Controllers\Auth\ResetPasswordController;
use App\Http\Controllers\Admin\RootCaController;
use App\Http\Controllers\ContactController;
use App\Http\Controllers\TicketController;
// Public API Routes
Route::get('/api/public/ca-certificates', [\App\Http\Controllers\Api\PublicCaController::class, 'index'])->name('api.public.ca-certificates');
// Authenticated API Routes (v1)
Route::middleware('api_key')->prefix('api/v1')->group(function () {
Route::get('/certificates', [\App\Http\Controllers\Api\CertificateApiController::class, 'index'])->name('api.v1.certificates.index');
});
Route::get('/ping', function () {
return response()->noContent();
});
// authentication pages
Route::middleware('guest')->group(function () {
Route::get('/', [PageController::class, 'landing'])->name('home');
Route::get('/signin', [AuthController::class, 'signin'])->name('signin');
Route::post('/signin', [AuthController::class, 'authenticate']);
Route::get('/signup', [AuthController::class, 'signup'])->name('signup');
Route::post('/signup', [AuthController::class, 'store']);
// Password Setup (for social signup)
Route::get('/setup-password', [AuthController::class, 'showPasswordSetup'])->name('setup-password');
Route::post('/setup-password', [AuthController::class, 'completePasswordSetup']);
// Forgot Password
// Forgot Password
Route::get('/forgot-password', [ForgotPasswordController::class, 'showLinkRequestForm'])->name('password.request');
Route::post('/forgot-password', [ForgotPasswordController::class, 'sendResetLinkEmail'])->name('password.email');
Route::get('/reset-password', function () {
return redirect()->route('password.request');
})->name('password.reset.missing_token');
Route::get('/reset-password/{token}', [ResetPasswordController::class, 'showResetForm'])->name('password.reset');
Route::post('/reset-password', [ResetPasswordController::class, 'reset'])->name('password.update');
});
// Social Auth Redirects (context-aware)
Route::get('/auth/{provider}/redirect/{context}', [AuthController::class, 'socialRedirect'])
->name('auth.social')
->where('provider', 'github|google')
->where('context', 'signin|signup|connect');
// Social Auth Callbacks
Route::get('/auth/{provider}/callback', [AuthController::class, 'socialCallback'])
->name('auth.social.callback')
->where('provider', 'github|google');
// Public Certificate Routes
Route::prefix('certificate')->name('certificate.')->group(function () {
Route::get('/download-ca/{type}', [CertificateController::class, 'downloadCa'])->name('download-ca');
Route::get('/download-ca-bundle', [CertificateController::class, 'downloadCaBundle'])->name('download-ca-bundle');
Route::get('/download-ca-android', [CertificateController::class, 'downloadCaAndroid'])->name('download-ca-android');
Route::get('/download-installer', [CertificateController::class, 'downloadInstaller'])->name('download-installer');
});
// Legal Pages
Route::get('/legal/{slug}', [\App\Http\Controllers\LegalController::class, 'show'])->name('legal.show');
// Email Verification (Public/Signed)
Route::get('/email/verify/{id}/{hash}', [App\Http\Controllers\VerificationController::class, 'verify'])
->middleware(['signed', 'throttle:6,1'])
->name('verification.verify');
// Authenticated Routes
Route::middleware(['auth', \App\Http\Middleware\EnsureUserIsActive::class])->group(function () {
// Email Verification Routes
Route::get('/email/verify', [App\Http\Controllers\VerificationController::class, 'show'])->name('verification.notice');
Route::post('/email/verification-notification', [App\Http\Controllers\VerificationController::class, 'resend'])->middleware(['throttle:6,1'])->name('verification.send');
// Suspended Page
Route::get('/suspended', [\App\Http\Controllers\SuspendedController::class, 'index'])->name('suspended');
// Logout
Route::get('/logout', [AuthController::class, 'logoutGet'])->name('logout.get');
Route::post('/logout', [AuthController::class, 'logout'])->name('logout');
// Authenticated & Verified Routes
Route::middleware('verified')->group(function () {
// Notifications
Route::get('/notifications/unread', [\App\Http\Controllers\NotificationController::class, 'getUnread'])->name('notifications.unread');
Route::get('/notifications/{id}/read', [\App\Http\Controllers\NotificationController::class, 'markAsRead'])->name('notifications.read');
Route::post('/notifications/read-all', [\App\Http\Controllers\NotificationController::class, 'markAllRead'])->name('notifications.readAll');
// Global Search
Route::get('/search/global', [\App\Http\Controllers\SearchController::class, 'global'])->name('search.global');
// dashboard pages
Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard');
Route::get('/dashboard/stats', [DashboardController::class, 'stats'])->name('dashboard.stats');
Route::get('/dashboard/ping', [DashboardController::class, 'ping'])->name('dashboard.ping');
// Certificate routes
Route::prefix('certificate')->name('certificate.')->group(function () {
Route::get('/', [CertificateController::class, 'index'])->name('index');
Route::get('/create', [CertificateController::class, 'create'])->name('create');
Route::post('/generate', [CertificateController::class, 'generate'])->name('generate');
// Setup CA moved to admin routes
Route::post('/regenerate/{certificate:uuid}', [CertificateController::class, 'regenerate'])->name('regenerate');
Route::get('/download-zip/{certificate:uuid}', [CertificateController::class, 'downloadZip'])->name('download-zip');
Route::get('/download-p12/{certificate:uuid}', [CertificateController::class, 'downloadP12'])->name('download-p12');
Route::get('/view/{certificate:uuid}/{type}', [CertificateController::class, 'viewFile'])->name('view');
Route::delete('/{certificate:uuid}', [CertificateController::class, 'delete'])->name('delete');
});
// Support Tickets (Customer)
Route::prefix('support')->name('support.')->group(function () {
Route::get('/', [TicketController::class, 'index'])->name('index');
Route::get('/create', [TicketController::class, 'create'])->name('create');
Route::post('/', [TicketController::class, 'store'])->name('store');
Route::get('/{ticket}', [TicketController::class, 'show'])->name('show');
Route::post('/{ticket}/reply', [TicketController::class, 'reply'])->name('reply');
Route::post('/{ticket}/close', [TicketController::class, 'close'])->name('close');
});
// Admin Only Pages (No Prefix) -> Moved to Templates
Route::middleware('admin')->group(function () {
// Templates Group
Route::prefix('templates')->name('templates.')->group(function () {
// calender pages
Route::get('/calendar', [PageController::class, 'calendar'])->name('calendar');
// form pages
Route::get('/form-elements', [UiController::class, 'formElements'])->name('form-elements');
// tables pages
Route::get('/basic-tables', [UiController::class, 'basicTables'])->name('basic-tables');
// pages
Route::get('/blank', [PageController::class, 'blank'])->name('blank');
// chart pages
Route::get('/line-chart', [ChartController::class, 'lineChart'])->name('line-chart');
Route::get('/bar-chart', [ChartController::class, 'barChart'])->name('bar-chart');
// ui elements pages
Route::get('/alerts', [UiController::class, 'alerts'])->name('alerts');
Route::get('/avatars', [UiController::class, 'avatars'])->name('avatars');
Route::get('/badge', [UiController::class, 'badges'])->name('badges');
Route::get('/buttons', [UiController::class, 'buttons'])->name('buttons');
Route::get('/image', [UiController::class, 'images'])->name('images');
Route::get('/videos', [UiController::class, 'videos'])->name('videos');
});
});
// profile pages
Route::get('/profile', [ProfileController::class, 'index'])->name('profile');
Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update');
// account settings
Route::get('/settings', [SettingsController::class, 'index'])->name('settings');
Route::post('/settings/password', [SettingsController::class, 'updatePassword'])->name('settings.password');
Route::delete('/settings/social/{provider}', [SettingsController::class, 'disconnectSocial'])->name('settings.social.disconnect');
Route::delete('/settings', [SettingsController::class, 'destroy'])->name('settings.destroy');
// API Keys
Route::resource('api-keys', \App\Http\Controllers\ApiKeyController::class)->only(['index', 'store', 'destroy', 'update']);
Route::patch('/api-keys/{apiKey}/toggle', [\App\Http\Controllers\ApiKeyController::class, 'toggle'])->name('api-keys.toggle');
Route::post('/api-keys/{apiKey}/regenerate', [\App\Http\Controllers\ApiKeyController::class, 'regenerate'])->name('api-keys.regenerate');
// Admin Pages
Route::middleware('admin')->prefix('admin')->name('admin.')->group(function () {
Route::get('/users', [App\Http\Controllers\UserManagementController::class, 'index'])->name('users.index');
Route::patch('/users/{user}/toggle-status', [App\Http\Controllers\UserManagementController::class, 'toggleStatus'])->name('users.toggle-status');
Route::delete('/users/{user}', [App\Http\Controllers\UserManagementController::class, 'destroy'])->name('users.destroy');
Route::post('/users/{user}/send-reset-link', [App\Http\Controllers\UserManagementController::class, 'sendResetLink'])->name('users.send-reset-link');
Route::post('/users/{user}/send-verification', [App\Http\Controllers\UserManagementController::class, 'sendVerification'])->name('users.send-verification');
Route::patch('/users/{user}/update-email', [App\Http\Controllers\UserManagementController::class, 'updateEmail'])->name('users.update-email');
// Root CA Management
Route::post('/setup-ca', [RootCaController::class, 'setup'])->name('setup-ca');
Route::get('/root-ca', [RootCaController::class, 'index'])->name('root-ca.index');
Route::post('/root-ca/{certificate}/renew', [RootCaController::class, 'renew'])->name('root-ca.renew');
// Legal Page Management
Route::get('/legal-pages', [App\Http\Controllers\Admin\LegalManagementController::class, 'index'])->name('legal-pages.index');
Route::get('/legal-pages/{legalPage}/edit', [App\Http\Controllers\Admin\LegalManagementController::class, 'edit'])->name('legal-pages.edit');
Route::put('/legal-pages/{legalPage}', [App\Http\Controllers\Admin\LegalManagementController::class, 'update'])->name('legal-pages.update');
// Contact Management
Route::get('/contacts', [App\Http\Controllers\Admin\ContactManagementController::class, 'index'])->name('contacts.index');
Route::get('/contacts/{contactSubmission}', [App\Http\Controllers\Admin\ContactManagementController::class, 'show'])->name('contacts.show');
Route::post('/contacts/{contactSubmission}/reply', [App\Http\Controllers\Admin\ContactManagementController::class, 'reply'])->name('contacts.reply');
Route::delete('/contacts/{contactSubmission}', [App\Http\Controllers\Admin\ContactManagementController::class, 'destroy'])->name('contacts.destroy');
// Ticket Management
Route::prefix('tickets')->name('tickets.')->group(function () {
Route::get('/', [App\Http\Controllers\Admin\TicketManagementController::class, 'index'])->name('index');
Route::get('/{ticket}', [App\Http\Controllers\Admin\TicketManagementController::class, 'show'])->name('show');
Route::post('/{ticket}/reply', [App\Http\Controllers\Admin\TicketManagementController::class, 'reply'])->name('reply');
Route::patch('/{ticket}/status', [App\Http\Controllers\Admin\TicketManagementController::class, 'updateStatus'])->name('update-status');
});
// SMTP Tester
Route::get('/smtp-tester', [\App\Http\Controllers\Admin\SmtpTesterController::class, 'index'])->name('smtp-tester.index');
Route::post('/smtp-tester/send', [\App\Http\Controllers\Admin\SmtpTesterController::class, 'send'])->name('smtp-tester.send');
});
});
});
// Public Contact Form
Route::get('/contact', [ContactController::class, 'index'])->name('contact');
Route::post('/contact', [ContactController::class, 'store'])->name('contact.store');
// Public Tools
Route::get('/tools/chat-id-finder', [\App\Http\Controllers\ToolController::class, 'chatIdFinder'])->name('tools.chat-id-finder');
Route::get('/tools/app-key-generator', [\App\Http\Controllers\ToolController::class, 'appKeyGenerator'])->name('tools.app-key-generator');
Route::post('/tools/app-key-generator', [\App\Http\Controllers\ToolController::class, 'generateAppKey'])->name('tools.app-key-generator.generate');
// Public / Error Pages
Route::get('/error-404', [PageController::class, 'error404'])->name('error-404');
Route::get('/php', [PageController::class, 'php']);