mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-11-26 18:30:50 +08:00
Updated okta config keys, made SVG fully vector
Also added some additional error handling to login.
This commit is contained in:
parent
d17eb0f54c
commit
90bf13c1ab
|
@ -250,15 +250,27 @@ class RegisterController extends Controller
|
||||||
/**
|
/**
|
||||||
* The callback for social login services.
|
* The callback for social login services.
|
||||||
* @param $socialDriver
|
* @param $socialDriver
|
||||||
|
* @param Request $request
|
||||||
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
||||||
* @throws SocialSignInException
|
* @throws SocialSignInException
|
||||||
|
* @throws UserRegistrationException
|
||||||
|
* @throws \BookStack\Exceptions\SocialDriverNotConfigured
|
||||||
|
* @throws ConfirmationEmailException
|
||||||
*/
|
*/
|
||||||
public function socialCallback($socialDriver)
|
public function socialCallback($socialDriver, Request $request)
|
||||||
{
|
{
|
||||||
if (!session()->has('social-callback')) {
|
if (!session()->has('social-callback')) {
|
||||||
throw new SocialSignInException(trans('errors.social_no_action_defined'), '/login');
|
throw new SocialSignInException(trans('errors.social_no_action_defined'), '/login');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check request for error information
|
||||||
|
if ($request->has('error') && $request->has('error_description')) {
|
||||||
|
throw new SocialSignInException(trans('errors.social_login_bad_response', [
|
||||||
|
'socialAccount' => $socialDriver,
|
||||||
|
'error' => $request->get('error_description'),
|
||||||
|
]), '/login');
|
||||||
|
}
|
||||||
|
|
||||||
$action = session()->pull('social-callback');
|
$action = session()->pull('social-callback');
|
||||||
if ($action == 'login') return $this->socialAuthService->handleLoginCallback($socialDriver);
|
if ($action == 'login') return $this->socialAuthService->handleLoginCallback($socialDriver);
|
||||||
if ($action == 'register') return $this->socialRegisterCallback($socialDriver);
|
if ($action == 'register') return $this->socialRegisterCallback($socialDriver);
|
||||||
|
@ -279,7 +291,9 @@ class RegisterController extends Controller
|
||||||
* Register a new user after a registration callback.
|
* Register a new user after a registration callback.
|
||||||
* @param $socialDriver
|
* @param $socialDriver
|
||||||
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
||||||
|
* @throws ConfirmationEmailException
|
||||||
* @throws UserRegistrationException
|
* @throws UserRegistrationException
|
||||||
|
* @throws \BookStack\Exceptions\SocialDriverNotConfigured
|
||||||
*/
|
*/
|
||||||
protected function socialRegisterCallback($socialDriver)
|
protected function socialRegisterCallback($socialDriver)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
<?php namespace BookStack\Services;
|
<?php namespace BookStack\Services;
|
||||||
|
|
||||||
|
use BookStack\Http\Requests\Request;
|
||||||
|
use GuzzleHttp\Exception\ClientException;
|
||||||
use Laravel\Socialite\Contracts\Factory as Socialite;
|
use Laravel\Socialite\Contracts\Factory as Socialite;
|
||||||
use BookStack\Exceptions\SocialDriverNotConfigured;
|
use BookStack\Exceptions\SocialDriverNotConfigured;
|
||||||
use BookStack\Exceptions\SocialSignInException;
|
use BookStack\Exceptions\SocialSignInException;
|
||||||
|
@ -91,7 +93,6 @@ class SocialAuthService
|
||||||
public function handleLoginCallback($socialDriver)
|
public function handleLoginCallback($socialDriver)
|
||||||
{
|
{
|
||||||
$driver = $this->validateDriver($socialDriver);
|
$driver = $this->validateDriver($socialDriver);
|
||||||
|
|
||||||
// Get user details from social driver
|
// Get user details from social driver
|
||||||
$socialUser = $this->socialite->driver($driver)->user();
|
$socialUser = $this->socialite->driver($driver)->user();
|
||||||
$socialId = $socialUser->getId();
|
$socialId = $socialUser->getId();
|
||||||
|
@ -135,7 +136,7 @@ class SocialAuthService
|
||||||
$message .= trans('errors.social_account_register_instructions', ['socialAccount' => title_case($socialDriver)]);
|
$message .= trans('errors.social_account_register_instructions', ['socialAccount' => title_case($socialDriver)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new SocialSignInException($message . '.', '/login');
|
throw new SocialSignInException($message, '/login');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -81,8 +81,8 @@ return [
|
||||||
],
|
],
|
||||||
|
|
||||||
'okta' => [
|
'okta' => [
|
||||||
'client_id' => env('OKTA_KEY'),
|
'client_id' => env('OKTA_APP_ID'),
|
||||||
'client_secret' => env('OKTA_SECRET'),
|
'client_secret' => env('OKTA_APP_SECRET'),
|
||||||
'redirect' => env('APP_URL') . '/login/service/okta/callback',
|
'redirect' => env('APP_URL') . '/login/service/okta/callback',
|
||||||
'base_url' => env('OKTA_BASE_URL'),
|
'base_url' => env('OKTA_BASE_URL'),
|
||||||
'name' => 'Okta',
|
'name' => 'Okta',
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
<svg viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.41421;"><use id="image0" xlink:href="#_Image1" x="0" y="0" width="64px" height="64px"/><defs><image id="_Image1" width="24px" height="24px" xlink:href=""/></defs></svg>
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414"><path d="M12 0A12 12 0 0 0 0 12a12 12 0 0 0 12 12 12 12 0 0 0 12-12A12 12 0 0 0 12 0zm-.035 5.537a6.427 6.427 0 0 1 6.428 6.428 6.427 6.427 0 0 1-6.428 6.428 6.427 6.427 0 0 1-6.428-6.428 6.427 6.427 0 0 1 6.428-6.428z" fill="#007dc1"/></svg>
|
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 392 B |
|
@ -20,6 +20,7 @@ return [
|
||||||
'ldap_extension_not_installed' => 'LDAP PHP extension not installed',
|
'ldap_extension_not_installed' => 'LDAP PHP extension not installed',
|
||||||
'ldap_cannot_connect' => 'Cannot connect to ldap server, Initial connection failed',
|
'ldap_cannot_connect' => 'Cannot connect to ldap server, Initial connection failed',
|
||||||
'social_no_action_defined' => 'No action defined',
|
'social_no_action_defined' => 'No action defined',
|
||||||
|
'social_login_bad_response' => "Error received during :socialAccount login: \n:error",
|
||||||
'social_account_in_use' => 'This :socialAccount account is already in use, Try logging in via the :socialAccount option.',
|
'social_account_in_use' => 'This :socialAccount account is already in use, Try logging in via the :socialAccount option.',
|
||||||
'social_account_email_in_use' => 'The email :email is already in use. If you already have an account you can connect your :socialAccount account from your profile settings.',
|
'social_account_email_in_use' => 'The email :email is already in use. If you already have an account you can connect your :socialAccount account from your profile settings.',
|
||||||
'social_account_existing' => 'This :socialAccount is already attached to your profile.',
|
'social_account_existing' => 'This :socialAccount is already attached to your profile.',
|
||||||
|
|
Loading…
Reference in New Issue
Block a user