first initial

This commit is contained in:
2025-05-27 19:09:17 +07:00
commit 80375d8af3
1587 changed files with 572586 additions and 0 deletions

View File

@@ -0,0 +1,38 @@
<?php
namespace App\Providers;
use App\Models\Menu;
use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\View;
class AppServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
View::composer(['layouts.partials.sidebarMenu', 'dashboard', 'dealer_recap', 'back.*'], function ($view) {
$menuQuery = Menu::all();
$menus = [];
foreach($menuQuery as $menu) {
$menus[$menu->link] = $menu;
}
$view->with('menus', $menus);
});
}
}

View File

@@ -0,0 +1,103 @@
<?php
namespace App\Providers;
use App\Models\Menu;
use App\Models\Privilege;
use App\Models\User;
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Gate;
class AuthServiceProvider extends ServiceProvider
{
/**
* The policy mappings for the application.
*
* @var array<class-string, class-string>
*/
protected $policies = [
// 'App\Models\Model' => 'App\Policies\ModelPolicy',
];
/**
* Register any authentication / authorization services.
*
* @return void
*/
public function boot()
{
$this->registerPolicies();
Gate::define(
'create',
function (User $user, Menu $menu) {
$role_id = $user->role_id;
$privilegeData = Privilege::where('role_id', $role_id)
->where('menu_id', $menu->id)
->where('create', 1)
->first();
$privilegeData ? $privilege = true : $privilege = false;
if($role_id == 0) {
$privilege = true;
}
return $privilege;
}
);
Gate::define(
'update',
function (User $user, Menu $menu) {
$role_id = $user->role_id;
$privilegeData = Privilege::where('role_id', $role_id)
->where('menu_id', $menu->id)
->where('update', 1)
->first();
$privilegeData ? $privilege = true : $privilege = false;
if($role_id == 0) {
$privilege = true;
}
return $privilege;
}
);
Gate::define(
'delete',
function (User $user, Menu $menu) {
$role_id = $user->role_id;
$privilegeData = Privilege::where('role_id', $role_id)
->where('menu_id', $menu->id)
->where('delete', 1)
->first();
$privilegeData ? $privilege = true : $privilege = false;
if($role_id == 0) {
$privilege = true;
}
return $privilege;
}
);
Gate::define(
'view',
function (User $user, Menu $menu) {
$role_id = $user->role_id;
$privilegeData = Privilege::where('role_id', $role_id)
->where('menu_id', $menu->id)
->where('view', 1)
->first();
$privilegeData ? $privilege = true : $privilege = false;
if($role_id == 0) {
$privilege = true;
}
return $privilege;
}
);
}
}

View File

@@ -0,0 +1,21 @@
<?php
namespace App\Providers;
use Illuminate\Support\Facades\Broadcast;
use Illuminate\Support\ServiceProvider;
class BroadcastServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
Broadcast::routes();
require base_path('routes/channels.php');
}
}

View File

@@ -0,0 +1,32 @@
<?php
namespace App\Providers;
use Illuminate\Auth\Events\Registered;
use Illuminate\Auth\Listeners\SendEmailVerificationNotification;
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Event;
class EventServiceProvider extends ServiceProvider
{
/**
* The event listener mappings for the application.
*
* @var array<class-string, array<int, class-string>>
*/
protected $listen = [
Registered::class => [
SendEmailVerificationNotification::class,
],
];
/**
* Register any events for your application.
*
* @return void
*/
public function boot()
{
//
}
}

View File

@@ -0,0 +1,63 @@
<?php
namespace App\Providers;
use Illuminate\Cache\RateLimiting\Limit;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\RateLimiter;
use Illuminate\Support\Facades\Route;
class RouteServiceProvider extends ServiceProvider
{
/**
* The path to the "home" route for your application.
*
* This is used by Laravel authentication to redirect users after login.
*
* @var string
*/
public const HOME = '/';
/**
* The controller namespace for the application.
*
* When present, controller route declarations will automatically be prefixed with this namespace.
*
* @var string|null
*/
// protected $namespace = 'App\\Http\\Controllers';
/**
* Define your route model bindings, pattern filters, etc.
*
* @return void
*/
public function boot()
{
$this->configureRateLimiting();
$this->routes(function () {
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
});
}
/**
* Configure the rate limiters for the application.
*
* @return void
*/
protected function configureRateLimiting()
{
RateLimiter::for('api', function (Request $request) {
return Limit::perMinute(60)->by(optional($request->user())->id ?: $request->ip());
});
}
}