mirror of
https://github.com/twinpath/app.git
synced 2026-01-26 05:15:28 +07:00
237 lines
14 KiB
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']);
|