2016-01-09 20:23:35 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace BookStack\Providers;
|
|
|
|
|
2019-12-30 15:51:28 +01:00
|
|
|
use BookStack\Api\ApiTokenGuard;
|
2020-02-01 12:42:22 +01:00
|
|
|
use BookStack\Auth\Access\ExternalBaseUserProvider;
|
|
|
|
use BookStack\Auth\Access\Guards\LdapSessionGuard;
|
2020-02-02 11:59:03 +01:00
|
|
|
use BookStack\Auth\Access\Guards\Saml2SessionGuard;
|
2020-07-01 23:27:50 +02:00
|
|
|
use BookStack\Auth\Access\Guards\OpenIdSessionGuard;
|
2018-09-25 13:30:50 +02:00
|
|
|
use BookStack\Auth\Access\LdapService;
|
2021-08-05 23:07:08 +02:00
|
|
|
use BookStack\Auth\Access\LoginService;
|
2020-07-09 18:00:16 +02:00
|
|
|
use BookStack\Auth\Access\OpenIdService;
|
2020-02-02 18:31:00 +01:00
|
|
|
use BookStack\Auth\Access\RegistrationService;
|
2021-09-26 16:48:22 +02:00
|
|
|
use Illuminate\Support\Facades\Auth;
|
2016-01-09 20:23:35 +01:00
|
|
|
use Illuminate\Support\ServiceProvider;
|
|
|
|
|
|
|
|
class AuthServiceProvider extends ServiceProvider
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Bootstrap the application services.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function boot()
|
|
|
|
{
|
2019-12-30 15:51:28 +01:00
|
|
|
Auth::extend('api-token', function ($app, $name, array $config) {
|
2021-08-05 23:07:08 +02:00
|
|
|
return new ApiTokenGuard($app['request'], $app->make(LoginService::class));
|
2019-12-30 15:51:28 +01:00
|
|
|
});
|
2020-02-01 12:42:22 +01:00
|
|
|
|
|
|
|
Auth::extend('ldap-session', function ($app, $name, array $config) {
|
|
|
|
$provider = Auth::createUserProvider($config['provider']);
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2020-02-01 12:42:22 +01:00
|
|
|
return new LdapSessionGuard(
|
|
|
|
$name,
|
|
|
|
$provider,
|
2021-08-05 23:07:08 +02:00
|
|
|
$app['session.store'],
|
2020-02-01 12:42:22 +01:00
|
|
|
$app[LdapService::class],
|
2020-02-02 18:31:00 +01:00
|
|
|
$app[RegistrationService::class]
|
2020-02-01 12:42:22 +01:00
|
|
|
);
|
|
|
|
});
|
2020-02-02 11:59:03 +01:00
|
|
|
|
|
|
|
Auth::extend('saml2-session', function ($app, $name, array $config) {
|
|
|
|
$provider = Auth::createUserProvider($config['provider']);
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2020-02-02 11:59:03 +01:00
|
|
|
return new Saml2SessionGuard(
|
|
|
|
$name,
|
|
|
|
$provider,
|
2021-08-05 23:07:08 +02:00
|
|
|
$app['session.store'],
|
2020-02-02 18:31:00 +01:00
|
|
|
$app[RegistrationService::class]
|
2020-02-02 11:59:03 +01:00
|
|
|
);
|
|
|
|
});
|
2020-07-01 23:27:50 +02:00
|
|
|
|
|
|
|
Auth::extend('openid-session', function ($app, $name, array $config) {
|
|
|
|
$provider = Auth::createUserProvider($config['provider']);
|
|
|
|
return new OpenIdSessionGuard(
|
|
|
|
$name,
|
|
|
|
$provider,
|
|
|
|
$this->app['session.store'],
|
2020-07-09 18:00:16 +02:00
|
|
|
$app[OpenIdService::class],
|
2020-07-01 23:27:50 +02:00
|
|
|
$app[RegistrationService::class]
|
|
|
|
);
|
|
|
|
});
|
2016-01-09 20:23:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Register the application services.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function register()
|
|
|
|
{
|
2020-02-01 12:42:22 +01:00
|
|
|
Auth::provider('external-users', function ($app, array $config) {
|
|
|
|
return new ExternalBaseUserProvider($config['model']);
|
2016-01-09 20:23:35 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|