Primo commit: trasferimento del progetto PPEasy

This commit is contained in:
2024-09-18 10:30:50 +02:00
commit eb475f257e
4233 changed files with 1043848 additions and 0 deletions
@@ -0,0 +1,71 @@
<?php
namespace Vanguard\Http\Controllers\Web\Users;
use Illuminate\Http\Request;
use Illuminate\Validation\ValidationException;
use Vanguard\Events\User\UpdatedByAdmin;
use Vanguard\Http\Controllers\Api\ApiController;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\Services\Upload\UserAvatarManager;
use Vanguard\User;
/**
* Class AvatarController
* @package Vanguard\Http\Controllers\Api\Users
*/
class AvatarController extends ApiController
{
public function __construct(private UserRepository $users, private UserAvatarManager $avatarManager)
{
}
/**
* Update user's avatar from uploaded image.
*
* @param User $user
* @param Request $request
* @return mixed
* @throws ValidationException
*/
public function update(User $user, Request $request)
{
$this->validate($request, ['avatar' => 'image']);
$name = $this->avatarManager->uploadAndCropAvatar(
$request->file('avatar'),
$request->get('points')
);
if ($name) {
$this->users->update($user->id, ['avatar' => $name]);
event(new UpdatedByAdmin($user));
return redirect()->route('users.edit', $user)
->withSuccess(__('Avatar changed successfully.'));
}
return redirect()->route('users.edit', $user)
->withErrors(__('Avatar image cannot be updated. Please try again.'));
}
/**
* Update user's avatar from some external source (Gravatar, Facebook, Twitter...)
*
* @param User $user
* @param Request $request
* @return mixed
*/
public function updateExternal(User $user, Request $request)
{
$this->avatarManager->deleteAvatarIfUploaded($user);
$this->users->update($user->id, ['avatar' => $request->get('url')]);
event(new UpdatedByAdmin($user));
return redirect()->route('users.edit', $user)
->withSuccess(__('Avatar changed successfully.'));
}
}
@@ -0,0 +1,66 @@
<?php
namespace Vanguard\Http\Controllers\Web\Users;
use Illuminate\Http\Request;
use Vanguard\Events\User\Banned;
use Vanguard\Events\User\UpdatedByAdmin;
use Vanguard\Http\Controllers\Controller;
use Vanguard\Http\Requests\User\UpdateDetailsRequest;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\Support\Enum\UserStatus;
use Vanguard\User;
/**
* Class UserDetailsController
* @package Vanguard\Http\Controllers\Users
*/
class DetailsController extends Controller
{
public function __construct(private UserRepository $users)
{
}
/**
* Updates user details.
*
* @param User $user
* @param UpdateDetailsRequest $request
* @return mixed
*/
public function update(User $user, UpdateDetailsRequest $request)
{
$data = $request->all();
if (! data_get($data, 'country_id')) {
$data['country_id'] = null;
}
$this->users->update($user->id, $data);
$this->users->setRole($user->id, $request->role_id);
event(new UpdatedByAdmin($user));
// If user status was updated to "Banned",
// fire the appropriate event.
if ($this->userWasBanned($user, $request)) {
event(new Banned($user));
}
return redirect()->back()
->withSuccess(__('User updated successfully.'));
}
/**
* Check if user is banned during last update.
*
* @param User $user
* @param Request $request
* @return bool
*/
private function userWasBanned(User $user, Request $request)
{
return $user->status != $request->status
&& $request->status == UserStatus::BANNED;
}
}
@@ -0,0 +1,44 @@
<?php
namespace Vanguard\Http\Controllers\Web\Users;
use Vanguard\Events\User\UpdatedByAdmin;
use Vanguard\Http\Controllers\Controller;
use Vanguard\Http\Requests\User\UpdateLoginDetailsRequest;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\User;
/**
* Class UserDetailsController
* @package Vanguard\Http\Controllers\Users
*/
class LoginDetailsController extends Controller
{
public function __construct(private UserRepository $users)
{
}
/**
* Update user's login details.
*
* @param User $user
* @param UpdateLoginDetailsRequest $request
* @return mixed
*/
public function update(User $user, UpdateLoginDetailsRequest $request)
{
$data = $request->all();
if (! $data['password']) {
unset($data['password']);
unset($data['password_confirmation']);
}
$this->users->update($user->id, $data);
event(new UpdatedByAdmin($user));
return redirect()->route('users.edit', $user->id)
->withSuccess(__('Login details updated successfully.'));
}
}
@@ -0,0 +1,51 @@
<?php
namespace Vanguard\Http\Controllers\Web\Users;
use Illuminate\Contracts\View\Factory;
use Illuminate\View\View;
use Vanguard\Http\Controllers\Controller;
use Vanguard\Repositories\Session\SessionRepository;
use Vanguard\User;
/**
* Class SessionsController
* @package Vanguard\Http\Controllers\Web\Users
*/
class SessionsController extends Controller
{
public function __construct(private SessionRepository $sessions)
{
$this->middleware('permission:users.manage');
}
/**
* Displays the list with all active sessions for the selected user.
*
* @param User $user
* @return Factory|View
*/
public function index(User $user)
{
return view('user.sessions', [
'adminView' => true,
'user' => $user,
'sessions' => $this->sessions->getUserSessions($user->id)
]);
}
/**
* Invalidate specified session for selected user.
*
* @param User $user
* @param $session
* @return mixed
*/
public function destroy(User $user, $session)
{
$this->sessions->invalidateSession($session->id);
return redirect()->route('user.sessions', $user->id)
->withSuccess(__('Session invalidated successfully.'));
}
}
@@ -0,0 +1,153 @@
<?php
namespace Vanguard\Http\Controllers\Web\Users;
use Illuminate\Contracts\View\Factory;
use Illuminate\Http\Request;
use Illuminate\View\View;
use Vanguard\Events\User\Deleted;
use Vanguard\Http\Controllers\Controller;
use Vanguard\Http\Requests\User\CreateUserRequest;
use Vanguard\Repositories\Activity\ActivityRepository;
use Vanguard\Repositories\Country\CountryRepository;
use Vanguard\Repositories\Role\RoleRepository;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\Support\Enum\UserStatus;
use Vanguard\User;
/**
* Class UsersController
* @package Vanguard\Http\Controllers
*/
class UsersController extends Controller
{
public function __construct(private UserRepository $users)
{
}
/**
* Display paginated list of all users.
*
* @param Request $request
* @return Factory|View
*/
public function index(Request $request)
{
$users = $this->users->paginate($perPage = 20, $request->search, $request->status);
$statuses = ['' => __('All')] + UserStatus::lists();
return view('user.list', compact('users', 'statuses'));
}
/**
* Displays user profile page.
*
* @param User $user
* @return Factory|View
*/
public function show(User $user)
{
return view('user.view', compact('user'));
}
/**
* Displays form for creating a new user.
*
* @param CountryRepository $countryRepository
* @param RoleRepository $roleRepository
* @return Factory|View
*/
public function create(CountryRepository $countryRepository, RoleRepository $roleRepository)
{
return view('user.add', [
'countries' => $this->parseCountries($countryRepository),
'roles' => $roleRepository->lists(),
'statuses' => UserStatus::lists()
]);
}
/**
* Parse countries into an array that also has a blank
* item as first element, which will allow users to
* leave the country field unpopulated.
*
* @param CountryRepository $countryRepository
* @return array
*/
private function parseCountries(CountryRepository $countryRepository)
{
return [0 => __('Select a Country')] + $countryRepository->lists()->toArray();
}
/**
* Stores new user into the database.
*
* @param CreateUserRequest $request
* @return mixed
*/
public function store(CreateUserRequest $request)
{
// When user is created by administrator, we will set his
// status to Active by default.
$data = $request->all() + [
'status' => UserStatus::ACTIVE,
'email_verified_at' => now()
];
if (! data_get($data, 'country_id')) {
$data['country_id'] = null;
}
// Username should be updated only if it is provided.
if (! data_get($data, 'username')) {
$data['username'] = null;
}
$this->users->create($data);
return redirect()->route('users.index')
->withSuccess(__('User created successfully.'));
}
/**
* Displays edit user form.
*
* @param User $user
* @param CountryRepository $countryRepository
* @param RoleRepository $roleRepository
* @return Factory|View
*/
public function edit(User $user, CountryRepository $countryRepository, RoleRepository $roleRepository)
{
return view('user.edit', [
'edit' => true,
'user' => $user,
'countries' => $this->parseCountries($countryRepository),
'roles' => $roleRepository->lists(),
'statuses' => UserStatus::lists(),
'socialLogins' => $this->users->getUserSocialLogins($user->id)
]);
}
/**
* Removes the user from database.
*
* @param User $user
* @return $this
*/
public function destroy(User $user)
{
if ($user->is(auth()->user())) {
return redirect()->route('users.index')
->withErrors(__('You cannot delete yourself.'));
}
$this->users->delete($user->id);
event(new Deleted($user));
return redirect()->route('users.index')
->withSuccess(__('User deleted successfully.'));
}
}