| 
									
										
										
										
											2016-08-14 19:29:35 +08:00
										 |  |  | <?php namespace BookStack\Http\Controllers\Auth; | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-03 18:16:49 +08:00
										 |  |  | use BookStack\Exceptions\AuthException; | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  | use Illuminate\Contracts\Auth\Authenticatable; | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2015-09-11 02:31:09 +08:00
										 |  |  | use BookStack\Exceptions\SocialSignInException; | 
					
						
							|  |  |  | use BookStack\Exceptions\UserRegistrationException; | 
					
						
							|  |  |  | use BookStack\Repos\UserRepo; | 
					
						
							|  |  |  | use BookStack\Services\EmailConfirmationService; | 
					
						
							|  |  |  | use BookStack\Services\SocialAuthService; | 
					
						
							|  |  |  | use BookStack\SocialAccount; | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | use Validator; | 
					
						
							| 
									
										
										
										
											2015-09-11 02:31:09 +08:00
										 |  |  | use BookStack\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | use Illuminate\Foundation\Auth\ThrottlesLogins; | 
					
						
							|  |  |  | use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class AuthController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /* | 
					
						
							|  |  |  |     |-------------------------------------------------------------------------- | 
					
						
							|  |  |  |     | Registration & Login Controller | 
					
						
							|  |  |  |     |-------------------------------------------------------------------------- | 
					
						
							|  |  |  |     | | 
					
						
							|  |  |  |     | This controller handles the registration of new users, as well as the | 
					
						
							|  |  |  |     | authentication of existing users. By default, this controller uses | 
					
						
							|  |  |  |     | a simple trait to add these behaviors. Why don't you explore it? | 
					
						
							|  |  |  |     | | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     use AuthenticatesAndRegistersUsers, ThrottlesLogins; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-06 03:59:39 +08:00
										 |  |  |     protected $redirectPath = '/'; | 
					
						
							| 
									
										
										
										
											2015-08-06 04:16:10 +08:00
										 |  |  |     protected $redirectAfterLogout = '/login'; | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |     protected $username = 'email'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 00:50:52 +08:00
										 |  |  |     protected $socialAuthService; | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |     protected $emailConfirmationService; | 
					
						
							|  |  |  |     protected $userRepo; | 
					
						
							| 
									
										
										
										
											2015-08-06 03:59:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Create a new authentication controller instance. | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |      * @param SocialAuthService $socialAuthService | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |      * @param EmailConfirmationService $emailConfirmationService | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |      * @param UserRepo $userRepo | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |     public function __construct(SocialAuthService $socialAuthService, EmailConfirmationService $emailConfirmationService, UserRepo $userRepo) | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         $this->middleware('guest', ['only' => ['getLogin', 'postLogin', 'getRegister', 'postRegister']]); | 
					
						
							| 
									
										
										
										
											2015-09-05 00:50:52 +08:00
										 |  |  |         $this->socialAuthService = $socialAuthService; | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |         $this->emailConfirmationService = $emailConfirmationService; | 
					
						
							|  |  |  |         $this->userRepo = $userRepo; | 
					
						
							| 
									
										
										
										
											2016-08-14 19:29:35 +08:00
										 |  |  |         $this->redirectPath = baseUrl('/'); | 
					
						
							|  |  |  |         $this->redirectAfterLogout = baseUrl('/login'); | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |         $this->username = config('auth.method') === 'standard' ? 'email' : 'username'; | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get a validator for an incoming registration request. | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |      * @param  array $data | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |      * @return \Illuminate\Contracts\Validation\Validator | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function validator(array $data) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Validator::make($data, [ | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |             'name' => 'required|max:255', | 
					
						
							|  |  |  |             'email' => 'required|email|max:255|unique:users', | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |             'password' => 'required|min:6', | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  |         ]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |     protected function checkRegistrationAllowed() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |         if (!setting('registration-enabled')) { | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |             throw new UserRegistrationException('Registrations are currently disabled.', '/login'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 00:42:05 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Show the application registration form. | 
					
						
							|  |  |  |      * @return \Illuminate\Http\Response | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getRegister() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |         $this->checkRegistrationAllowed(); | 
					
						
							| 
									
										
										
										
											2015-09-06 00:42:05 +08:00
										 |  |  |         $socialDrivers = $this->socialAuthService->getActiveDrivers(); | 
					
						
							|  |  |  |         return view('auth.register', ['socialDrivers' => $socialDrivers]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Handle a registration request for the application. | 
					
						
							|  |  |  |      * @param  \Illuminate\Http\Request $request | 
					
						
							|  |  |  |      * @return \Illuminate\Http\Response | 
					
						
							|  |  |  |      * @throws UserRegistrationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function postRegister(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->checkRegistrationAllowed(); | 
					
						
							|  |  |  |         $validator = $this->validator($request->all()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($validator->fails()) { | 
					
						
							|  |  |  |             $this->throwValidationException( | 
					
						
							|  |  |  |                 $request, $validator | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         $userData = $request->all(); | 
					
						
							|  |  |  |         return $this->registerUser($userData); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Overrides the action when a user is authenticated. | 
					
						
							|  |  |  |      * If the user authenticated but does not exist in the user table we create them. | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |      * @param Request $request | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |      * @param Authenticatable $user | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							| 
									
										
										
										
											2016-04-03 18:16:49 +08:00
										 |  |  |      * @throws AuthException | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |      */ | 
					
						
							|  |  |  |     protected function authenticated(Request $request, Authenticatable $user) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-16 07:21:47 +08:00
										 |  |  |         // Explicitly log them out for now if they do no exist.
 | 
					
						
							|  |  |  |         if (!$user->exists) auth()->logout($user); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!$user->exists && $user->email === null && !$request->has('email')) { | 
					
						
							| 
									
										
										
										
											2016-01-14 06:22:30 +08:00
										 |  |  |             $request->flash(); | 
					
						
							|  |  |  |             session()->flash('request-email', true); | 
					
						
							|  |  |  |             return redirect('/login'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 07:21:47 +08:00
										 |  |  |         if (!$user->exists && $user->email === null && $request->has('email')) { | 
					
						
							| 
									
										
										
										
											2016-01-14 06:22:30 +08:00
										 |  |  |             $user->email = $request->get('email'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 07:21:47 +08:00
										 |  |  |         if (!$user->exists) { | 
					
						
							| 
									
										
										
										
											2016-04-03 18:16:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // Check for users with same email already
 | 
					
						
							|  |  |  |             $alreadyUser = $user->newQuery()->where('email', '=', $user->email)->count() > 0; | 
					
						
							|  |  |  |             if ($alreadyUser) { | 
					
						
							|  |  |  |                 throw new AuthException('A user with the email ' . $user->email . ' already exists but with different credentials.'); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |             $user->save(); | 
					
						
							|  |  |  |             $this->userRepo->attachDefaultRole($user); | 
					
						
							|  |  |  |             auth()->login($user); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-14 06:22:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-21 21:49:40 +08:00
										 |  |  |         $path = session()->pull('url.intended', '/'); | 
					
						
							|  |  |  |         $path = baseUrl($path, true); | 
					
						
							|  |  |  |         return redirect($path); | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Register a new user after a registration callback. | 
					
						
							|  |  |  |      * @param $socialDriver | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws UserRegistrationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function socialRegisterCallback($socialDriver) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $socialUser = $this->socialAuthService->handleRegistrationCallback($socialDriver); | 
					
						
							|  |  |  |         $socialAccount = $this->socialAuthService->fillSocialAccount($socialDriver, $socialUser); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Create an array of the user data to create a new user instance
 | 
					
						
							|  |  |  |         $userData = [ | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |             'name' => $socialUser->getName(), | 
					
						
							|  |  |  |             'email' => $socialUser->getEmail(), | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |             'password' => str_random(30) | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         return $this->registerUser($userData, $socialAccount); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The registrations flow for all users. | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |      * @param array $userData | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |      * @param bool|false|SocialAccount $socialAccount | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws UserRegistrationException | 
					
						
							| 
									
										
										
										
											2015-09-11 02:31:09 +08:00
										 |  |  |      * @throws \BookStack\Exceptions\ConfirmationEmailException | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |      */ | 
					
						
							|  |  |  |     protected function registerUser(array $userData, $socialAccount = false) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |         if (setting('registration-restrict')) { | 
					
						
							|  |  |  |             $restrictedEmailDomains = explode(',', str_replace(' ', '', setting('registration-restrict'))); | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |             $userEmailDomain = $domain = substr(strrchr($userData['email'], "@"), 1); | 
					
						
							|  |  |  |             if (!in_array($userEmailDomain, $restrictedEmailDomains)) { | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |                 throw new UserRegistrationException('That email domain does not have access to this application', '/register'); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         $newUser = $this->userRepo->registerNew($userData); | 
					
						
							|  |  |  |         if ($socialAccount) { | 
					
						
							|  |  |  |             $newUser->socialAccounts()->save($socialAccount); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 20:55:08 +08:00
										 |  |  |         if (setting('registration-confirmation') || setting('registration-restrict')) { | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |             $newUser->save(); | 
					
						
							|  |  |  |             $this->emailConfirmationService->sendConfirmation($newUser); | 
					
						
							|  |  |  |             return redirect('/register/confirm'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         auth()->login($newUser); | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         session()->flash('success', 'Thanks for signing up! You are now registered and signed in.'); | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |         return redirect($this->redirectPath()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-14 06:22:30 +08:00
										 |  |  |      * Show the page to tell the user to check their email | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |      * and confirm their address. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getRegisterConfirmation() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return view('auth/register-confirm'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-22 03:54:11 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * View the confirmation email as a standard web page. | 
					
						
							|  |  |  |      * @param $token | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      * @throws UserRegistrationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function viewConfirmEmail($token) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $confirmation = $this->emailConfirmationService->getEmailConfirmationFromToken($token); | 
					
						
							|  |  |  |         return view('emails/email-confirmation', ['token' => $confirmation->token]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Confirms an email via a token and logs the user into the system. | 
					
						
							|  |  |  |      * @param $token | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws UserRegistrationException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function confirmEmail($token) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $confirmation = $this->emailConfirmationService->getEmailConfirmationFromToken($token); | 
					
						
							|  |  |  |         $user = $confirmation->user; | 
					
						
							|  |  |  |         $user->email_confirmed = true; | 
					
						
							|  |  |  |         $user->save(); | 
					
						
							|  |  |  |         auth()->login($confirmation->user); | 
					
						
							|  |  |  |         session()->flash('success', 'Your email has been confirmed!'); | 
					
						
							|  |  |  |         $this->emailConfirmationService->deleteConfirmationsByUser($user); | 
					
						
							|  |  |  |         return redirect($this->redirectPath); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Shows a notice that a user's email address has not been confirmed, | 
					
						
							|  |  |  |      * Also has the option to re-send the confirmation email. | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function showAwaitingConfirmation() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return view('auth/user-unconfirmed'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Resend the confirmation email | 
					
						
							|  |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function resendConfirmation(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->validate($request, [ | 
					
						
							|  |  |  |             'email' => 'required|email|exists:users,email' | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  |         $user = $this->userRepo->getByEmail($request->get('email')); | 
					
						
							|  |  |  |         $this->emailConfirmationService->sendConfirmation($user); | 
					
						
							| 
									
										
										
										
											2016-01-14 06:22:30 +08:00
										 |  |  |         session()->flash('success', 'Confirmation email resent, Please check your inbox.'); | 
					
						
							| 
									
										
										
										
											2015-09-06 03:25:57 +08:00
										 |  |  |         return redirect('/register/confirm'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Show the application login form. | 
					
						
							|  |  |  |      * @return \Illuminate\Http\Response | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getLogin() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-05 00:50:52 +08:00
										 |  |  |         $socialDrivers = $this->socialAuthService->getActiveDrivers(); | 
					
						
							| 
									
										
										
										
											2016-01-12 06:41:05 +08:00
										 |  |  |         $authMethod = config('auth.method'); | 
					
						
							| 
									
										
										
										
											2016-01-10 03:23:35 +08:00
										 |  |  |         return view('auth/login', ['socialDrivers' => $socialDrivers, 'authMethod' => $authMethod]); | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Redirect to the relevant social site. | 
					
						
							|  |  |  |      * @param $socialDriver | 
					
						
							|  |  |  |      * @return \Symfony\Component\HttpFoundation\RedirectResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getSocialLogin($socialDriver) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         session()->put('social-callback', 'login'); | 
					
						
							| 
									
										
										
										
											2015-09-05 03:40:36 +08:00
										 |  |  |         return $this->socialAuthService->startLogIn($socialDriver); | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-01-10 03:23:35 +08:00
										 |  |  |      * Redirect to the social site for authentication intended to register. | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |      * @param $socialDriver | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function socialRegister($socialDriver) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->checkRegistrationAllowed(); | 
					
						
							|  |  |  |         session()->put('social-callback', 'register'); | 
					
						
							|  |  |  |         return $this->socialAuthService->startRegister($socialDriver); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * The callback for social login services. | 
					
						
							|  |  |  |      * @param $socialDriver | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							| 
									
										
										
										
											2015-09-05 03:40:36 +08:00
										 |  |  |      * @throws SocialSignInException | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function socialCallback($socialDriver) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-06 19:14:32 +08:00
										 |  |  |         if (session()->has('social-callback')) { | 
					
						
							|  |  |  |             $action = session()->pull('social-callback'); | 
					
						
							|  |  |  |             if ($action == 'login') { | 
					
						
							|  |  |  |                 return $this->socialAuthService->handleLoginCallback($socialDriver); | 
					
						
							|  |  |  |             } elseif ($action == 'register') { | 
					
						
							|  |  |  |                 return $this->socialRegisterCallback($socialDriver); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             throw new SocialSignInException('No action defined', '/login'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return redirect()->back(); | 
					
						
							| 
									
										
										
										
											2015-09-05 03:40:36 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Detach a social account from a user. | 
					
						
							|  |  |  |      * @param $socialDriver | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function detachSocialAccount($socialDriver) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->socialAuthService->detachSocialAccount($socialDriver); | 
					
						
							| 
									
										
										
										
											2015-09-05 00:16:58 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | } |