*/
public function __construct(SocialAuthService $socialAuthService, EmailConfirmationService $emailConfirmationService, UserRepo $userRepo)
{
- $this->middleware('guest')->except(['socialCallback', 'detachSocialAccount']);
+ $this->middleware('guest')->only(['getRegister', 'postRegister', 'socialRegister']);
$this->socialAuthService = $socialAuthService;
$this->emailConfirmationService = $emailConfirmationService;
$this->userRepo = $userRepo;
*/
public function handle($request, Closure $next)
{
- if ($this->auth->check() && setting('registration-confirmation') && !$this->auth->user()->email_confirmed) {
- return redirect(baseUrl('/register/confirm/awaiting'));
+ if ($this->auth->check()) {
+ $requireConfirmation = (setting('registration-confirmation') || setting('registration-restrict'));
+ if ($requireConfirmation && !$this->auth->user()->email_confirmed) {
+ return redirect('/register/confirm/awaiting');
+ }
}
if ($this->auth->guest() && !setting('app-public')) {
->press('Create Account')
->seePageIs('/register/confirm')
->seeInDatabase('users', ['name' => $user->name, 'email' => $user->email, 'email_confirmed' => false]);
+
+ $this->visit('/')->seePageIs('/login')
+ ->type($user->email, '#email')
+ ->type($user->password, '#password')
+ ->press('Log In')
+ ->seePageIs('/register/confirm/awaiting')
+ ->seeText('Email Address Not Confirmed');
+ }
+
+ public function test_restricted_registration_with_confirmation_disabled()
+ {
+ $this->setSettings(['registration-enabled' => 'true', 'registration-confirmation' => 'false', 'registration-restrict' => 'example.com']);
+ $user = factory(\BookStack\User::class)->make();
+ // Go through registration process
+ $this->visit('/register')
+ ->type($user->name, '#name')
+ ->type($user->email, '#email')
+ ->type($user->password, '#password')
+ ->press('Create Account')
+ ->seePageIs('/register')
+ ->dontSeeInDatabase('users', ['email' => $user->email])
+ ->see('That email domain does not have access to this application');
+
+
+ $this->visit('/register')
+ ->type($user->name, '#name')
+ ->type($user->email, '#email')
+ ->type($user->password, '#password')
+ ->press('Create Account')
+ ->seePageIs('/register/confirm')
+ ->seeInDatabase('users', ['name' => $user->name, 'email' => $user->email, 'email_confirmed' => false]);
+
+ $this->visit('/')->seePageIs('/login')
+ ->type($user->email, '#email')
+ ->type($user->password, '#password')
+ ->press('Log In')
+ ->seePageIs('/register/confirm/awaiting')
+ ->seeText('Email Address Not Confirmed');
}
public function test_user_creation()