3 namespace BookStack\Http\Controllers\Auth;
5 use BookStack\Auth\Access\Saml2Service;
6 use BookStack\Http\Controllers\Controller;
8 class Saml2Controller extends Controller
11 protected $samlService;
14 * Saml2Controller constructor.
16 public function __construct(Saml2Service $samlService)
18 parent::__construct();
19 $this->samlService = $samlService;
21 // SAML2 access middleware
22 $this->middleware(function ($request, $next) {
24 if (config('auth.method') !== 'saml2') {
25 $this->showPermissionError();
28 return $next($request);
33 * Start the login flow via SAML2.
35 public function login()
37 $loginDetails = $this->samlService->login();
38 session()->flash('saml2_request_id', $loginDetails['id']);
40 return redirect($loginDetails['url']);
44 * Start the logout flow via SAML2.
46 public function logout()
48 $logoutDetails = $this->samlService->logout();
50 if ($logoutDetails['id']) {
51 session()->flash('saml2_logout_request_id', $logoutDetails['id']);
54 return redirect($logoutDetails['url']);
58 * Get the metadata for this SAML2 service provider.
60 public function metadata()
62 $metaData = $this->samlService->metadata();
63 return response()->make($metaData, 200, [
64 'Content-Type' => 'text/xml'
69 * Single logout service.
70 * Handle logout requests and responses.
74 $requestId = session()->pull('saml2_logout_request_id', null);
75 $redirect = $this->samlService->processSlsResponse($requestId) ?? '/';
76 return redirect($redirect);
80 * Assertion Consumer Service.
81 * Processes the SAML response from the IDP.
85 $requestId = session()->pull('saml2_request_id', null);
87 $user = $this->samlService->processAcsResponse($requestId);
89 $this->showErrorNotification(trans('errors.saml_fail_authed', ['system' => config('saml2.name')]));
90 return redirect('/login');
93 session()->put('last_login_type', 'saml2');
94 return redirect()->intended();