2022-03-31 08:38:35 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Feature\Http\Middlewares;
|
|
|
|
|
2024-07-03 11:16:08 +02:00
|
|
|
use App\Http\Middleware\Authenticate;
|
|
|
|
use App\Models\User;
|
|
|
|
use App\Providers\AuthServiceProvider;
|
|
|
|
use Illuminate\Support\Facades\App;
|
2022-03-31 08:38:35 +02:00
|
|
|
use Illuminate\Support\Facades\Config;
|
2024-07-03 11:16:08 +02:00
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
|
|
use PHPUnit\Framework\Attributes\CoversMethod;
|
2024-06-26 14:29:13 +02:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2022-11-22 15:15:52 +01:00
|
|
|
use Tests\FeatureTestCase;
|
2022-03-31 08:38:35 +02:00
|
|
|
|
2024-07-03 11:16:08 +02:00
|
|
|
#[CoversClass(Authenticate::class)]
|
|
|
|
#[CoversMethod(AuthServiceProvider::class, 'boot')]
|
2022-03-31 08:38:35 +02:00
|
|
|
class AuthenticateMiddlewareTest extends FeatureTestCase
|
|
|
|
{
|
|
|
|
private const USER_NAME = 'John';
|
2022-11-22 15:15:52 +01:00
|
|
|
|
2022-03-31 08:38:35 +02:00
|
|
|
private const USER_EMAIL = 'john@example.com';
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2022-03-31 08:38:35 +02:00
|
|
|
public function test_it_always_authenticates_with_reverse_proxy_guard()
|
|
|
|
{
|
|
|
|
Config::set('auth.auth_proxy_headers.user', 'HTTP_REMOTE_USER');
|
2022-11-22 15:15:52 +01:00
|
|
|
|
2022-03-31 08:38:35 +02:00
|
|
|
$this->app['auth']->shouldUse('reverse-proxy-guard');
|
|
|
|
|
|
|
|
$this->json('GET', '/api/v1/groups', [], ['HTTP_REMOTE_USER' => self::USER_NAME]);
|
|
|
|
$this->assertAuthenticated('reverse-proxy-guard');
|
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2022-03-31 08:38:35 +02:00
|
|
|
public function test_it_does_not_authenticate_with_empty_header()
|
|
|
|
{
|
|
|
|
Config::set('auth.auth_proxy_headers.user', 'HTTP_REMOTE_USER');
|
|
|
|
Config::set('auth.auth_proxy_headers.email', 'HTTP_REMOTE_EMAIL');
|
|
|
|
|
|
|
|
$this->app['auth']->shouldUse('reverse-proxy-guard');
|
|
|
|
|
|
|
|
$this->json('GET', '/api/v1/groups', [], [
|
2022-11-22 15:15:52 +01:00
|
|
|
'HTTP_REMOTE_USER' => '',
|
|
|
|
'HTTP_REMOTE_EMAIL' => '',
|
2022-05-23 11:39:10 +02:00
|
|
|
])->assertStatus(407);
|
2022-03-31 08:38:35 +02:00
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2022-03-31 08:38:35 +02:00
|
|
|
public function test_it_does_not_authenticate_with_missing_header()
|
|
|
|
{
|
|
|
|
$this->app['auth']->shouldUse('reverse-proxy-guard');
|
|
|
|
|
|
|
|
$this->json('GET', '/api/v1/groups', [], [])
|
2022-05-23 11:39:10 +02:00
|
|
|
->assertStatus(407);
|
2022-03-31 08:38:35 +02:00
|
|
|
}
|
2024-07-03 11:16:08 +02:00
|
|
|
|
|
|
|
#[Test]
|
|
|
|
public function test_it_overrides_locale_when_auth_is_successful()
|
|
|
|
{
|
|
|
|
Config::set('auth.auth_proxy_headers.user', 'HTTP_REMOTE_USER');
|
|
|
|
Config::set('auth.auth_proxy_headers.email', 'HTTP_REMOTE_EMAIL');
|
2024-09-26 23:50:01 +02:00
|
|
|
|
2024-07-03 11:16:08 +02:00
|
|
|
$this->app['auth']->shouldUse('reverse-proxy-guard');
|
|
|
|
|
|
|
|
$lang = 'fr';
|
|
|
|
$user = User::factory()->create([
|
|
|
|
'name' => self::USER_NAME,
|
|
|
|
'email' => self::USER_EMAIL,
|
|
|
|
]);
|
|
|
|
$user['preferences->lang'] = $lang;
|
|
|
|
$user->save();
|
|
|
|
|
|
|
|
$this->json('GET', '/api/v1/groups', [], [
|
2024-09-26 23:50:01 +02:00
|
|
|
'HTTP_REMOTE_USER' => self::USER_NAME,
|
2024-07-03 11:16:08 +02:00
|
|
|
]);
|
|
|
|
|
|
|
|
$this->assertEquals($lang, App::getLocale());
|
|
|
|
}
|
2022-11-22 15:15:52 +01:00
|
|
|
}
|