223 lines
13 KiB
PHP
223 lines
13 KiB
PHP
<?php
|
|
|
|
use App\Classes\Settings\Invoices;
|
|
use App\Classes\Settings\Language;
|
|
use App\Classes\Settings\Misc;
|
|
use App\Classes\Settings\Payments;
|
|
use App\Classes\Settings\System;
|
|
use App\Http\Controllers\Admin\ActivityLogController;
|
|
use App\Http\Controllers\Admin\ApplicationApiController;
|
|
use App\Http\Controllers\Admin\InvoiceController;
|
|
use App\Http\Controllers\Admin\OverViewController;
|
|
use App\Http\Controllers\Admin\PaymentController;
|
|
use App\Http\Controllers\Admin\ProductController;
|
|
use App\Http\Controllers\Admin\ServerController as AdminServerController;
|
|
use App\Http\Controllers\Admin\SettingsController;
|
|
use App\Http\Controllers\Admin\ShopProductController;
|
|
use App\Http\Controllers\Admin\UsefulLinkController;
|
|
use App\Http\Controllers\Admin\UserController;
|
|
use App\Http\Controllers\Admin\VoucherController;
|
|
use App\Http\Controllers\Auth\SocialiteController;
|
|
use App\Http\Controllers\HomeController;
|
|
use App\Http\Controllers\Moderation\TicketsController as ModTicketsController;
|
|
use App\Http\Controllers\NotificationController;
|
|
use App\Http\Controllers\PartnerController;
|
|
use App\Http\Controllers\ProductController as FrontProductController;
|
|
use App\Http\Controllers\ProfileController;
|
|
use App\Http\Controllers\ServerController;
|
|
use App\Http\Controllers\StoreController;
|
|
use App\Http\Controllers\TicketsController;
|
|
use App\Http\Controllers\TranslationController;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Web Routes
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Here is where you can register web routes for your application. These
|
|
| routes are loaded by the RouteServiceProvider within a group which
|
|
| contains the "web" middleware group. Now create something great!
|
|
|
|
|
*/
|
|
|
|
Route::middleware('guest')->get('/', function () {
|
|
return redirect('login');
|
|
})->name('welcome');
|
|
|
|
Auth::routes(['verify' => true]);
|
|
|
|
// Stripe WebhookRoute -> validation in Route Handler
|
|
Route::post('payment/StripeWebhooks', [PaymentController::class, 'StripeWebhooks'])->name('payment.StripeWebhooks');
|
|
|
|
Route::get('/privacy', function () {
|
|
return view('information.privacy');
|
|
})->name('privacy');
|
|
Route::get('/imprint', function () {
|
|
return view('information.imprint');
|
|
})->name('imprint');
|
|
Route::get('/tos', function () {
|
|
return view('information.tos');
|
|
})->name('tos');
|
|
|
|
Route::middleware(['auth', 'checkSuspended'])->group(function () {
|
|
//resend verification email
|
|
Route::get('/email/verification-notification', function (Request $request) {
|
|
$request->user()->sendEmailVerificationNotification();
|
|
|
|
return back()->with('success', 'Verification link sent!');
|
|
})->middleware(['auth', 'throttle:3,1'])->name('verification.send');
|
|
|
|
//normal routes
|
|
Route::get('notifications/readAll', [NotificationController::class, 'readAll'])->name('notifications.readAll');
|
|
Route::resource('notifications', NotificationController::class);
|
|
Route::resource('servers', ServerController::class);
|
|
if (config('SETTINGS::SYSTEM:ENABLE_UPGRADE')) {
|
|
Route::post('servers/{server}/upgrade', [ServerController::class, 'upgrade'])->name('servers.upgrade');
|
|
}
|
|
|
|
Route::post('profile/selfdestruct', [ProfileController::class, 'selfDestroyUser'])->name('profile.selfDestroyUser');
|
|
Route::resource('profile', ProfileController::class);
|
|
Route::resource('store', StoreController::class);
|
|
|
|
//server create utility routes (product)
|
|
//routes made for server create page to fetch product info
|
|
Route::get('/products/nodes/egg/{egg?}', [FrontProductController::class, 'getNodesBasedOnEgg'])->name('products.nodes.egg');
|
|
Route::get('/products/locations/egg/{egg?}', [FrontProductController::class, 'getLocationsBasedOnEgg'])->name('products.locations.egg');
|
|
Route::get('/products/products/{egg?}/{node?}', [FrontProductController::class, 'getProductsBasedOnNode'])->name('products.products.node');
|
|
|
|
//payments
|
|
Route::get('checkout/{shopProduct}', [PaymentController::class, 'checkOut'])->name('checkout');
|
|
Route::get('payment/PaypalPay/{shopProduct}', [PaymentController::class, 'PaypalPay'])->name('payment.PaypalPay');
|
|
Route::get('payment/PaypalSuccess', [PaymentController::class, 'PaypalSuccess'])->name('payment.PaypalSuccess');
|
|
Route::get('payment/StripePay/{shopProduct}', [PaymentController::class, 'StripePay'])->name('payment.StripePay');
|
|
Route::get('payment/StripeSuccess', [PaymentController::class, 'StripeSuccess'])->name('payment.StripeSuccess');
|
|
Route::get('payment/FreePay/{shopProduct}', [PaymentController::class, 'FreePay'])->name('payment.FreePay');
|
|
Route::get('payment/Cancel', [PaymentController::class, 'Cancel'])->name('payment.Cancel');
|
|
|
|
Route::get('users/logbackin', [UserController::class, 'logBackIn'])->name('users.logbackin');
|
|
|
|
//discord
|
|
Route::get('/auth/redirect', [SocialiteController::class, 'redirect'])->name('auth.redirect');
|
|
Route::get('/auth/callback', [SocialiteController::class, 'callback'])->name('auth.callback');
|
|
|
|
//voucher redeem
|
|
Route::post('/voucher/redeem', [VoucherController::class, 'redeem'])->middleware('throttle:5,1')->name('voucher.redeem');
|
|
|
|
//switch language
|
|
Route::post('changelocale', [TranslationController::class, 'changeLocale'])->name('changeLocale');
|
|
|
|
//ticket user
|
|
if (config('SETTINGS::TICKET:ENABLED')) {
|
|
Route::get('ticket', [TicketsController::class, 'index'])->name('ticket.index');
|
|
Route::get('ticket/datatable', [TicketsController::class, 'datatable'])->name('ticket.datatable');
|
|
Route::get('ticket/new', [TicketsController::class, 'create'])->name('ticket.new');
|
|
Route::post('ticket/new', [TicketsController::class, 'store'])->middleware(['throttle:ticket-new'])->name('ticket.new.store');
|
|
Route::get('ticket/show/{ticket_id}', [TicketsController::class, 'show'])->name('ticket.show');
|
|
Route::post('ticket/reply', [TicketsController::class, 'reply'])->middleware(['throttle:ticket-reply'])->name('ticket.reply');
|
|
Route::post('ticket/close/{ticket_id}', [TicketsController::class, 'close'])->name('ticket.close');
|
|
}
|
|
|
|
//admin
|
|
Route::prefix('admin')->name('admin.')->middleware('admin')->group(function () {
|
|
|
|
//overview
|
|
Route::get('overview', [OverViewController::class, 'index'])->name('overview.index');
|
|
Route::get('overview/sync', [OverViewController::class, 'syncPterodactyl'])->name('overview.sync');
|
|
|
|
Route::resource('activitylogs', ActivityLogController::class);
|
|
|
|
//users
|
|
Route::get('users.json', [UserController::class, 'json'])->name('users.json');
|
|
Route::get('users/loginas/{user}', [UserController::class, 'loginAs'])->name('users.loginas');
|
|
Route::get('users/verifyEmail/{user}', [UserController::class, 'verifyEmail'])->name('users.verifyEmail');
|
|
Route::get('users/datatable', [UserController::class, 'datatable'])->name('users.datatable');
|
|
Route::get('users/notifications', [UserController::class, 'notifications'])->name('users.notifications');
|
|
Route::post('users/notifications', [UserController::class, 'notify'])->name('users.notifications');
|
|
Route::post('users/togglesuspend/{user}', [UserController::class, 'toggleSuspended'])->name('users.togglesuspend');
|
|
Route::resource('users', UserController::class);
|
|
|
|
//servers
|
|
Route::get('servers/datatable', [AdminServerController::class, 'datatable'])->name('servers.datatable');
|
|
Route::post('servers/togglesuspend/{server}', [AdminServerController::class, 'toggleSuspended'])->name('servers.togglesuspend');
|
|
Route::get('servers/sync', [AdminServerController::class, 'syncServers'])->name('servers.sync');
|
|
Route::resource('servers', AdminServerController::class);
|
|
|
|
//products
|
|
Route::get('products/datatable', [ProductController::class, 'datatable'])->name('products.datatable');
|
|
Route::get('products/clone/{product}', [ProductController::class, 'clone'])->name('products.clone');
|
|
Route::patch('products/disable/{product}', [ProductController::class, 'disable'])->name('products.disable');
|
|
Route::resource('products', ProductController::class);
|
|
|
|
//store
|
|
Route::get('store/datatable', [ShopProductController::class, 'datatable'])->name('store.datatable');
|
|
Route::patch('store/disable/{shopProduct}', [ShopProductController::class, 'disable'])->name('store.disable');
|
|
Route::resource('store', ShopProductController::class)->parameters([
|
|
'store' => 'shopProduct',
|
|
]);
|
|
|
|
//payments
|
|
Route::get('payments/datatable', [PaymentController::class, 'datatable'])->name('payments.datatable');
|
|
Route::get('payments', [PaymentController::class, 'index'])->name('payments.index');
|
|
|
|
//settings
|
|
Route::get('settings/datatable', [SettingsController::class, 'datatable'])->name('settings.datatable');
|
|
Route::patch('settings/updatevalue', [SettingsController::class, 'updatevalue'])->name('settings.updatevalue');
|
|
Route::get('settings/checkPteroClientkey', [System::class, 'checkPteroClientkey'])->name('settings.checkPteroClientkey');
|
|
Route::redirect('settings#system', 'system')->name('settings.system');
|
|
|
|
//settings
|
|
Route::patch('settings/update/invoice-settings', [Invoices::class, 'updateSettings'])->name('settings.update.invoicesettings');
|
|
Route::patch('settings/update/language', [Language::class, 'updateSettings'])->name('settings.update.languagesettings');
|
|
Route::patch('settings/update/payment', [Payments::class, 'updateSettings'])->name('settings.update.paymentsettings');
|
|
Route::patch('settings/update/misc', [Misc::class, 'updateSettings'])->name('settings.update.miscsettings');
|
|
Route::patch('settings/update/system', [System::class, 'updateSettings'])->name('settings.update.systemsettings');
|
|
Route::resource('settings', SettingsController::class)->only('index');
|
|
|
|
//invoices
|
|
Route::get('invoices/download-invoices', [InvoiceController::class, 'downloadAllInvoices'])->name('invoices.downloadAllInvoices');
|
|
Route::get('invoices/download-single-invoice', [InvoiceController::class, 'downloadSingleInvoice'])->name('invoices.downloadSingleInvoice');
|
|
|
|
//usefullinks
|
|
Route::get('usefullinks/datatable', [UsefulLinkController::class, 'datatable'])->name('usefullinks.datatable');
|
|
Route::resource('usefullinks', UsefulLinkController::class);
|
|
|
|
//vouchers
|
|
Route::get('vouchers/datatable', [VoucherController::class, 'datatable'])->name('vouchers.datatable');
|
|
Route::get('vouchers/{voucher}/usersdatatable', [VoucherController::class, 'usersdatatable'])->name('vouchers.usersdatatable');
|
|
Route::get('vouchers/{voucher}/users', [VoucherController::class, 'users'])->name('vouchers.users');
|
|
Route::resource('vouchers', VoucherController::class);
|
|
|
|
//partners
|
|
Route::get('partners/datatable', [PartnerController::class, 'datatable'])->name('partners.datatable');
|
|
Route::get('partners/{voucher}/users', [PartnerController::class, 'users'])->name('partners.users');
|
|
Route::resource('partners', PartnerController::class);
|
|
|
|
//api-keys
|
|
Route::get('api/datatable', [ApplicationApiController::class, 'datatable'])->name('api.datatable');
|
|
Route::resource('api', ApplicationApiController::class)->parameters([
|
|
'api' => 'applicationApi',
|
|
]);
|
|
});
|
|
|
|
//mod
|
|
Route::prefix('moderator')->name('moderator.')->middleware('moderator')->group(function () {
|
|
//ticket moderation
|
|
Route::get('ticket', [ModTicketsController::class, 'index'])->name('ticket.index');
|
|
Route::get('ticket/datatable', [ModTicketsController::class, 'datatable'])->name('ticket.datatable');
|
|
Route::get('ticket/show/{ticket_id}', [ModTicketsController::class, 'show'])->name('ticket.show');
|
|
Route::post('ticket/reply', [ModTicketsController::class, 'reply'])->name('ticket.reply');
|
|
Route::post('ticket/close/{ticket_id}', [ModTicketsController::class, 'close'])->name('ticket.close');
|
|
Route::post('ticket/delete/{ticket_id}', [ModTicketsController::class, 'delete'])->name('ticket.delete');
|
|
//ticket moderation blacklist
|
|
Route::get('ticket/blacklist', [ModTicketsController::class, 'blacklist'])->name('ticket.blacklist');
|
|
Route::post('ticket/blacklist', [ModTicketsController::class, 'blacklistAdd'])->name('ticket.blacklist.add');
|
|
Route::post('ticket/blacklist/delete/{id}', [ModTicketsController::class, 'blacklistDelete'])->name('ticket.blacklist.delete');
|
|
Route::post('ticket/blacklist/change/{id}', [ModTicketsController::class, 'blacklistChange'])->name('ticket.blacklist.change');
|
|
Route::get('ticket/blacklist/datatable', [ModTicketsController::class, 'dataTableBlacklist'])->name('ticket.blacklist.datatable');
|
|
});
|
|
|
|
Route::get('/home', [HomeController::class, 'index'])->name('home');
|
|
});
|