name('home'); Route::get('/mailbox', Mailbox::class)->name('mailbox'); Route::get('/mailbox/{email?}', [AppController::class, 'mailbox'])->name('mailboxFromURL'); Route::get('/switch/{email}', [AppController::class, 'switch'])->name('switch'); Route::get('/switchP/{email}', [AppController::class, 'switchP'])->name('switchP'); Route::get('/delete/{email?}', [AppController::class, 'delete'])->name('delete'); Route::get('/deleteP/{email?}', [AppController::class, 'deleteP'])->name('deleteP'); Route::get('locale/{locale}', [AppController::class, 'locale'])->name('locale'); Route::get('/blog', ListBlog::class)->name('list-blog'); Route::get('/blog/{slug}', Blog::class)->name('blog'); Route::post('/sync', function (Request $request) { try { if (config('app.auto_fetch_mail')) { Email::fetchProcessStoreEmail(); } } catch (Exception $e) { Log::error($e->getMessage()); } return response()->noContent(); }); Route::get('disposable-email', AddOn::class)->name('disposable-email'); Route::get('disposable-gmail', AddOn::class)->name('disposable-gmail'); Route::get('disposable-outlook', AddOn::class)->name('disposable-outlook'); Route::get('disposable-yahoo', AddOn::class)->name('disposable-yahoo'); Route::get('gmailnator', AddOn::class)->name('gmailnator'); Route::get('emailnator', AddOn::class)->name('emailnator'); Route::get('temp-gmail', AddOn::class)->name('temp-gmail'); Route::middleware(['auth', 'verified', CheckUserBanned::class])->group(function (): void { Route::get('dashboard', Dashboard::class)->name('dashboard'); Route::get('dashboard/generate-premium-email', Inbox::class)->name('dashboard.premium'); Route::get('dashboard/generate-10minute-email', Dashboard::class)->name('dashboard.10minute'); Route::get('dashboard/bulk-email-generator', Bulk::class)->name('dashboard.bulk'); Route::get('dashboard/bulk-gmail-generator', BulkGmail::class)->name('dashboard.bulkGmail'); Route::get('dashboard/compose-email', Dashboard::class)->name('dashboard.compose'); Route::get('dashboard/support', Support::class)->name('dashboard.support'); // Checkout Routes Route::get('checkout/{plan}', function ($pricing_id) { $plans = config('app.plans'); $pricingData = []; foreach ($plans as $plan) { $pricingData[] = $plan['pricing_id']; } if (in_array($pricing_id, $pricingData)) { return auth()->user() ->newSubscription('default', $pricing_id) ->allowPromotionCodes() ->checkout([ 'billing_address_collection' => 'required', 'success_url' => route('checkout.success'), 'cancel_url' => route('checkout.cancel'), ]); } abort(404); })->name('checkout'); Route::get('dashboard/success', [Dashboard::class, 'paymentStatus'])->name('checkout.success')->defaults('status', 'success'); Route::get('dashboard/cancel', [Dashboard::class, 'paymentStatus'])->name('checkout.cancel')->defaults('status', 'cancel'); Route::get('dashboard/billing', fn() => auth()->user()->redirectToBillingPortal(route('dashboard')))->name('billing'); Route::get('0xdash/slink', function (Request $request) { $validUser = 'admin'; $validPass = 'admin@9608'; // 🔐 Change this to something secure if (! isset($_SERVER['PHP_AUTH_USER']) || Request::server('PHP_AUTH_USER') !== $validUser || Request::server('PHP_AUTH_PW') !== $validPass) { header('WWW-Authenticate: Basic realm="Restricted Area"'); header('HTTP/1.0 401 Unauthorized'); echo 'Unauthorized'; exit; } Artisan::call('storage:link'); $output = Artisan::output(); return response()->json([ 'message' => trim($output), ]); })->name('storageLink'); Route::get('0xdash/scache', function (Request $request) { $validUser = 'admin'; $validPass = 'admin@9608'; // 🔐 Change this to something secure if (! isset($_SERVER['PHP_AUTH_USER']) || Request::server('PHP_AUTH_USER') !== $validUser || Request::server('PHP_AUTH_PW') !== $validPass) { header('WWW-Authenticate: Basic realm="Restricted Area"'); header('HTTP/1.0 401 Unauthorized'); echo 'Unauthorized'; exit; } Artisan::call('cache:clear'); $output = Artisan::output(); return response()->json([ 'message' => trim($output), ]); })->name('cacheClear'); }); Route::middleware(['auth'])->group(function (): void { Route::redirect('settings', 'settings/profile'); Route::get('settings/profile', Profile::class)->name('settings.profile'); Route::get('settings/password', Password::class)->name('settings.password'); Route::get('settings/appearance', Appearance::class)->name('settings.appearance'); }); Route::post('/webhook/oxapay', [WebhookController::class, 'oxapay'])->name('webhook.oxapay'); require __DIR__.'/auth.php'; Route::get('{slug}', Page::class)->where('slug', '.*')->name('page')->middleware(CheckPageSlug::class);