Skip to content

Commit

Permalink
Merge pull request #10 from lthurler/task-172
Browse files Browse the repository at this point in the history
Task-172: Criação do endpoint PATCH e função no UserController para alteração de tipo de usuário
  • Loading branch information
lthurler authored Jul 5, 2024
2 parents 0193003 + 87a30e4 commit fc0f190
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 3 deletions.
47 changes: 44 additions & 3 deletions app/Controller/UserController.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,12 @@ final class UserController extends AbstractController
#[Value(key: 'register_token')]
private $registerToken;

#[Value(key: 'defaultPermissions.admin_default_permissions')]
private $defaultAdminPermissions;

#[Value(key: 'defaultPermissions.founder_default_permissions')]
private $defaultFounderPermissions;

public function __construct(
LoginRepository $loginRepository,
) {
Expand Down Expand Up @@ -116,6 +122,42 @@ public function update(RequestInterface $request, $id)
]);
}

public function updateUserType(RequestInterface $request, $id)
{
$user = User::query()->where('uuid', $id)->first();

if (empty($user)) {
return $this->response->json([
'error' => 'Usuário não encontrado.',
], 404);
}

if ($user->uuid !== $id) {
return $this->response->json([
'error' => 'Você não tem permissão para atualizar este usuário.',
], 403);
}

$userType = $this->request->input('user_type');

$user->user_type = $userType;

if ($userType == 'founder') {
$user->permissions = serialize($this->defaultFounderPermissions);
}

if ($userType == 'admin') {
$user->permissions = serialize($this->defaultAdminPermissions);
}

$user->save();

return $this->response->json([
'message' => 'Tipo de usuário atualizado com sucesso!',
'user' => $user,
]);
}

public function del($id): Psr7ResponseInterface
{
$user = $this->container->get('user');
Expand All @@ -126,15 +168,15 @@ public function del($id): Psr7ResponseInterface
], 403);
}

if (! $id) {
if (!$id) {
return $this->response->json([
'error' => 'O email é necessário para deletar o usuário.',
], 400);
}

$user = User::query()->where('uuid', $id)->first();

if (! $user) {
if (!$user) {
return $this->response->json([
'error' => 'Usuário não encontrado.',
], 404);
Expand All @@ -147,7 +189,6 @@ public function del($id): Psr7ResponseInterface
]);
}

// user type - modificar
public function permission(RequestInterface $request, $uuid)
{
$user = User::query()->where('uuid', $uuid)->first();
Expand Down
1 change: 1 addition & 0 deletions config/routes.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ function () {
Router::addRoute(['PUT'], '/user/{id}', 'App\Controller\UserController@update');
Router::addRoute(['DELETE'], '/user/{id}', 'App\Controller\UserController@del');
Router::addRoute(['POST'], '/user/permission/{uuid}', 'App\Controller\UserController@permission');
Router::addRoute(['PATCH'], '/user/type/{id}', 'App\Controller\UserController@updateUserType');

// Product
Router::addRoute(['GET'], '/product/{uuid}', 'App\Controller\Product@show');
Expand Down

0 comments on commit fc0f190

Please sign in to comment.