Agregar y eliminar de un restaurante
This commit is contained in:
@@ -25,14 +25,14 @@ class UsuariosController extends Controller {
|
||||
$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,
|
||||
'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::with('restaurantes')->skip($paginate['from'] - 1 )->take($paginate['per_page'])->get()->all())
|
||||
'data' => array_values(Usuario::with('restaurantes')->skip($paginate['from'] - 1)->take($paginate['per_page'])->get()->all())
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -229,4 +229,111 @@ class UsuariosController extends Controller {
|
||||
|
||||
return response()->json([], 204);
|
||||
}
|
||||
|
||||
/**
|
||||
* Agrega usuario a un restaurant
|
||||
* @param Request $request
|
||||
* @param $id
|
||||
* @param $restaurant
|
||||
* @return JsonResponse
|
||||
*/
|
||||
public function addToRestaurant(Request $request, $id, $restaurant) {
|
||||
/** @var Usuario $logged_user */
|
||||
$logged_user = $request->user;
|
||||
|
||||
$usuario = Usuario::findByIdOrAuth0Id($id);
|
||||
if (!$usuario) {
|
||||
return response()->json([
|
||||
'error' => 'not_found',
|
||||
'message' => 'El usuario con id ' . $id . ' no existe'
|
||||
], 404);
|
||||
}
|
||||
|
||||
$restaurant = Restaurante::find($restaurant);
|
||||
if (!$restaurant) {
|
||||
return response()->json([
|
||||
'error' => 'not_found',
|
||||
'message' => 'El restaurante con id ' . $id . ' no existe'
|
||||
], 404);
|
||||
}
|
||||
|
||||
if (!$logged_user->canManageUsers()) {
|
||||
return response()->json([
|
||||
'error' => 'cant_manage_users',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$logged_user->hasPermissionsOnRestaurant($restaurant)) {
|
||||
return response()->json([
|
||||
'error' => 'cant_manage_user_of_another_restaurant',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no puede agregar un usuario al restaurant ' . $restaurant->id . ' porque que no pertenece a el'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if ($usuario->restaurantes->contains($restaurant)) {
|
||||
return response()->json([
|
||||
'error' => 'already_on_restaurant',
|
||||
'message' => 'El usuario ' . $usuario->id . ' ya se encuentra en el restaurante ' . $restaurant->id
|
||||
], 400);
|
||||
}
|
||||
|
||||
$restaurant->usuarios()->attach($usuario);
|
||||
|
||||
return response()->json($usuario->fresh(['restaurantes']));
|
||||
}
|
||||
|
||||
/**
|
||||
* Saca a un usuario de un restaurant
|
||||
*
|
||||
* @param Request $request
|
||||
* @param $id
|
||||
* @param $restaurant
|
||||
* @return JsonResponse
|
||||
*/
|
||||
public function removeFromRestaurant(Request $request, $id, $restaurant) {
|
||||
/** @var Usuario $logged_user */
|
||||
$logged_user = $request->user;
|
||||
|
||||
$usuario = Usuario::findByIdOrAuth0Id($id);
|
||||
if (!$usuario) {
|
||||
return response()->json([
|
||||
'error' => 'not_found',
|
||||
'message' => 'El usuario con id ' . $id . ' no existe'
|
||||
], 404);
|
||||
}
|
||||
|
||||
$restaurant = Restaurante::find($restaurant);
|
||||
if (!$restaurant) {
|
||||
return response()->json([
|
||||
'error' => 'not_found',
|
||||
'message' => 'El restaurante con id ' . $id . ' no existe'
|
||||
], 404);
|
||||
}
|
||||
|
||||
if (!$logged_user->canManageUsers()) {
|
||||
return response()->json([
|
||||
'error' => 'cant_manage_users',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no tiene permisos para modificar usuarios'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$logged_user->hasPermissionsOnRestaurant($restaurant)) {
|
||||
return response()->json([
|
||||
'error' => 'cant_manage_user_of_another_restaurant',
|
||||
'message' => 'El usuario ' . $logged_user->id . ' no puede agregar un usuario al restaurant ' . $restaurant->id . ' porque que no pertenece a el'
|
||||
], 403);
|
||||
}
|
||||
|
||||
if (!$usuario->restaurantes->contains($restaurant)) {
|
||||
return response()->json([
|
||||
'error' => 'already_not_on_restaurant',
|
||||
'message' => 'El usuario ' . $usuario->id . ' no encuentra en el restaurante ' . $restaurant->id
|
||||
], 400);
|
||||
}
|
||||
|
||||
$restaurant->usuarios()->detach($usuario);
|
||||
|
||||
return response()->json($usuario->fresh(['restaurantes']));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user