2021-06-26 23:23:15 +08:00
|
|
|
<?php
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2021-06-26 23:23:15 +08:00
|
|
|
namespace Tests\Auth;
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2023-09-12 02:26:28 +08:00
|
|
|
use BookStack\Access\Notifications\UserInviteNotification;
|
2023-05-18 00:56:55 +08:00
|
|
|
use BookStack\Access\UserInviteService;
|
|
|
|
use BookStack\Users\Models\User;
|
2019-08-18 20:55:28 +08:00
|
|
|
use Carbon\Carbon;
|
2022-02-01 06:15:21 +08:00
|
|
|
use Illuminate\Notifications\Messages\MailMessage;
|
2021-09-26 22:37:55 +08:00
|
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
use Illuminate\Support\Facades\Notification;
|
2021-09-26 22:48:22 +08:00
|
|
|
use Illuminate\Support\Str;
|
2020-04-04 08:16:05 +08:00
|
|
|
use Tests\TestCase;
|
2019-08-18 20:55:28 +08:00
|
|
|
|
|
|
|
class UserInviteTest extends TestCase
|
|
|
|
{
|
|
|
|
public function test_user_creation_creates_invite()
|
|
|
|
{
|
|
|
|
Notification::fake();
|
2023-01-21 19:08:34 +08:00
|
|
|
$admin = $this->users->admin();
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2021-03-04 06:11:00 +08:00
|
|
|
$email = Str::random(16) . '@example.com';
|
|
|
|
$resp = $this->actingAs($admin)->post('/settings/users/create', [
|
2022-02-01 19:49:30 +08:00
|
|
|
'name' => 'Barry',
|
|
|
|
'email' => $email,
|
2019-08-18 20:55:28 +08:00
|
|
|
'send_invite' => 'true',
|
|
|
|
]);
|
2021-03-04 06:11:00 +08:00
|
|
|
$resp->assertRedirect('/settings/users');
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2021-03-04 06:11:00 +08:00
|
|
|
$newUser = User::query()->where('email', '=', $email)->orderBy('id', 'desc')->first();
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2023-09-12 02:26:28 +08:00
|
|
|
Notification::assertSentTo($newUser, UserInviteNotification::class);
|
2019-08-18 20:55:28 +08:00
|
|
|
$this->assertDatabaseHas('user_invites', [
|
2021-06-26 23:23:15 +08:00
|
|
|
'user_id' => $newUser->id,
|
2019-08-18 20:55:28 +08:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2022-02-01 06:15:21 +08:00
|
|
|
public function test_user_invite_sent_in_selected_language()
|
|
|
|
{
|
|
|
|
Notification::fake();
|
2023-01-21 19:08:34 +08:00
|
|
|
$admin = $this->users->admin();
|
2022-02-01 06:15:21 +08:00
|
|
|
|
|
|
|
$email = Str::random(16) . '@example.com';
|
|
|
|
$resp = $this->actingAs($admin)->post('/settings/users/create', [
|
2022-02-01 19:49:30 +08:00
|
|
|
'name' => 'Barry',
|
|
|
|
'email' => $email,
|
2022-02-01 06:15:21 +08:00
|
|
|
'send_invite' => 'true',
|
2022-02-04 09:02:13 +08:00
|
|
|
'language' => 'de',
|
2022-02-01 06:15:21 +08:00
|
|
|
]);
|
|
|
|
$resp->assertRedirect('/settings/users');
|
|
|
|
|
|
|
|
$newUser = User::query()->where('email', '=', $email)->orderBy('id', 'desc')->first();
|
2023-09-12 02:26:28 +08:00
|
|
|
Notification::assertSentTo($newUser, UserInviteNotification::class, function ($notification, $channels, $notifiable) {
|
2022-02-01 06:15:21 +08:00
|
|
|
/** @var MailMessage $mail */
|
|
|
|
$mail = $notification->toMail($notifiable);
|
2022-02-01 19:49:30 +08:00
|
|
|
|
2023-06-29 06:46:59 +08:00
|
|
|
return 'Sie wurden eingeladen, BookStack beizutreten!' === $mail->subject &&
|
2022-02-01 06:15:21 +08:00
|
|
|
'Ein Konto wurde für Sie auf BookStack erstellt.' === $mail->greeting;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-08-18 20:55:28 +08:00
|
|
|
public function test_invite_set_password()
|
|
|
|
{
|
|
|
|
Notification::fake();
|
2023-01-21 19:08:34 +08:00
|
|
|
$user = $this->users->viewer();
|
2019-08-18 20:55:28 +08:00
|
|
|
$inviteService = app(UserInviteService::class);
|
|
|
|
|
|
|
|
$inviteService->sendInvitation($user);
|
|
|
|
$token = DB::table('user_invites')->where('user_id', '=', $user->id)->first()->token;
|
|
|
|
|
|
|
|
$setPasswordPageResp = $this->get('/register/invite/' . $token);
|
|
|
|
$setPasswordPageResp->assertSuccessful();
|
|
|
|
$setPasswordPageResp->assertSee('Welcome to BookStack!');
|
|
|
|
$setPasswordPageResp->assertSee('Password');
|
|
|
|
$setPasswordPageResp->assertSee('Confirm Password');
|
|
|
|
|
|
|
|
$setPasswordResp = $this->followingRedirects()->post('/register/invite/' . $token, [
|
|
|
|
'password' => 'my test password',
|
|
|
|
]);
|
2021-11-15 18:50:28 +08:00
|
|
|
$setPasswordResp->assertSee('Password set, you should now be able to login using your set password to access BookStack!');
|
2019-08-18 20:55:28 +08:00
|
|
|
$newPasswordValid = auth()->validate([
|
2022-02-01 19:49:30 +08:00
|
|
|
'email' => $user->email,
|
2021-06-26 23:23:15 +08:00
|
|
|
'password' => 'my test password',
|
2019-08-18 20:55:28 +08:00
|
|
|
]);
|
|
|
|
$this->assertTrue($newPasswordValid);
|
|
|
|
$this->assertDatabaseMissing('user_invites', [
|
2021-06-26 23:23:15 +08:00
|
|
|
'user_id' => $user->id,
|
2019-08-18 20:55:28 +08:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function test_invite_set_has_password_validation()
|
|
|
|
{
|
|
|
|
Notification::fake();
|
2023-01-21 19:08:34 +08:00
|
|
|
$user = $this->users->viewer();
|
2019-08-18 20:55:28 +08:00
|
|
|
$inviteService = app(UserInviteService::class);
|
|
|
|
|
|
|
|
$inviteService->sendInvitation($user);
|
|
|
|
$token = DB::table('user_invites')->where('user_id', '=', $user->id)->first()->token;
|
|
|
|
|
2019-09-14 06:58:40 +08:00
|
|
|
$this->get('/register/invite/' . $token);
|
2019-08-18 20:55:28 +08:00
|
|
|
$shortPassword = $this->followingRedirects()->post('/register/invite/' . $token, [
|
2019-09-14 06:58:40 +08:00
|
|
|
'password' => 'mypassw',
|
2019-08-18 20:55:28 +08:00
|
|
|
]);
|
2019-09-14 06:58:40 +08:00
|
|
|
$shortPassword->assertSee('The password must be at least 8 characters.');
|
2019-08-18 20:55:28 +08:00
|
|
|
|
2019-09-14 06:58:40 +08:00
|
|
|
$this->get('/register/invite/' . $token);
|
2019-08-18 20:55:28 +08:00
|
|
|
$noPassword = $this->followingRedirects()->post('/register/invite/' . $token, [
|
|
|
|
'password' => '',
|
|
|
|
]);
|
|
|
|
$noPassword->assertSee('The password field is required.');
|
|
|
|
|
|
|
|
$this->assertDatabaseHas('user_invites', [
|
2021-06-26 23:23:15 +08:00
|
|
|
'user_id' => $user->id,
|
2019-08-18 20:55:28 +08:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function test_non_existent_invite_token_redirects_to_home()
|
|
|
|
{
|
2019-09-14 06:58:40 +08:00
|
|
|
$setPasswordPageResp = $this->get('/register/invite/' . Str::random(12));
|
2019-08-18 20:55:28 +08:00
|
|
|
$setPasswordPageResp->assertRedirect('/');
|
|
|
|
|
2019-09-14 06:58:40 +08:00
|
|
|
$setPasswordResp = $this->post('/register/invite/' . Str::random(12), ['password' => 'Password Test']);
|
2019-08-18 20:55:28 +08:00
|
|
|
$setPasswordResp->assertRedirect('/');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function test_token_expires_after_two_weeks()
|
|
|
|
{
|
|
|
|
Notification::fake();
|
2023-01-21 19:08:34 +08:00
|
|
|
$user = $this->users->viewer();
|
2019-08-18 20:55:28 +08:00
|
|
|
$inviteService = app(UserInviteService::class);
|
|
|
|
|
|
|
|
$inviteService->sendInvitation($user);
|
|
|
|
$tokenEntry = DB::table('user_invites')->where('user_id', '=', $user->id)->first();
|
|
|
|
DB::table('user_invites')->update(['created_at' => Carbon::now()->subDays(14)->subHour(1)]);
|
|
|
|
|
|
|
|
$setPasswordPageResp = $this->get('/register/invite/' . $tokenEntry->token);
|
|
|
|
$setPasswordPageResp->assertRedirect('/password/email');
|
|
|
|
$setPasswordPageResp->assertSessionHas('error', 'This invitation link has expired. You can instead try to reset your account password.');
|
|
|
|
}
|
2021-06-26 23:23:15 +08:00
|
|
|
}
|