Mejor paginado, y actualizado el .env.example!
This commit is contained in:
@@ -21,3 +21,9 @@ QUEUE_CONNECTION=sync
|
|||||||
AUTH0_DOMAIN=https://super-domain.auth0.com/
|
AUTH0_DOMAIN=https://super-domain.auth0.com/
|
||||||
AUTH0_AUD=https://audience
|
AUTH0_AUD=https://audience
|
||||||
|
|
||||||
|
|
||||||
|
AUTH0_API_AUD=https://super-domain.auth0.com/api/v2/
|
||||||
|
AUTH0_CLIENT_ID=secret
|
||||||
|
AUTH0_CLIENT_SECRET=secret
|
||||||
|
AUTH0_CONNECTION=Username-Password-Authentication
|
||||||
|
AUTH0_VERIFY_MAIL=false
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ namespace App\Http\Controllers;
|
|||||||
use App\Models\Restaurante;
|
use App\Models\Restaurante;
|
||||||
use App\Models\Usuario;
|
use App\Models\Usuario;
|
||||||
use App\Services\Auth0Service;
|
use App\Services\Auth0Service;
|
||||||
|
use App\Services\PaginatorService;
|
||||||
use Illuminate\Http\JsonResponse;
|
use Illuminate\Http\JsonResponse;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
@@ -14,12 +15,24 @@ use Ramsey\Uuid\Uuid;
|
|||||||
class UsuariosController extends Controller {
|
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
|
* @return JsonResponse
|
||||||
*/
|
*/
|
||||||
public function all() {
|
public function all(Request $request) {
|
||||||
$usuarios = Usuario::all();
|
$paginate = app(PaginatorService::class)->paginate($request->input('per_page', 15), $request->input('page', 1), Usuario::all()->count());
|
||||||
return response()->json(['usuarios' => $usuarios]);
|
$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) {
|
if (!$usuario) {
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'error' => 'not_found',
|
'error' => 'user_not_found',
|
||||||
'message' => 'El usuario con id ' . $id . ' no existe'
|
'message' => 'El usuario con id o auth0_id ' . $id . ' no existe'
|
||||||
], 404);
|
], 404);
|
||||||
}
|
}
|
||||||
|
|
||||||
return response()->json(['usuario' => $usuario]);
|
return response()->json($usuario);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -62,14 +75,14 @@ class UsuariosController extends Controller {
|
|||||||
|
|
||||||
if (!$logged_user->canManageUsers()) {
|
if (!$logged_user->canManageUsers()) {
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'error' => 'not_allowed',
|
'error' => 'cant_manage_users',
|
||||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para crear usuarios'
|
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para crear usuarios'
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$logged_user->hasPermissionsOnRestaurant($restaurant)) {
|
if (!$logged_user->hasPermissionsOnRestaurant($restaurant)) {
|
||||||
return response()->json([
|
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'
|
'message' => 'El usuario ' . $logged_user->id . ' no puede crear un usuario en el restaurant ' . $restaurant->id . ' porque que no pertenece a el'
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
@@ -98,7 +111,7 @@ class UsuariosController extends Controller {
|
|||||||
'nombre' => $request->input('nombre')
|
'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()) {
|
if (!$logged_user->canManageUsers()) {
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'error' => 'not_allowed',
|
'error' => 'cant_manage_users',
|
||||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
||||||
return response()->json([
|
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
|
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar al usuario ' . $usuario->id
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
@@ -166,9 +179,15 @@ class UsuariosController extends Controller {
|
|||||||
if ($request->input('nombre')) $usuario->nombre = $request->input('nombre');
|
if ($request->input('nombre')) $usuario->nombre = $request->input('nombre');
|
||||||
$usuario->save();
|
$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) {
|
public function delete(Request $request, $id) {
|
||||||
/** @var Usuario $logged_user */
|
/** @var Usuario $logged_user */
|
||||||
$logged_user = $request->user;
|
$logged_user = $request->user;
|
||||||
@@ -183,14 +202,14 @@ class UsuariosController extends Controller {
|
|||||||
|
|
||||||
if (!$logged_user->canManageUsers()) {
|
if (!$logged_user->canManageUsers()) {
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'error' => 'not_allowed',
|
'error' => 'cant_manage_users',
|
||||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
if (!$logged_user->hasPermissionsOverUser($usuario)) {
|
||||||
return response()->json([
|
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
|
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar al usuario ' . $usuario->id
|
||||||
], 403);
|
], 403);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ use Ramsey\Uuid\Uuid;
|
|||||||
* @method static find($id)
|
* @method static find($id)
|
||||||
* @method static where(string $string, $sub)
|
* @method static where(string $string, $sub)
|
||||||
* @method static create(array $array)
|
* @method static create(array $array)
|
||||||
|
* @method static paginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
|
||||||
*
|
*
|
||||||
* @package App\Models
|
* @package App\Models
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
namespace App\Providers;
|
namespace App\Providers;
|
||||||
|
|
||||||
use App\Services\Auth0Service;
|
use App\Services\Auth0Service;
|
||||||
|
use App\Services\PaginatorService;
|
||||||
use Illuminate\Support\ServiceProvider;
|
use Illuminate\Support\ServiceProvider;
|
||||||
|
|
||||||
class AppServiceProvider extends ServiceProvider
|
class AppServiceProvider extends ServiceProvider
|
||||||
@@ -17,5 +18,8 @@ class AppServiceProvider extends ServiceProvider
|
|||||||
$this->app->singleton(Auth0Service::class, function($app) {
|
$this->app->singleton(Auth0Service::class, function($app) {
|
||||||
return new Auth0Service($app);
|
return new Auth0Service($app);
|
||||||
});
|
});
|
||||||
|
$this->app->singleton(PaginatorService::class, function($app) {
|
||||||
|
return new PaginatorService($app);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
47
backend/app/Services/PaginatorService.php
Normal file
47
backend/app/Services/PaginatorService.php
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Services;
|
||||||
|
|
||||||
|
use Illuminate\Support\ServiceProvider;
|
||||||
|
use JetBrains\PhpStorm\ArrayShape;
|
||||||
|
|
||||||
|
class PaginatorService extends ServiceProvider {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Crea una lista asociativa que indica como paginar una lista de elementos.
|
||||||
|
* @param $perPage int Cuantos elementos se van a mostrar por pagina
|
||||||
|
* @param $page int Que pagina se va a mostrar ahora
|
||||||
|
* @param $total int Cuantos elementos en total hay
|
||||||
|
* @return array Una lista asociativa conteniendo todos los datos a saber para realizar la paginación
|
||||||
|
*/
|
||||||
|
#[ArrayShape([
|
||||||
|
'per_page' => "int",
|
||||||
|
'from' => "int",
|
||||||
|
'to' => "int",
|
||||||
|
'total' => "int",
|
||||||
|
'current_page' => "int",
|
||||||
|
'last_page' => "int"
|
||||||
|
])]
|
||||||
|
public function paginate(int $perPage, int $page, int $total) {
|
||||||
|
// Se mostraran entre 1 o mas elementos por pagina
|
||||||
|
$perPage = max(1, $perPage);
|
||||||
|
|
||||||
|
// Se necesita saber cuantas paginas son, no recuerdo porque la formula funciona, pero lo hace
|
||||||
|
$lastPage = floor(($total + $perPage - 1) / $perPage);
|
||||||
|
|
||||||
|
// Se necesita la pagina, la cual debe estar entre 1 y el numero de paginas calculadas previamente
|
||||||
|
$currentPage = min($lastPage, max(1, $page));
|
||||||
|
|
||||||
|
// Cuantos elementos se van a saltar para empezar a tomar usuarios
|
||||||
|
$skip = ($currentPage - 1) * $perPage;
|
||||||
|
|
||||||
|
return [
|
||||||
|
'per_page' => $perPage,
|
||||||
|
'from' => $skip + 1,
|
||||||
|
'to' => min($total, $skip + $perPage),
|
||||||
|
'total' => $total,
|
||||||
|
'current_page' => $currentPage,
|
||||||
|
'last_page' => $lastPage,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,7 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use Laravel\Lumen\Routing\Router;
|
||||||
|
|
||||||
/** @var \Laravel\Lumen\Routing\Router $router */
|
/** @var Router $router */
|
||||||
|
|
||||||
$router->get('/', function () use ($router) {
|
$router->get('/', function () use ($router) {
|
||||||
return 'Public View';
|
return 'Public View';
|
||||||
|
|||||||
Reference in New Issue
Block a user