added OAuth2 Controller
This commit is contained in:
parent
c1046ee6e0
commit
0d939ca9e8
|
@ -0,0 +1,41 @@
|
|||
<?php
|
||||
|
||||
namespace App\Controller;
|
||||
|
||||
use App\Entity\User;
|
||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||
use Symfony\Component\Routing\Attribute\Route;
|
||||
|
||||
class OAuth2Controller extends AbstractController
|
||||
{
|
||||
#[Route('/oauth/api/user', name: 'app_oauth_api_user')]
|
||||
public function oauthApiUser(): JsonResponse
|
||||
{
|
||||
/** @var User $user */
|
||||
$user = $this->getUser();
|
||||
return new JsonResponse([
|
||||
'message' => 'Authentification réussie !',
|
||||
'email' => $user->getEmail(),
|
||||
'name' => $user->getUsername(),
|
||||
]);
|
||||
|
||||
}
|
||||
|
||||
#[Route('/oauth2/userinfo', name: 'userinfo', methods: ['GET'])]
|
||||
public function userinfo(): JsonResponse
|
||||
{
|
||||
$user = $this->getUser();
|
||||
|
||||
if (!$user) {
|
||||
return new JsonResponse(['error' => 'Unauthorized'], 401);
|
||||
}
|
||||
|
||||
return new JsonResponse([
|
||||
'sub' => $user->getId(),
|
||||
'username' => $user->getUsername(),
|
||||
'email' => $user->getEmail(),
|
||||
'roles' => $user->getRoles(),
|
||||
]);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue