osb/routes/web.php

162 lines
6.7 KiB
PHP
Raw Normal View History

2017-11-03 16:26:07 +11:00
<?php
use Leenooks\Controllers\AdminController as LeenooksAdminController;
use App\Http\Controllers\{AdminController,
Auth\LoginController,
2021-07-13 15:00:01 +10:00
Auth\SocialLoginController,
CostController,
2021-07-01 09:21:18 +10:00
CheckoutController,
HomeController,
MediaController,
2021-07-09 11:39:27 +10:00
OrderController,
PaypalController,
ProductController,
SearchController,
ServiceController,
WelcomeController};
2021-06-28 11:06:44 +10:00
2017-11-03 16:26:07 +11:00
/*
|--------------------------------------------------------------------------
| Web Routes
2017-11-03 16:26:07 +11:00
|--------------------------------------------------------------------------
|
| 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!
2017-11-03 16:26:07 +11:00
|
*/
2018-07-31 14:11:00 +10:00
Auth::routes();
Route::get('logout',[LoginController::class,'logout']);
// Account linking to OPENID host
2019-09-03 14:43:59 +10:00
Route::group(['middleware'=>['theme:adminlte-be']],function() {
2021-07-13 15:00:01 +10:00
Route::get('auth/{socialProvider}',[SocialLoginController::class,'redirectToProvider']);
Route::get('auth/{socialProvider}/callback',[SocialLoginController::class,'handleProviderCallback']);
Route::get('auth/{socialProvider}/link',[SocialLoginController::class,'link']);
Route::post('auth/{socialProvider}/linkcomplete',[SocialLoginController::class,'linkcomplete']);
2019-09-03 14:43:59 +10:00
});
2017-12-04 23:37:14 +11:00
// Generic Image Renderer - Render images that we dont have with a generic image
Route::get('image/generic/{width}/{height}/{color}/{name?}',[MediaController::class,'image'])->name('image');
2017-12-04 23:37:14 +11:00
// Our Admin Routes - for wholesalers
Route::group(['middleware'=>['theme:adminlte-be','auth','role:wholesaler'],'prefix'=>'a'],function() {
2021-12-20 14:25:43 +11:00
// Site Setup
Route::match(['get','post'],'setup',[AdminController::class,'setup']);
// Product Setup
Route::match(['get'],'product',[ProductController::class,'home']);
Route::match(['get','post'],'product/details/{o?}',[ProductController::class,'details']);
2021-12-20 14:25:43 +11:00
// Supplier Setup
// @todo Move to Supplier Controller
2021-12-20 14:25:43 +11:00
Route::match(['get'],'supplier',[AdminController::class,'supplier']);
Route::match(['get','post'],'supplier/details/{o?}',[AdminController::class,'supplier_addedit']);
2021-12-20 14:25:43 +11:00
// Route::get('service/{o}','AdminHomeController@service');
// Route::post('service/{o}','AdminHomeController@service_update');
// Route::get('report/products','Wholesale\ReportController@products');
// Charges
Route::match(['get','post'],'charge/addedit/{o?}',[AdminController::class,'charge_addedit']);
Route::get('charge/unprocessed',[AdminController::class,'charge_unprocessed']);
// Payments
Route::match(['get','post'],'payment/addedit/{o?}',[AdminController::class,'pay_addedit']);
Route::get('payment/unapplied',[AdminController::class,'pay_unapplied']);
2022-02-01 16:40:46 +11:00
Route::post('service/edit/{o}',[ServiceController::class,'update'])
->where('o','[0-9]+')
->middleware('can:update,o');
//Route::get('accounting/connect','AccountingController@connect');
Route::get('cost/{o}',[CostController::class,'home'])
->where('o','[0-9]+')
->middleware('can:view,o');
});
2018-05-20 22:53:14 +10:00
Route::get('admin/switch/stop',[LeenooksAdminController::class,'user_switch_stop'])->name('switch.user.start')->middleware('auth');
2018-08-01 17:09:38 +10:00
2018-07-31 14:11:00 +10:00
// Our Reseller Routes
Route::group(['middleware'=>['theme:adminlte-be','auth','role:reseller'],'prefix'=>'r'],function() {
// Route::get('supplier/index','SuppliersController@index');
// Route::get('supplier/create','SuppliersController@create');
// Route::post('supplier/store','SuppliersController@store');
Route::get('switch/start/{id}',[LeenooksAdminController::class,'user_switch_start'])->name('switch.user.stop');
Route::group(['middleware'=>['theme:adminlte-be','auth','role:reseller'],'prefix'=>'report'],function() {
Route::get('domain',[ServiceController::class,'domain_list']);
Route::get('email',[ServiceController::class,'email_list']);
Route::get('hosting',[ServiceController::class,'hosting_list']);
});
// Charges on an account
Route::get('charges/{o}',[AdminController::class,'charge_pending_account'])
->where('o','[0-9]+');
// Reseller API calls
Route::post('service_change_charges/{o}',[ServiceController::class,'service_change_charges_display'])
->where('o','[0-9]+');
2018-07-31 14:11:00 +10:00
});
// Our User Routes
Route::group(['middleware'=>['theme:adminlte-be','auth'],'prefix'=>'u'],function() {
2021-06-28 11:06:44 +10:00
Route::get('home',[HomeController::class,'home']);
2021-06-29 16:36:34 +10:00
Route::get('home/{o}',[HomeController::class,'home'])
->where('o','[0-9]+')
->middleware('can:view,o');
// Route::get('account/{o}/invoice','User\AccountController@view_invoice_next')
// ->where('o','[0-9]+')
// ->middleware('can:view,o');
Route::post('checkout/pay',[CheckoutController::class,'pay']);
2021-06-29 16:36:34 +10:00
Route::get('invoice/{o}',[HomeController::class,'invoice'])
->where('o','[0-9]+')
->middleware('can:view,o');
2021-06-29 16:36:34 +10:00
Route::get('invoice/{o}/pdf',[HomeController::class,'invoice_pdf'])
2020-07-27 14:49:59 +10:00
->where('o','[0-9]+')
->middleware('can:view,o');
Route::get('invoice/cart',[CheckoutController::class,'cart_invoice']);
Route::get('invoice/cart/{o}',[CheckoutController::class,'cart_invoice'])
->where('o','[0-9]+')
->middleware('can:view,o');
2021-06-29 16:36:34 +10:00
Route::get('service/{o}',[HomeController::class,'service'])
->where('o','[0-9]+')
->middleware('can:view,o');
2021-09-29 14:57:25 +10:00
Route::match(['get','post'],'service/{o}/cancel-request',[ServiceController::class,'cancel_request'])
->where('o','[0-9]+')
2021-09-29 17:11:46 +10:00
->middleware('can:progress,o,"cancel-request"');
2021-09-29 14:57:25 +10:00
Route::match(['get','post'],'service/{o}/change-request',[ServiceController::class,'change_request'])
->where('o','[0-9]+')
2021-09-29 17:11:46 +10:00
->middleware('can:progress,o,"change-request"');
// @todo This shouldnt be a user privilege.
Route::match(['get','post'],'service/{o}/change-pending',[ServiceController::class,'change_pending'])
->where('o','[0-9]+')
->middleware('can:progress,o,"change-pending"');
2021-09-29 14:57:25 +10:00
Route::get('service/{o}/change/{status}',[ServiceController::class,'change'])
->where('o','[0-9]+')
->middleware('can:progress,o,status');
2018-07-31 14:11:00 +10:00
});
2020-05-25 17:45:17 +10:00
// Doorman Code Routes
Route::group(['middleware'=>['theme:adminlte-be'],'prefix'=>'u'],function() {
Route::get('invoice/{o}/email/{code}',[HomeController::class,'invoice_pdf_email'])
->where('o','[0-9]+')
->where('code','[0-9A-Z]{6}');
2020-05-25 17:45:17 +10:00
});
2018-07-31 14:11:00 +10:00
// Frontend Routes (Non-Authed Users)
Route::group(['middleware'=>['theme:metronic-fe']],function() {
2021-06-28 11:06:44 +10:00
Route::get('/',[WelcomeController::class,'home']);
2021-07-09 11:39:27 +10:00
Route::get('order',[OrderController::class,'index']);
Route::post('order',[OrderController::class,'submit']);
2018-05-20 22:53:14 +10:00
});
2021-07-09 11:39:27 +10:00
Route::get('product_order/{o}',[OrderController::class,'product_order']);
Route::get('product_info/{o}',[OrderController::class,'product_info']);
2020-07-27 14:49:59 +10:00
Route::redirect('home','u/home');
Route::get('search',[SearchController::class,'search']);
Route::get('pay/paypal/authorise',[PaypalController::class,'authorise']);
Route::get('pay/paypal/cancel',[PaypalController::class,'cancel']);
Route::get('pay/paypal/capture',[PaypalController::class,'capture']);