Skip to content

Commit

Permalink
Merge branch 'develop' into hotfix/ip-logging
Browse files Browse the repository at this point in the history
  • Loading branch information
tuj authored Apr 19, 2024
2 parents 2a2c6d8 + 91d8bc2 commit ae0ca46
Show file tree
Hide file tree
Showing 7 changed files with 29 additions and 10 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ All notable changes to this project will be documented in this file.

- [#204](https://github.com/os2display/display-api-service/pull/204)
- Ensured real ip is logged in nginx.
- [#200](https://github.com/os2display/display-api-service/pull/200)
- Updated oidc internal documentation.
- [#205](https://github.com/os2display/display-api-service/pull/205)
- Fixed redirecting post requests.

## [2.0.3] - 2024-04-10

Expand Down
13 changes: 10 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -128,9 +128,16 @@ The internal oidc provider gets that user's name, email and tenants from claims.

The claim keys needed are set in the env variables:

- INTERNAL_OIDC_CLAIM_NAME
- INTERNAL_OIDC_CLAIM_EMAIL
- INTERNAL_OIDC_CLAIM_GROUPS
- `INTERNAL_OIDC_CLAIM_NAME`
- `INTERNAL_OIDC_CLAIM_EMAIL`
- `INTERNAL_OIDC_CLAIM_GROUPS`

The value of the claim with the name that is defined in the env variable `INTERNAL_OIDC_CLAIM_GROUPS` is mapped to
the user's access to tenants in `App\Security\AzureOidcAuthenticator`. The claim field should consist of an array of
names that should follow the following structure `<TENANT_NAME><ROLE_IN_TENANT>`.
`<ROLE_IN_TENANT>` can be `Admin` or `Redaktoer` (editor).
E.g. `Example1Admin` will map to the tenant with name `Example1` with `ROLE_ADMIN`.
If the tenant does not exist it will be created when the user logs in.

### External

Expand Down
3 changes: 2 additions & 1 deletion config/packages/nelmio_cors.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ nelmio_cors:
expose_headers: ['Link']
max_age: 3600
paths:
'^/v2/authentication/':
# v1 is added for backwards compatability: See App/Controller/ApiV1RedirectController
'^/(v1|v2)/authentication/':
allow_credentials: true
'^/': null
3 changes: 2 additions & 1 deletion config/packages/security.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,9 @@ security:
login_oidc:
pattern: ^/v2/authentication/oidc
security: false
# v1 is added for backwards compatability: See App/Controller/ApiV1RedirectController
api_token_refresh:
pattern: ^/v2/authentication/token/refresh
pattern: ^/(v1|v2)/authentication/token/refresh
stateless: true
refresh_jwt:
provider: user_provider
Expand Down
2 changes: 1 addition & 1 deletion psalm-baseline.xml
Original file line number Diff line number Diff line change
Expand Up @@ -751,8 +751,8 @@
<code><![CDATA[$theme]]></code>
</NullableReturnStatement>
<PossiblyNullReference>
<code><![CDATA[addLogo]]></code>
<code><![CDATA[removeLogo]]></code>
<code><![CDATA[setLogo]]></code>
<code><![CDATA[setCreatedBy]]></code>
<code><![CDATA[setCssStyles]]></code>
<code><![CDATA[setDescription]]></code>
Expand Down
5 changes: 3 additions & 2 deletions src/Controller/ApiV1RedirectController.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,14 @@

use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Attribute\Route;

class ApiV1RedirectController extends AbstractController
{
#[Route('/v1/{endpoint}', name: 'app_api_v1_redirect', requirements: ['endpoint' => '.+'], defaults: ['endpoint' => null], methods: ['GET'])]
#[Route('/v1/{endpoint}', name: 'app_api_v1_redirect', requirements: ['endpoint' => '.+'], defaults: ['endpoint' => null])]
public function index(string $endpoint): RedirectResponse
{
return $this->redirect('/v2/'.$endpoint, \Symfony\Component\HttpFoundation\Response::HTTP_MOVED_PERMANENTLY);
return $this->redirect('/v2/'.$endpoint, Response::HTTP_PERMANENTLY_REDIRECT);
}
}
9 changes: 7 additions & 2 deletions tests/Controller/ApiV1RedirectControllerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,19 @@
namespace App\Tests\Controller;

use App\Tests\AbstractBaseApiTestCase;
use Symfony\Component\HttpFoundation\Request;

class ApiV1RedirectControllerTest extends AbstractBaseApiTestCase
{
public function testIndex()
{
$client = $this->getAuthenticatedClient('ROLE_ADMIN');
$crawler = $client->request('GET', '/v1/screens/01GN9PW2Z03V8VQG7SN6Q9R17H');
$client->request(Request::METHOD_GET, '/v1/screens/01GN9PW2Z03V8VQG7SN6Q9R17H');

$this->assertResponseRedirects('/v2/screens/01GN9PW2Z03V8VQG7SN6Q9R17H', 301);
$this->assertResponseRedirects('/v2/screens/01GN9PW2Z03V8VQG7SN6Q9R17H', 308);

$client->request(Request::METHOD_POST, '/v1/authentication/screen');

$this->assertResponseRedirects('/v2/authentication/screen', 308);
}
}

0 comments on commit ae0ca46

Please sign in to comment.