mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-05 18:23:48 +00:00
206 lines
5.1 KiB
PHP
206 lines
5.1 KiB
PHP
<?php
|
|
namespace App\Http\Controllers\User;
|
|
|
|
use App\Models\User;
|
|
use Illuminate\Support\Str;
|
|
use Illuminate\Http\Request;
|
|
use App\Services\DemoService;
|
|
use Illuminate\Http\Response;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Resources\UserResource;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Http\RedirectResponse;
|
|
use Laravel\Sanctum\PersonalAccessToken;
|
|
use App\Http\Resources\InvoiceCollection;
|
|
use Illuminate\Support\Facades\Validator;
|
|
use App\Http\Resources\UserStorageResource;
|
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
use App\Http\Requests\User\UpdateUserPasswordRequest;
|
|
use App\Http\Requests\User\UserCreateAccessTokenRequest;
|
|
|
|
class AccountController extends Controller
|
|
{
|
|
/**
|
|
* AccountController constructor.
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->demo = resolve(DemoService::class);
|
|
}
|
|
|
|
/**
|
|
* Get all user data to frontend
|
|
*
|
|
* @return UserResource
|
|
*/
|
|
public function user()
|
|
{
|
|
return new UserResource(
|
|
Auth::user()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get storage details
|
|
*
|
|
* @return UserStorageResource
|
|
*/
|
|
public function storage()
|
|
{
|
|
return new UserStorageResource(
|
|
Auth::user()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get user invoices
|
|
*
|
|
* @return InvoiceCollection
|
|
*/
|
|
public function invoices()
|
|
{
|
|
return new InvoiceCollection(
|
|
Auth::user()->invoices()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Update user settings relationship
|
|
*
|
|
* @param Request $request
|
|
* @return ResponseFactory|\Illuminate\Http\Response
|
|
*/
|
|
public function update_user_settings(Request $request)
|
|
{
|
|
// Validate request
|
|
// TODO: pridat validator do requestu
|
|
$validator = Validator::make($request->all(), [
|
|
'avatar' => 'sometimes|file',
|
|
'name' => 'string',
|
|
'value' => 'string',
|
|
]);
|
|
|
|
// Return error
|
|
if ($validator->fails()) {
|
|
abort(400, 'Bad input');
|
|
}
|
|
|
|
// Get user
|
|
$user = Auth::user();
|
|
|
|
// Check if is demo
|
|
abort_if(is_demo_account('howdy@hi5ve.digital'), 204, 'Done.');
|
|
|
|
// Update avatar
|
|
if ($request->hasFile('avatar')) {
|
|
$user
|
|
->settings()
|
|
->update([
|
|
'avatar' => store_avatar($request, 'avatar'),
|
|
]);
|
|
|
|
return response('Saved!', 204);
|
|
}
|
|
|
|
$user
|
|
->settings()
|
|
->update(
|
|
make_single_input($request)
|
|
);
|
|
|
|
return response('Saved!', 204);
|
|
}
|
|
|
|
/**
|
|
* Change user password
|
|
*
|
|
* @param Request $request
|
|
* @return ResponseFactory|\Illuminate\Http\Response
|
|
*/
|
|
public function change_password(UpdateUserPasswordRequest $request)
|
|
{
|
|
// Get user
|
|
$user = Auth::user();
|
|
|
|
// Check if is demo
|
|
abort_if(is_demo_account('howdy@hi5ve.digital'), 204, 'Done.');
|
|
|
|
// Change and store new password
|
|
$user->password = bcrypt($request->input('password'));
|
|
$user->save();
|
|
|
|
return response('Changed!', 204);
|
|
}
|
|
|
|
/**
|
|
* Get all user tokens
|
|
*/
|
|
public function tokens(): Response
|
|
{
|
|
return response(
|
|
Auth::user()->tokens()->get(),
|
|
200
|
|
);
|
|
}
|
|
|
|
public function create_token(UserCreateAccessTokenRequest $request): Response
|
|
{
|
|
// Check if is demo
|
|
abort_if(is_demo_account('howdy@hi5ve.digital'), 201, [
|
|
'name' => 'token',
|
|
'token' => Str::random(40),
|
|
'abilities' => '["*"]',
|
|
'tokenable_id' => Str::uuid(),
|
|
'updated_at' => now(),
|
|
'created_at' => now(),
|
|
'id' => Str::random(40),
|
|
]);
|
|
|
|
$token = Auth::user()->createToken($request->input('name'));
|
|
|
|
return response($token, 201);
|
|
}
|
|
|
|
public function revoke_token(PersonalAccessToken $token): Response
|
|
{
|
|
// Check if is demo
|
|
abort_if(is_demo_account('howdy@hi5ve.digital'), 204, 'Deleted!');
|
|
|
|
if (Auth::id() !== $token->tokenable_id) {
|
|
return response('Unauthorized', 401);
|
|
}
|
|
|
|
$token->delete();
|
|
|
|
return response('Deleted!', 204);
|
|
}
|
|
|
|
public function email_verification(string $id, Request $request): RedirectResponse | Response
|
|
{
|
|
if (! $request->hasValidSignature()) {
|
|
return response('Invalid or expired url provided.', 401);
|
|
}
|
|
|
|
$user = User::find($id);
|
|
|
|
if (! $user->hasVerifiedEmail()) {
|
|
$user->markEmailAsVerified();
|
|
}
|
|
|
|
return redirect()->to('/successfully-verified');
|
|
}
|
|
|
|
public function resend_verification_email(Request $request): Response
|
|
{
|
|
$user = User::whereEmail($request->input('email'))->first();
|
|
|
|
if ($user->hasVerifiedEmail()) {
|
|
return response('Email was already verified.', 204);
|
|
}
|
|
|
|
$user->sendEmailVerificationNotification();
|
|
|
|
return response('Email verification link sent to your email', 204);
|
|
}
|
|
}
|