mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
* Install bouncer * Seeder and level migration * Display and edit roles * remove unused deluser page * Update Radius and SSO to assign roles * update AlertUtil direct level check to use roles instead * rewrite ircbot auth handling * Remove legacy auth getUserlist and getUserlevel methods, add getRoles Set roles in LegacyUserProvider * Small cleanups * centralize role sync code show roles on user preferences page * VueSelect component WIP and a little docs * WIP * SelectControllers id and text fields. * LibrenmsSelect component extracted from SettingSelectDynamic * Handle multiple selections * allow type coercion * full width settings * final style adjustments * Final compiled assets update * Style fixes * Fix SSO tests * Lint cleanups * small style fix * don't use json yet * Update baseline for usptream package issues * Change schema, not 100% sure it is correct not sure why xor doesn't work
66 lines
2.1 KiB
PHP
66 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Providers;
|
|
|
|
use App\Guards\ApiTokenGuard;
|
|
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Support\Facades\Gate;
|
|
use Silber\Bouncer\BouncerFacade as Bouncer;
|
|
|
|
class AuthServiceProvider extends ServiceProvider
|
|
{
|
|
/**
|
|
* The policy mappings for the application.
|
|
*
|
|
* @var array<class-string, class-string>
|
|
*/
|
|
protected $policies = [
|
|
\App\Models\User::class => \App\Policies\UserPolicy::class,
|
|
\App\Models\Dashboard::class => \App\Policies\DashboardPolicy::class,
|
|
\App\Models\Device::class => \App\Policies\DevicePolicy::class,
|
|
\App\Models\DeviceGroup::class => \App\Policies\DeviceGroupPolicy::class,
|
|
\App\Models\PollerCluster::class => \App\Policies\PollerClusterPolicy::class,
|
|
\App\Models\Port::class => \App\Policies\PortPolicy::class,
|
|
\App\Models\ServiceTemplate::class => \App\Policies\ServiceTemplatePolicy::class,
|
|
];
|
|
|
|
/**
|
|
* Register any authentication / authorization services.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function boot(): void
|
|
{
|
|
Bouncer::cache();
|
|
|
|
Auth::provider('legacy', function ($app, array $config) {
|
|
return new LegacyUserProvider();
|
|
});
|
|
|
|
Auth::provider('token_provider', function ($app, array $config) {
|
|
return new TokenUserProvider();
|
|
});
|
|
|
|
Auth::extend('token_driver', function ($app, $name, array $config) {
|
|
$userProvider = $app->make(TokenUserProvider::class);
|
|
$request = $app->make('request');
|
|
|
|
return new ApiTokenGuard($userProvider, $request);
|
|
});
|
|
|
|
Gate::define('global-admin', function ($user) {
|
|
return $user->hasGlobalAdmin();
|
|
});
|
|
Gate::define('admin', function ($user) {
|
|
return $user->isAdmin();
|
|
});
|
|
Gate::define('global-read', function ($user) {
|
|
return $user->hasGlobalRead();
|
|
});
|
|
Gate::define('device', function ($user, $device) {
|
|
return $user->canAccessDevice($device);
|
|
});
|
|
}
|
|
}
|