Mejor paginado, y actualizado el .env.example!
This commit is contained in:
@@ -5,6 +5,7 @@ namespace App\Http\Controllers;
|
||||
use App\Models\Restaurante;
|
||||
use App\Models\Usuario;
|
||||
use App\Services\Auth0Service;
|
||||
use App\Services\PaginatorService;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Validation\Rule;
|
||||
@@ -14,12 +15,24 @@ use Ramsey\Uuid\Uuid;
|
||||
class UsuariosController extends Controller {
|
||||
|
||||
/**
|
||||
* Obtiene todos los usuarios registrados en el backend
|
||||
* Obtiene de forma paginada los usuarios registrados en el backend
|
||||
* @param Request $request
|
||||
* @return JsonResponse
|
||||
*/
|
||||
public function all() {
|
||||
$usuarios = Usuario::all();
|
||||
return response()->json(['usuarios' => $usuarios]);
|
||||
public function all(Request $request) {
|
||||
$paginate = app(PaginatorService::class)->paginate($request->input('per_page', 15), $request->input('page', 1), Usuario::all()->count());
|
||||
$paginate['links'] = [
|
||||
'first' => route('users.all', ['page' => 1, 'per_page' => $paginate['per_page']]),
|
||||
'prev' => $paginate['current_page'] - 1 >= 1 ? route('users.all', ['page' => $paginate['current_page'] - 1, 'per_page' => $paginate['per_page']]) : null,
|
||||
'current' => route('users.all', ['page' =>$paginate['current_page'], 'per_page' => $paginate['per_page']]),
|
||||
'next' => $paginate['current_page']+ 1 <= $paginate['last_page'] ? route('users.all', ['page' => $paginate['current_page'] + 1, 'per_page' => $paginate['per_page']]) : null,
|
||||
'last' => route('users.all', ['page' => $paginate['last_page'], 'per_page' => $paginate['per_page']]),
|
||||
];
|
||||
|
||||
return response()->json([
|
||||
'pagination' => $paginate,
|
||||
'data' => array_values(Usuario::all()->skip($paginate['from'] - 1 )->take($paginate['per_page'])->all())
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -32,12 +45,12 @@ class UsuariosController extends Controller {
|
||||
|
||||
if (!$usuario) {
|
||||
return response()->json([
|
||||
'error' => 'not_found',
|
||||
'message' => 'El usuario con id ' . $id . ' no existe'
|
||||
'error' => 'user_not_found',
|
||||
'message' => 'El usuario con id o auth0_id ' . $id . ' no existe'
|
||||
], 404);
|
||||
}
|
||||
|
||||
return response()->json(['usuario' => $usuario]);
|
||||
return response()->json($usuario);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -62,14 +75,14 @@ class UsuariosController extends Controller {
|
||||
|
||||
if (!$logged_user->canManageUsers()) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_users',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para crear usuarios'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$logged_user->hasPermissionsOnRestaurant($restaurant)) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_user_of_another_restaurant',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no puede crear un usuario en el restaurant ' . $restaurant->id . ' porque que no pertenece a el'
|
||||
], 403);
|
||||
}
|
||||
@@ -98,7 +111,7 @@ class UsuariosController extends Controller {
|
||||
'nombre' => $request->input('nombre')
|
||||
]);
|
||||
|
||||
return response()->json(["usuario" => $usuario]);
|
||||
return response()->json($usuario);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -131,14 +144,14 @@ class UsuariosController extends Controller {
|
||||
|
||||
if (!$logged_user->canManageUsers()) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_users',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_that_user',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar al usuario ' . $usuario->id
|
||||
], 403);
|
||||
}
|
||||
@@ -166,9 +179,15 @@ class UsuariosController extends Controller {
|
||||
if ($request->input('nombre')) $usuario->nombre = $request->input('nombre');
|
||||
$usuario->save();
|
||||
|
||||
return response()->json(["usuario" => $usuario]);
|
||||
return response()->json($usuario);
|
||||
}
|
||||
|
||||
/**
|
||||
* Elimina un usuario
|
||||
* @param Request $request
|
||||
* @param $id
|
||||
* @return JsonResponse
|
||||
*/
|
||||
public function delete(Request $request, $id) {
|
||||
/** @var Usuario $logged_user */
|
||||
$logged_user = $request->user;
|
||||
@@ -183,14 +202,14 @@ class UsuariosController extends Controller {
|
||||
|
||||
if (!$logged_user->canManageUsers()) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_users',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
||||
return response()->json([
|
||||
'error' => 'not_allowed',
|
||||
'error' => 'cant_manage_that_user',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar al usuario ' . $usuario->id
|
||||
], 403);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user