3 namespace BookStack\Providers;
6 use BookStack\Api\ApiTokenGuard;
7 use BookStack\Auth\Access\ExternalBaseUserProvider;
8 use BookStack\Auth\Access\Guards\LdapSessionGuard;
9 use BookStack\Auth\Access\Guards\Saml2SessionGuard;
10 use BookStack\Auth\Access\LdapService;
11 use BookStack\Auth\Access\LoginService;
12 use BookStack\Auth\Access\RegistrationService;
13 use Illuminate\Support\ServiceProvider;
15 class AuthServiceProvider extends ServiceProvider
18 * Bootstrap the application services.
22 public function boot()
24 Auth::extend('api-token', function ($app, $name, array $config) {
25 return new ApiTokenGuard($app['request'], $app->make(LoginService::class));
28 Auth::extend('ldap-session', function ($app, $name, array $config) {
29 $provider = Auth::createUserProvider($config['provider']);
31 return new LdapSessionGuard(
34 $app['session.store'],
35 $app[LdapService::class],
36 $app[RegistrationService::class]
40 Auth::extend('saml2-session', function ($app, $name, array $config) {
41 $provider = Auth::createUserProvider($config['provider']);
43 return new Saml2SessionGuard(
46 $app['session.store'],
47 $app[RegistrationService::class]
53 * Register the application services.
57 public function register()
59 Auth::provider('external-users', function ($app, array $config) {
60 return new ExternalBaseUserProvider($config['model']);