mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 16:22:14 +00:00
controller refactoring part 15
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -1,37 +1,46 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Domain\Admin\Controllers\UserController;
|
use Domain\Admin\Controllers\Dashboard\GetNewbiesController;
|
||||||
use Domain\Localization\Controllers\UpdateLanguageStringController;
|
use Domain\Admin\Controllers\Dashboard\GetWidgetsValuesController;
|
||||||
|
use Domain\Admin\Controllers\Users\UserController;
|
||||||
|
use Domain\Admin\Controllers\Users\ChangeUserRoleController;
|
||||||
|
use Domain\Admin\Controllers\Users\ChangeUserStorageCapacityController;
|
||||||
|
use Domain\Admin\Controllers\Users\DeleteUserController;
|
||||||
|
use Domain\Admin\Controllers\Users\ResetUserPasswordController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserInvoicesController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserStorageCapacityController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserSubscriptionController;
|
||||||
use Domain\Plans\Controllers\PlansController;
|
use Domain\Plans\Controllers\PlansController;
|
||||||
use Domain\Admin\Controllers\InvoiceController;
|
use Domain\Admin\Controllers\InvoiceController;
|
||||||
use Domain\Admin\Controllers\DashboardController;
|
|
||||||
use Domain\Pages\Controllers\AdminPagesController;
|
use Domain\Pages\Controllers\AdminPagesController;
|
||||||
use Domain\Localization\Controllers\LanguageController;
|
|
||||||
use Domain\Settings\Controllers\AdminSettingsController;
|
|
||||||
use Domain\Settings\Controllers\FlushCacheController;
|
|
||||||
use Domain\Settings\Controllers\GetSettingsValueController;
|
|
||||||
use Domain\Settings\Controllers\SetEmailController;
|
use Domain\Settings\Controllers\SetEmailController;
|
||||||
use Domain\Settings\Controllers\SetStripeController;
|
use Domain\Settings\Controllers\SetStripeController;
|
||||||
|
use Domain\Settings\Controllers\FlushCacheController;
|
||||||
|
use Domain\Localization\Controllers\LanguageController;
|
||||||
|
use Domain\Settings\Controllers\GetSettingsValueController;
|
||||||
use Domain\Settings\Controllers\UpdateSettingValueController;
|
use Domain\Settings\Controllers\UpdateSettingValueController;
|
||||||
|
use Domain\Localization\Controllers\UpdateLanguageStringController;
|
||||||
|
|
||||||
// Dashboard
|
// Dashboard
|
||||||
Route::group(['prefix' => 'dashboard'], function () {
|
Route::group(['prefix' => 'dashboard'], function () {
|
||||||
Route::get('/newbies', [DashboardController::class, 'newbies']);
|
Route::get('/newbies', GetNewbiesController::class);
|
||||||
Route::get('/', [DashboardController::class, 'index']);
|
Route::get('/', GetWidgetsValuesController::class);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Users
|
// Users
|
||||||
Route::group(['prefix' => 'users'], function () {
|
Route::group(['prefix' => 'users'], function () {
|
||||||
Route::patch('/{user}/capacity', [UserController::class, 'change_storage_capacity']);
|
Route::patch('/{user}/capacity', ChangeUserStorageCapacityController::class);
|
||||||
Route::post('/{user}/reset-password', [UserController::class, 'reset_password']);
|
Route::post('/{user}/reset-password', ResetUserPasswordController::class);
|
||||||
Route::get('/{user}/subscription', [UserController::class, 'subscription']);
|
Route::get('/{user}/storage', ShowUserStorageCapacityController::class);
|
||||||
Route::delete('/{user}/delete', [UserController::class, 'delete_user']);
|
Route::patch('/{user}/role', ChangeUserRoleController::class);
|
||||||
Route::patch('/{user}/role', [UserController::class, 'change_role']);
|
Route::delete('/{user}/delete', DeleteUserController::class);
|
||||||
Route::get('/{user}/invoices', [UserController::class, 'invoices']);
|
|
||||||
Route::get('/{user}/storage', [UserController::class, 'storage']);
|
// Subscription
|
||||||
Route::get('/{user}/detail', [UserController::class, 'details']);
|
Route::get('/{user}/subscription', ShowUserSubscriptionController::class);
|
||||||
Route::post('/create', [UserController::class, 'create_user']);
|
Route::get('/{user}/invoices', ShowUserInvoicesController::class);
|
||||||
Route::get('/', [UserController::class, 'users']);
|
|
||||||
|
// Resource
|
||||||
|
Route::apiResource('/', UserController::class);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Plans
|
// Plans
|
||||||
|
|||||||
@@ -11,10 +11,10 @@ use App\Users\Controllers\ForgotPasswordController;
|
|||||||
use Domain\Files\Controllers\UploadFilesController;
|
use Domain\Files\Controllers\UploadFilesController;
|
||||||
use Domain\Folders\Controllers\FavouriteController;
|
use Domain\Folders\Controllers\FavouriteController;
|
||||||
use Domain\Plans\Controllers\ActivePlansController;
|
use Domain\Plans\Controllers\ActivePlansController;
|
||||||
use Domain\Settings\Controllers\GetSettingsValueController;
|
|
||||||
use Domain\Zipping\Controllers\ZipFolderController;
|
use Domain\Zipping\Controllers\ZipFolderController;
|
||||||
use Domain\Folders\Controllers\CreateFolderController;
|
use Domain\Folders\Controllers\CreateFolderController;
|
||||||
use Domain\Sharing\Controllers\ShareViaEmailController;
|
use Domain\Sharing\Controllers\ShareViaEmailController;
|
||||||
|
use Domain\Settings\Controllers\GetSettingsValueController;
|
||||||
use Domain\Trash\Controllers\RestoreTrashContentController;
|
use Domain\Trash\Controllers\RestoreTrashContentController;
|
||||||
use Domain\Browsing\Controllers\BrowseLatestFilesController;
|
use Domain\Browsing\Controllers\BrowseLatestFilesController;
|
||||||
use Domain\Browsing\Controllers\BrowseSharedItemsController;
|
use Domain\Browsing\Controllers\BrowseSharedItemsController;
|
||||||
|
|||||||
@@ -1,21 +1,20 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use App\Users\Controllers\Account\AccountDetailsController;
|
|
||||||
use App\Users\Controllers\Account\StorageCapacityController;
|
|
||||||
use App\Users\Controllers\Account\UpdatePasswordController;
|
|
||||||
use App\Users\Controllers\Account\UpdateProfileSettingsController;
|
|
||||||
use App\Users\Controllers\AuthController;
|
|
||||||
use App\Users\Controllers\Authentication\AccountAccessTokenController;
|
|
||||||
use App\Users\Controllers\Authentication\CheckAccountController;
|
|
||||||
use App\Users\Controllers\Verification\ResendVerificationEmail;
|
|
||||||
use App\Users\Controllers\Verification\VerifyEmailController;
|
|
||||||
use Domain\Invoices\Controllers\UserInvoicesController;
|
use Domain\Invoices\Controllers\UserInvoicesController;
|
||||||
use Domain\Payments\Controllers\PaymentMethodsController;
|
use Domain\Payments\Controllers\PaymentMethodsController;
|
||||||
|
use App\Users\Controllers\Account\AccountDetailsController;
|
||||||
|
use App\Users\Controllers\Account\UpdatePasswordController;
|
||||||
|
use App\Users\Controllers\Account\StorageCapacityController;
|
||||||
|
use App\Users\Controllers\Verification\VerifyEmailController;
|
||||||
use Domain\Subscriptions\Controllers\GetSetupIntentController;
|
use Domain\Subscriptions\Controllers\GetSetupIntentController;
|
||||||
|
use App\Users\Controllers\Verification\ResendVerificationEmail;
|
||||||
|
use App\Users\Controllers\Authentication\CheckAccountController;
|
||||||
|
use App\Users\Controllers\Account\UpdateProfileSettingsController;
|
||||||
use Domain\Subscriptions\Controllers\SubscriptionCancelController;
|
use Domain\Subscriptions\Controllers\SubscriptionCancelController;
|
||||||
use Domain\Subscriptions\Controllers\SubscriptionDetailsController;
|
|
||||||
use Domain\Subscriptions\Controllers\SubscriptionResumeController;
|
use Domain\Subscriptions\Controllers\SubscriptionResumeController;
|
||||||
|
use Domain\Subscriptions\Controllers\SubscriptionDetailsController;
|
||||||
use Domain\Subscriptions\Controllers\SubscriptionUpgradeController;
|
use Domain\Subscriptions\Controllers\SubscriptionUpgradeController;
|
||||||
|
use App\Users\Controllers\Authentication\AccountAccessTokenController;
|
||||||
|
|
||||||
Route::post('/check', CheckAccountController::class);
|
Route::post('/check', CheckAccountController::class);
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ use Domain\Subscriptions\Controllers\StripeWebhookController;
|
|||||||
use Domain\SetupWizard\Controllers\CreateAdminAccountController;
|
use Domain\SetupWizard\Controllers\CreateAdminAccountController;
|
||||||
use Domain\Localization\Controllers\CurrentLocalizationController;
|
use Domain\Localization\Controllers\CurrentLocalizationController;
|
||||||
|
|
||||||
|
|
||||||
// Setup Wizard
|
// Setup Wizard
|
||||||
Route::post('/admin-setup', CreateAdminAccountController::class);
|
Route::post('/admin-setup', CreateAdminAccountController::class);
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Account;
|
namespace App\Users\Controllers\Account;
|
||||||
|
|
||||||
|
|
||||||
use App\Users\Resources\UserStorageResource;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use App\Users\Resources\UserStorageResource;
|
||||||
|
|
||||||
class StorageCapacityController
|
class StorageCapacityController
|
||||||
{
|
{
|
||||||
@@ -15,4 +12,4 @@ class StorageCapacityController
|
|||||||
Auth::user()
|
Auth::user()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,19 +1,16 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Account;
|
namespace App\Users\Controllers\Account;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Requests\UpdateUserPasswordRequest;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use App\Users\Requests\UpdateUserPasswordRequest;
|
||||||
|
|
||||||
class UpdatePasswordController extends Controller
|
class UpdatePasswordController extends Controller
|
||||||
{
|
{
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
UpdateUserPasswordRequest $request
|
UpdateUserPasswordRequest $request
|
||||||
): Response{
|
): Response {
|
||||||
$user = Auth::user();
|
$user = Auth::user();
|
||||||
|
|
||||||
// Check if is demo
|
// Check if is demo
|
||||||
@@ -26,4 +23,4 @@ class UpdatePasswordController extends Controller
|
|||||||
|
|
||||||
return response('Changed!', 204);
|
return response('Changed!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Account;
|
namespace App\Users\Controllers\Account;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Illuminate\Support\Facades\Validator;
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
|
||||||
@@ -55,4 +52,4 @@ class UpdateProfileSettingsController extends Controller
|
|||||||
|
|
||||||
return response('Saved!', 204);
|
return response('Saved!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,15 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Authentication;
|
namespace App\Users\Controllers\Authentication;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Requests\UserCreateAccessTokenRequest;
|
|
||||||
use Illuminate\Http\Response;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Laravel\Sanctum\PersonalAccessToken;
|
use Laravel\Sanctum\PersonalAccessToken;
|
||||||
|
use App\Users\Requests\UserCreateAccessTokenRequest;
|
||||||
|
|
||||||
class AccountAccessTokenController extends Controller
|
class AccountAccessTokenController extends Controller
|
||||||
{
|
{
|
||||||
@@ -19,7 +16,8 @@ class AccountAccessTokenController extends Controller
|
|||||||
public function index(): Response
|
public function index(): Response
|
||||||
{
|
{
|
||||||
return response(
|
return response(
|
||||||
Auth::user()->tokens()->get(), 200
|
Auth::user()->tokens()->get(),
|
||||||
|
200
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -61,4 +59,4 @@ class AccountAccessTokenController extends Controller
|
|||||||
|
|
||||||
return response('Deleted!', 204);
|
return response('Deleted!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,9 +2,9 @@
|
|||||||
namespace App\Users\Controllers\Authentication;
|
namespace App\Users\Controllers\Authentication;
|
||||||
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Requests\CheckAccountRequest;
|
use App\Users\Requests\CheckAccountRequest;
|
||||||
use Illuminate\Http\Response;
|
|
||||||
|
|
||||||
class CheckAccountController extends Controller
|
class CheckAccountController extends Controller
|
||||||
{
|
{
|
||||||
@@ -13,8 +13,7 @@ class CheckAccountController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
CheckAccountRequest $request
|
CheckAccountRequest $request
|
||||||
): array|Response {
|
): array | Response {
|
||||||
|
|
||||||
$user = User::whereEmail($request->input('email'))
|
$user = User::whereEmail($request->input('email'))
|
||||||
->first();
|
->first();
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +1,16 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Verification;
|
namespace App\Users\Controllers\Verification;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class ResendVerificationEmail extends Controller
|
class ResendVerificationEmail extends Controller
|
||||||
{
|
{
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
Request $request
|
Request $request
|
||||||
): Response {
|
): Response {
|
||||||
|
|
||||||
$user = User::where('email', $request->input('email'))
|
$user = User::where('email', $request->input('email'))
|
||||||
->first();
|
->first();
|
||||||
|
|
||||||
@@ -26,4 +22,4 @@ class ResendVerificationEmail extends Controller
|
|||||||
|
|
||||||
return response('Email verification link sent to your email', 204);
|
return response('Email verification link sent to your email', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,22 +1,18 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace App\Users\Controllers\Verification;
|
namespace App\Users\Controllers\Verification;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Illuminate\Http\RedirectResponse;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Illuminate\Http\RedirectResponse;
|
||||||
|
|
||||||
class VerifyEmailController extends Controller
|
class VerifyEmailController extends Controller
|
||||||
{
|
{
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
string $id,
|
string $id,
|
||||||
Request $request,
|
Request $request,
|
||||||
): RedirectResponse|Response {
|
): RedirectResponse | Response {
|
||||||
|
|
||||||
if (! $request->hasValidSignature()) {
|
if (! $request->hasValidSignature()) {
|
||||||
return response('Invalid or expired url provided.', 401);
|
return response('Invalid or expired url provided.', 401);
|
||||||
}
|
}
|
||||||
@@ -29,4 +25,4 @@ class VerifyEmailController extends Controller
|
|||||||
|
|
||||||
return redirect()->to('/successfully-verified');
|
return redirect()->to('/successfully-verified');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ use Laravel\Sanctum\HasApiTokens;
|
|||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Database\Factories\UserFactory;
|
use Database\Factories\UserFactory;
|
||||||
use Kyslik\ColumnSortable\Sortable;
|
use Kyslik\ColumnSortable\Sortable;
|
||||||
use Support\Services\HelperService;
|
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Illuminate\Notifications\Notifiable;
|
use Illuminate\Notifications\Notifiable;
|
||||||
use App\Users\Notifications\ResetPassword;
|
use App\Users\Notifications\ResetPassword;
|
||||||
@@ -215,10 +214,5 @@ class User extends Authenticatable implements MustVerifyEmail
|
|||||||
// Create user directory for his files
|
// Create user directory for his files
|
||||||
Storage::makeDirectory("files/$user->id");
|
Storage::makeDirectory("files/$user->id");
|
||||||
});
|
});
|
||||||
|
|
||||||
static::deleted(function ($user) {
|
|
||||||
resolve(HelperService::class)
|
|
||||||
->erase_user_data($user);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
34
src/Domain/Admin/Actions/DeleteUserDataAction.php
Normal file
34
src/Domain/Admin/Actions/DeleteUserDataAction.php
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Admin\Actions;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use DB;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
|
||||||
|
class DeleteUserDataAction
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Delete all user data including files, folders, avatar etc.
|
||||||
|
*/
|
||||||
|
public function __invoke(User $user)
|
||||||
|
{
|
||||||
|
// Delete user avatar if exists
|
||||||
|
if ($user->settings->getRawOriginal('avatar')) {
|
||||||
|
Storage::delete($user->settings->getRawOriginal('avatar'));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete all user files
|
||||||
|
Storage::deleteDirectory("files/$user->id");
|
||||||
|
|
||||||
|
// Delete all user records in database
|
||||||
|
collect(['folders', 'files', 'user_settings', 'shares', 'favourite_folder', 'zips', 'traffic'])
|
||||||
|
->each(function ($table) use ($user) {
|
||||||
|
DB::table($table)
|
||||||
|
->whereUserId($user->id)
|
||||||
|
->delete();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Admin\Controllers\Dashboard;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use App\Users\Resources\UsersCollection;
|
||||||
|
|
||||||
|
class GetNewbiesController extends Controller
|
||||||
|
{
|
||||||
|
public function __invoke(): UsersCollection
|
||||||
|
{
|
||||||
|
$users = User::sortable([
|
||||||
|
'created_at' => 'desc'
|
||||||
|
])
|
||||||
|
->paginate(10);
|
||||||
|
|
||||||
|
return new UsersCollection($users);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,26 +1,17 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers;
|
|
||||||
|
|
||||||
use ByteUnits\Metric;
|
|
||||||
use App\Users\Models\User;
|
namespace Domain\Admin\Controllers\Dashboard;
|
||||||
use Laravel\Cashier\Subscription;
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UsersCollection;
|
use App\Users\Models\User;
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
use ByteUnits\Metric;
|
||||||
|
use Laravel\Cashier\Subscription;
|
||||||
|
|
||||||
class DashboardController extends Controller
|
class GetWidgetsValuesController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __invoke(): array
|
||||||
private StripeService $stripe
|
|
||||||
) {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get data for dashboard
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function index()
|
|
||||||
{
|
{
|
||||||
// Get total premium users
|
// Get total premium users
|
||||||
$premium_users = Subscription::whereStripeStatus('active')
|
$premium_users = Subscription::whereStripeStatus('active')
|
||||||
@@ -39,17 +30,4 @@ class DashboardController extends Controller
|
|||||||
'total_premium_users' => $premium_users,
|
'total_premium_users' => $premium_users,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
/**
|
|
||||||
* Get the newest users
|
|
||||||
*
|
|
||||||
* @return UsersCollection
|
|
||||||
*/
|
|
||||||
public function newbies()
|
|
||||||
{
|
|
||||||
return new UsersCollection(
|
|
||||||
User::sortable(['created_at' => 'desc'])
|
|
||||||
->paginate(10)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,228 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Domain\Admin\Controllers;
|
|
||||||
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use Illuminate\Http\Response;
|
|
||||||
use App\Users\Models\UserSettings;
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
|
||||||
use App\Users\Resources\UserResource;
|
|
||||||
use App\Users\Resources\UsersCollection;
|
|
||||||
use Illuminate\Support\Facades\Password;
|
|
||||||
use App\Users\Resources\UserSubscription;
|
|
||||||
use App\Users\Resources\UserStorageResource;
|
|
||||||
use Domain\Admin\Requests\ChangeRoleRequest;
|
|
||||||
use Domain\Admin\Requests\CreateUserByAdmin;
|
|
||||||
use Domain\Admin\Requests\DeleteUserRequest;
|
|
||||||
use Domain\Invoices\Resources\InvoiceCollection;
|
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
|
||||||
use Illuminate\Contracts\Foundation\Application;
|
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
||||||
use Domain\Admin\Requests\ChangeStorageCapacityRequest;
|
|
||||||
|
|
||||||
class UserController extends Controller
|
|
||||||
{
|
|
||||||
public function __construct(
|
|
||||||
private StripeService $stripe
|
|
||||||
) {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get user details
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
* @return UserResource
|
|
||||||
*/
|
|
||||||
public function details(User $user)
|
|
||||||
{
|
|
||||||
return new UserResource(
|
|
||||||
$user
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get user storage details
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
* @return UserStorageResource
|
|
||||||
*/
|
|
||||||
public function storage(User $user)
|
|
||||||
{
|
|
||||||
return new UserStorageResource(
|
|
||||||
$user
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get user storage details
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
* @return InvoiceCollection
|
|
||||||
*/
|
|
||||||
public function invoices(User $user)
|
|
||||||
{
|
|
||||||
return new InvoiceCollection(
|
|
||||||
$this
|
|
||||||
->stripe
|
|
||||||
->getUserInvoices($user)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get user subscription details
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
* @return UserSubscription|Application|ResponseFactory|Response
|
|
||||||
*/
|
|
||||||
public function subscription(User $user)
|
|
||||||
{
|
|
||||||
if (! $user->stripeId() || ! $user->subscription('main')) {
|
|
||||||
return response("User doesn't have any subscription.", 404);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new UserSubscription(
|
|
||||||
$user
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get all users
|
|
||||||
*
|
|
||||||
* @return UsersCollection
|
|
||||||
*/
|
|
||||||
public function users()
|
|
||||||
{
|
|
||||||
return new UsersCollection(
|
|
||||||
User::sortable(['created_at', 'DESC'])
|
|
||||||
->paginate(20)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Change user role
|
|
||||||
*
|
|
||||||
* @param ChangeRoleRequest $request
|
|
||||||
* @param User $user
|
|
||||||
* @return UserResource
|
|
||||||
*/
|
|
||||||
public function change_role(ChangeRoleRequest $request, User $user)
|
|
||||||
{
|
|
||||||
// Demo preview
|
|
||||||
if (is_demo_account('howdy@hi5ve.digial')) {
|
|
||||||
return new UserResource($user);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update user role
|
|
||||||
$user->role = $request->input('attributes.role');
|
|
||||||
$user->save();
|
|
||||||
|
|
||||||
return new UserResource(
|
|
||||||
$user
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Change user storage capacity
|
|
||||||
*
|
|
||||||
* @param ChangeStorageCapacityRequest $request
|
|
||||||
* @param User $user
|
|
||||||
* @return UserStorageResource
|
|
||||||
*/
|
|
||||||
public function change_storage_capacity(ChangeStorageCapacityRequest $request, User $user)
|
|
||||||
{
|
|
||||||
$user
|
|
||||||
->settings()
|
|
||||||
->update(
|
|
||||||
$request->input('attributes')
|
|
||||||
);
|
|
||||||
|
|
||||||
return new UserStorageResource(
|
|
||||||
$user
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Send user password reset link
|
|
||||||
*
|
|
||||||
* @param User $user
|
|
||||||
* @return ResponseFactory|Response
|
|
||||||
*/
|
|
||||||
public function reset_password(User $user)
|
|
||||||
{
|
|
||||||
// Demo preview
|
|
||||||
if (is_demo()) {
|
|
||||||
return response('Done!', 204);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get password token
|
|
||||||
$token = Password::getRepository()
|
|
||||||
->create($user);
|
|
||||||
|
|
||||||
// Send user email
|
|
||||||
$user->sendPasswordResetNotification($token);
|
|
||||||
|
|
||||||
return response('Done!', 204);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create new user by admin
|
|
||||||
*
|
|
||||||
* @param CreateUserByAdmin $request
|
|
||||||
* @return UserResource|Application|ResponseFactory|Response
|
|
||||||
*/
|
|
||||||
public function create_user(CreateUserByAdmin $request)
|
|
||||||
{
|
|
||||||
// Create user
|
|
||||||
$user = User::forceCreate([
|
|
||||||
'role' => $request->role,
|
|
||||||
'email' => $request->email,
|
|
||||||
'password' => bcrypt($request->password),
|
|
||||||
'email_verified_at' => now(),
|
|
||||||
]);
|
|
||||||
|
|
||||||
UserSettings::unguard();
|
|
||||||
|
|
||||||
$user
|
|
||||||
->settings()
|
|
||||||
->create([
|
|
||||||
'name' => $request->name,
|
|
||||||
'avatar' => store_avatar($request, 'avatar'),
|
|
||||||
'storage_capacity' => $request->storage_capacity,
|
|
||||||
]);
|
|
||||||
|
|
||||||
UserSettings::reguard();
|
|
||||||
|
|
||||||
return response(new UserResource($user), 201);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Delete user with all user data
|
|
||||||
*
|
|
||||||
* @param DeleteUserRequest $request
|
|
||||||
* @param User $user
|
|
||||||
* @return ResponseFactory|Response
|
|
||||||
* @throws \Exception
|
|
||||||
*/
|
|
||||||
public function delete_user(DeleteUserRequest $request, User $user)
|
|
||||||
{
|
|
||||||
if (is_demo()) {
|
|
||||||
return response('Done!', 204);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($user->subscribed('main')) {
|
|
||||||
abort(202, "You can\'t delete this account while user have active subscription.");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($user->id === Auth::id()) {
|
|
||||||
abort(406, "You can\'t delete your account");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($user->settings->name !== $request->name) {
|
|
||||||
abort(403, 'The name you typed is wrong!');
|
|
||||||
}
|
|
||||||
|
|
||||||
$user->delete();
|
|
||||||
|
|
||||||
return response('Done!', 204);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use App\Users\Resources\UserResource;
|
||||||
|
use Domain\Admin\Requests\ChangeRoleRequest;
|
||||||
|
|
||||||
|
class ChangeUserRoleController extends Controller
|
||||||
|
{
|
||||||
|
public function __invoke(
|
||||||
|
ChangeRoleRequest $request,
|
||||||
|
User $user,
|
||||||
|
): UserResource {
|
||||||
|
if (is_demo_account($user->email)) {
|
||||||
|
return new UserResource($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update user role
|
||||||
|
$user->update([
|
||||||
|
'role' => $request->input('attributes.role'),
|
||||||
|
]);
|
||||||
|
|
||||||
|
return new UserResource($user);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use App\Users\Resources\UserStorageResource;
|
||||||
|
use Domain\Admin\Requests\ChangeStorageCapacityRequest;
|
||||||
|
|
||||||
|
class ChangeUserStorageCapacityController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Change user storage capacity
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
ChangeStorageCapacityRequest $request,
|
||||||
|
User $user,
|
||||||
|
): UserStorageResource {
|
||||||
|
$user
|
||||||
|
->settings()
|
||||||
|
->update(
|
||||||
|
$request->input('attributes')
|
||||||
|
);
|
||||||
|
|
||||||
|
return new UserStorageResource($user);
|
||||||
|
}
|
||||||
|
}
|
||||||
45
src/Domain/Admin/Controllers/Users/DeleteUserController.php
Normal file
45
src/Domain/Admin/Controllers/Users/DeleteUserController.php
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Domain\Admin\Actions\DeleteUserDataAction;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Domain\Admin\Requests\DeleteUserRequest;
|
||||||
|
|
||||||
|
class DeleteUserController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Delete user with all user data
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
DeleteUserRequest $request,
|
||||||
|
User $user,
|
||||||
|
DeleteUserDataAction $deleteUserData,
|
||||||
|
): Response {
|
||||||
|
|
||||||
|
if (is_demo()) {
|
||||||
|
return response('Done!', 204);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($user->subscribed('main')) {
|
||||||
|
abort(202, "You can\'t delete this account while user have active subscription.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($user->id === Auth::id()) {
|
||||||
|
abort(406, "You can\'t delete your account");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($user->settings->name !== $request->name) {
|
||||||
|
abort(403, 'The name you typed is wrong!');
|
||||||
|
}
|
||||||
|
|
||||||
|
$user->delete();
|
||||||
|
|
||||||
|
// Delete all user data
|
||||||
|
($deleteUserData)($user);
|
||||||
|
|
||||||
|
return response('Done!', 204);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Illuminate\Support\Facades\Password;
|
||||||
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
||||||
|
|
||||||
|
class ResetUserPasswordController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Send user password reset link
|
||||||
|
*/
|
||||||
|
public function __invoke(User $user): Response
|
||||||
|
{
|
||||||
|
if (is_demo()) {
|
||||||
|
return response('Done!', 204);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get password token
|
||||||
|
$token = Password::getRepository()
|
||||||
|
->create($user);
|
||||||
|
|
||||||
|
// Send user email
|
||||||
|
$user->sendPasswordResetNotification($token);
|
||||||
|
|
||||||
|
return response('Done!', 204);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Domain\Invoices\Resources\InvoiceCollection;
|
||||||
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
|
|
||||||
|
class ShowUserInvoicesController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private StripeService $stripe
|
||||||
|
) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get user storage details
|
||||||
|
*/
|
||||||
|
public function __invoke(User $user): InvoiceCollection
|
||||||
|
{
|
||||||
|
$invoices = $this->stripe->getUserInvoices($user);
|
||||||
|
|
||||||
|
return new InvoiceCollection($invoices);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use App\Users\Resources\UserStorageResource;
|
||||||
|
|
||||||
|
class ShowUserStorageCapacityController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get user storage details
|
||||||
|
*/
|
||||||
|
public function __invoke(User $user): UserStorageResource
|
||||||
|
{
|
||||||
|
return new UserStorageResource($user);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use App\Users\Resources\UserSubscription;
|
||||||
|
|
||||||
|
class ShowUserSubscriptionController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get user subscription details
|
||||||
|
*/
|
||||||
|
public function __invoke(User $user): UserSubscription|Response
|
||||||
|
{
|
||||||
|
if (! $user->stripeId() || ! $user->subscription('main')) {
|
||||||
|
return response("User doesn't have any subscription.", 404);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new UserSubscription($user);
|
||||||
|
}
|
||||||
|
}
|
||||||
60
src/Domain/Admin/Controllers/Users/UserController.php
Normal file
60
src/Domain/Admin/Controllers/Users/UserController.php
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use App\Users\Models\UserSettings;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Resources\UserResource;
|
||||||
|
use App\Users\Resources\UsersCollection;
|
||||||
|
use Domain\Admin\Requests\CreateUserByAdmin;
|
||||||
|
|
||||||
|
class UserController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get all users
|
||||||
|
*/
|
||||||
|
public function index(): UsersCollection
|
||||||
|
{
|
||||||
|
$users = User::sortable(['created_at', 'DESC'])
|
||||||
|
->paginate(20);
|
||||||
|
|
||||||
|
return new UsersCollection($users);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get user details
|
||||||
|
*/
|
||||||
|
public function show(User $user): UserResource
|
||||||
|
{
|
||||||
|
return new UserResource($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create new user by admin
|
||||||
|
*/
|
||||||
|
public function store(CreateUserByAdmin $request): Response
|
||||||
|
{
|
||||||
|
// Create user
|
||||||
|
$user = User::forceCreate([
|
||||||
|
'password' => bcrypt($request->input('password')),
|
||||||
|
'role' => $request->input('role'),
|
||||||
|
'email' => $request->input('email'),
|
||||||
|
'email_verified_at' => now(),
|
||||||
|
]);
|
||||||
|
|
||||||
|
UserSettings::unguard();
|
||||||
|
|
||||||
|
$user
|
||||||
|
->settings()
|
||||||
|
->create([
|
||||||
|
'storage_capacity' => $request->input('storage_capacity'),
|
||||||
|
'avatar' => store_avatar($request, 'avatar'),
|
||||||
|
'name' => $request->input('name'),
|
||||||
|
]);
|
||||||
|
|
||||||
|
UserSettings::reguard();
|
||||||
|
|
||||||
|
return response(new UserResource($user), 201);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Invoices\Controllers;
|
namespace Domain\Invoices\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Invoices\Resources\InvoiceCollection;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Domain\Invoices\Resources\InvoiceCollection;
|
||||||
|
|
||||||
class UserInvoicesController extends Controller
|
class UserInvoicesController extends Controller
|
||||||
{
|
{
|
||||||
@@ -19,4 +16,4 @@ class UserInvoicesController extends Controller
|
|||||||
Auth::user()->invoices()
|
Auth::user()->invoices()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,10 +5,7 @@ use Illuminate\Http\Response;
|
|||||||
use Domain\Settings\Models\Setting;
|
use Domain\Settings\Models\Setting;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Localization\Models\Language;
|
use Domain\Localization\Models\Language;
|
||||||
use Illuminate\Contracts\Foundation\Application;
|
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
||||||
use Domain\Localization\Resources\LanguageResource;
|
use Domain\Localization\Resources\LanguageResource;
|
||||||
use Domain\Localization\Requests\UpdateStringRequest;
|
|
||||||
use Domain\Localization\Resources\LanguageCollection;
|
use Domain\Localization\Resources\LanguageCollection;
|
||||||
use Domain\Localization\Requests\CreateLanguageRequest;
|
use Domain\Localization\Requests\CreateLanguageRequest;
|
||||||
use Domain\Localization\Requests\UpdateLanguageRequest;
|
use Domain\Localization\Requests\UpdateLanguageRequest;
|
||||||
@@ -23,7 +20,8 @@ class LanguageController extends Controller
|
|||||||
return response(
|
return response(
|
||||||
new LanguageCollection(
|
new LanguageCollection(
|
||||||
Language::sortable(['created_at', 'DESC'])->get()
|
Language::sortable(['created_at', 'DESC'])->get()
|
||||||
), 200
|
),
|
||||||
|
200
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -33,7 +31,8 @@ class LanguageController extends Controller
|
|||||||
public function show(Language $language): Response
|
public function show(Language $language): Response
|
||||||
{
|
{
|
||||||
return response(
|
return response(
|
||||||
new LanguageResource($language), 200
|
new LanguageResource($language),
|
||||||
|
200
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -60,7 +59,8 @@ class LanguageController extends Controller
|
|||||||
* Update language
|
* Update language
|
||||||
*/
|
*/
|
||||||
public function update(
|
public function update(
|
||||||
UpdateLanguageRequest $request, Language $language
|
UpdateLanguageRequest $request,
|
||||||
|
Language $language
|
||||||
): Response {
|
): Response {
|
||||||
// Abort in demo mode
|
// Abort in demo mode
|
||||||
abort_if(is_demo(), 204, 'Done.');
|
abort_if(is_demo(), 204, 'Done.');
|
||||||
@@ -97,7 +97,8 @@ class LanguageController extends Controller
|
|||||||
$language->delete();
|
$language->delete();
|
||||||
|
|
||||||
return response(
|
return response(
|
||||||
'Done', 204
|
'Done',
|
||||||
|
204
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Localization\Controllers;
|
namespace Domain\Localization\Controllers;
|
||||||
|
|
||||||
|
use Illuminate\Http\Response;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Localization\Models\Language;
|
use Domain\Localization\Models\Language;
|
||||||
use Domain\Localization\Requests\UpdateStringRequest;
|
use Domain\Localization\Requests\UpdateStringRequest;
|
||||||
use Illuminate\Http\Response;
|
|
||||||
|
|
||||||
class UpdateLanguageStringController extends Controller
|
class UpdateLanguageStringController extends Controller
|
||||||
{
|
{
|
||||||
@@ -18,7 +15,6 @@ class UpdateLanguageStringController extends Controller
|
|||||||
UpdateStringRequest $request,
|
UpdateStringRequest $request,
|
||||||
Language $language,
|
Language $language,
|
||||||
): Response {
|
): Response {
|
||||||
|
|
||||||
// Abort in demo mode
|
// Abort in demo mode
|
||||||
abort_if(is_demo(), 204, 'Done.');
|
abort_if(is_demo(), 204, 'Done.');
|
||||||
|
|
||||||
@@ -32,7 +28,8 @@ class UpdateLanguageStringController extends Controller
|
|||||||
cache()->forget("language-translations-{$language->locale}");
|
cache()->forget("language-translations-{$language->locale}");
|
||||||
|
|
||||||
return response(
|
return response(
|
||||||
'Done', 204
|
'Done',
|
||||||
|
204
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Maintenance\Controllers;
|
namespace Domain\Maintenance\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Artisan;
|
|
||||||
use Gate;
|
use Gate;
|
||||||
|
use Artisan;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class MaintenanceModeController extends Controller
|
class MaintenanceModeController extends Controller
|
||||||
{
|
{
|
||||||
@@ -39,4 +36,4 @@ class MaintenanceModeController extends Controller
|
|||||||
echo 'System is in maintenance mode';
|
echo 'System is in maintenance mode';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Maintenance\Controllers;
|
namespace Domain\Maintenance\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Artisan;
|
|
||||||
use Gate;
|
use Gate;
|
||||||
|
use Artisan;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class UpgradeDatabaseController extends Controller
|
class UpgradeDatabaseController extends Controller
|
||||||
{
|
{
|
||||||
@@ -29,4 +26,4 @@ class UpgradeDatabaseController extends Controller
|
|||||||
|
|
||||||
return $command;
|
return $command;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -42,7 +42,8 @@ class AdminPagesController extends Controller
|
|||||||
);
|
);
|
||||||
|
|
||||||
return response(
|
return response(
|
||||||
new PageResource($page), 204
|
new PageResource($page),
|
||||||
|
204
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,6 @@
|
|||||||
namespace Domain\Payments\Controllers;
|
namespace Domain\Payments\Controllers;
|
||||||
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
use Laravel\Cashier\PaymentMethod;
|
use Laravel\Cashier\PaymentMethod;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
@@ -17,7 +16,8 @@ class PaymentMethodsController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private StripeService $stripe,
|
private StripeService $stripe,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get user payment methods grouped by default and others
|
* Get user payment methods grouped by default and others
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Settings\Controllers;
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
use Illuminate\Support\Collection;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Collection;
|
||||||
use Domain\Settings\Models\Setting;
|
use Domain\Settings\Models\Setting;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Settings\Controllers;
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Artisan;
|
use Artisan;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class FlushCacheController extends Controller
|
class FlushCacheController extends Controller
|
||||||
{
|
{
|
||||||
@@ -26,4 +23,4 @@ class FlushCacheController extends Controller
|
|||||||
|
|
||||||
return response('Done', 204);
|
return response('Done', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Settings\Controllers;
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use Artisan;
|
use Artisan;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
@@ -36,4 +33,4 @@ class SetEmailController
|
|||||||
|
|
||||||
return response('Done', 204);
|
return response('Done', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,15 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Settings\Controllers;
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use Artisan;
|
use Artisan;
|
||||||
use Cartalyst\Stripe\Exception\UnauthorizedException;
|
|
||||||
use Cartalyst\Stripe\Stripe;
|
use Cartalyst\Stripe\Stripe;
|
||||||
use Domain\Settings\Models\Setting;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use Domain\Settings\Models\Setting;
|
||||||
|
use Cartalyst\Stripe\Exception\UnauthorizedException;
|
||||||
use Symfony\Component\HttpKernel\Exception\HttpException;
|
use Symfony\Component\HttpKernel\Exception\HttpException;
|
||||||
|
|
||||||
class SetStripeController
|
class SetStripeController
|
||||||
@@ -74,4 +71,4 @@ class SetStripeController
|
|||||||
|
|
||||||
return response('Done', 204);
|
return response('Done', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Settings\Controllers;
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Domain\Settings\Models\Setting;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use Domain\Settings\Models\Setting;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class UpdateSettingValueController extends Controller
|
class UpdateSettingValueController extends Controller
|
||||||
{
|
{
|
||||||
@@ -39,4 +36,4 @@ class UpdateSettingValueController extends Controller
|
|||||||
|
|
||||||
return response('Done', 204);
|
return response('Done', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Subscriptions\Controllers;
|
namespace Domain\Subscriptions\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate setup intent
|
* Generate setup intent
|
||||||
@@ -16,12 +13,14 @@ class GetSetupIntentController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public StripeService $stripe,
|
public StripeService $stripe,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
public function __invoke(): Response
|
public function __invoke(): Response
|
||||||
{
|
{
|
||||||
return response(
|
return response(
|
||||||
$this->stripe->getSetupIntent(Auth::user()), 201
|
$this->stripe->getSetupIntent(Auth::user()),
|
||||||
|
201
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Subscriptions\Controllers;
|
namespace Domain\Subscriptions\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Cache;
|
use Illuminate\Support\Facades\Cache;
|
||||||
|
|
||||||
class SubscriptionCancelController extends Controller
|
class SubscriptionCancelController extends Controller
|
||||||
@@ -31,4 +28,4 @@ class SubscriptionCancelController extends Controller
|
|||||||
|
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Subscriptions\Controllers;
|
namespace Domain\Subscriptions\Controllers;
|
||||||
|
|
||||||
|
use Auth;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserSubscription;
|
use App\Users\Resources\UserSubscription;
|
||||||
use Auth;
|
|
||||||
|
|
||||||
class SubscriptionDetailsController extends Controller
|
class SubscriptionDetailsController extends Controller
|
||||||
{
|
{
|
||||||
@@ -14,7 +11,7 @@ class SubscriptionDetailsController extends Controller
|
|||||||
{
|
{
|
||||||
$user = Auth::user();
|
$user = Auth::user();
|
||||||
|
|
||||||
if (!$user->subscription('main')) {
|
if (! $user->subscription('main')) {
|
||||||
return abort(204, "User don't have any subscription");
|
return abort(204, "User don't have any subscription");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -25,7 +22,8 @@ class SubscriptionDetailsController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
return cache()->rememberForever(
|
return cache()->rememberForever(
|
||||||
$slug, fn() => new UserSubscription($user)
|
$slug,
|
||||||
|
fn () => new UserSubscription($user)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Subscriptions\Controllers;
|
namespace Domain\Subscriptions\Controllers;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Cache;
|
use Illuminate\Support\Facades\Cache;
|
||||||
|
|
||||||
class SubscriptionResumeController extends Controller
|
class SubscriptionResumeController extends Controller
|
||||||
@@ -30,4 +28,4 @@ class SubscriptionResumeController extends Controller
|
|||||||
|
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,15 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Subscriptions\Controllers;
|
namespace Domain\Subscriptions\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Domain\Subscriptions\Requests\StoreUpgradeAccountRequest;
|
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Cache;
|
use Illuminate\Support\Facades\Cache;
|
||||||
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
|
use Domain\Subscriptions\Requests\StoreUpgradeAccountRequest;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Upgrade account to subscription
|
* Upgrade account to subscription
|
||||||
@@ -18,7 +15,8 @@ class SubscriptionUpgradeController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public StripeService $stripe,
|
public StripeService $stripe,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
public function __invoke(StoreUpgradeAccountRequest $request): Response
|
public function __invoke(StoreUpgradeAccountRequest $request): Response
|
||||||
{
|
{
|
||||||
@@ -57,4 +55,4 @@ class SubscriptionUpgradeController extends Controller
|
|||||||
|
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,30 +15,6 @@ use Symfony\Component\HttpKernel\Exception\HttpException;
|
|||||||
|
|
||||||
class HelperService
|
class HelperService
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* Delete all user data including files, folders, avatar etc.
|
|
||||||
*
|
|
||||||
* @param $user
|
|
||||||
*/
|
|
||||||
public function erase_user_data($user)
|
|
||||||
{
|
|
||||||
// Delete user avatar if exists
|
|
||||||
if ($user->settings->getRawOriginal('avatar')) {
|
|
||||||
Storage::delete($user->settings->getRawOriginal('avatar'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete all user files
|
|
||||||
Storage::deleteDirectory("files/$user->id");
|
|
||||||
|
|
||||||
// Delete all user records in database
|
|
||||||
collect(['folders', 'files', 'user_settings', 'shares', 'favourite_folder', 'zips'])
|
|
||||||
->each(function ($table) use ($user) {
|
|
||||||
DB::table($table)
|
|
||||||
->whereUserId($user->id)
|
|
||||||
->delete();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check access to requested directory
|
* Check access to requested directory
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -24,67 +24,6 @@ class AdminTest extends TestCase
|
|||||||
$this->setup = app()->make(SetupService::class);
|
$this->setup = app()->make(SetupService::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
*/
|
|
||||||
public function it_get_dashboard_data()
|
|
||||||
{
|
|
||||||
$user = User::factory(User::class)
|
|
||||||
->create(['role' => 'admin']);
|
|
||||||
|
|
||||||
File::factory(File::class)
|
|
||||||
->count(2)
|
|
||||||
->create(['filesize' => 1000000]);
|
|
||||||
|
|
||||||
Setting::forceCreate([
|
|
||||||
'name' => 'license',
|
|
||||||
'value' => 'Regular',
|
|
||||||
]);
|
|
||||||
|
|
||||||
DB::table('subscriptions')
|
|
||||||
->insert([
|
|
||||||
'user_id' => $user->id,
|
|
||||||
'name' => 'main',
|
|
||||||
'stripe_id' => 'sub_Hp4jgdIpPDDWXw',
|
|
||||||
'stripe_status' => 'active',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this
|
|
||||||
->actingAs($user)
|
|
||||||
->getJson('/api/admin/dashboard')
|
|
||||||
->assertStatus(200)
|
|
||||||
->assertExactJson([
|
|
||||||
'license' => 'Regular',
|
|
||||||
'app_version' => config('vuefilemanager.version'),
|
|
||||||
'total_users' => 1,
|
|
||||||
'total_used_space' => '2.00MB',
|
|
||||||
'total_premium_users' => 1,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
*/
|
|
||||||
public function it_get_new_users_for_dashboard()
|
|
||||||
{
|
|
||||||
$users = User::factory(User::class)
|
|
||||||
->count(5)
|
|
||||||
->create(['role' => 'user']);
|
|
||||||
|
|
||||||
$admin = User::factory(User::class)
|
|
||||||
->create(['role' => 'admin']);
|
|
||||||
|
|
||||||
Sanctum::actingAs($admin);
|
|
||||||
|
|
||||||
$users->each(function ($user) {
|
|
||||||
$this->getJson('/api/admin/dashboard/newbies')
|
|
||||||
->assertStatus(200)
|
|
||||||
->assertJsonFragment([
|
|
||||||
'id' => $user->id,
|
|
||||||
]);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
|
|||||||
76
tests/Domain/Admin/DashboardTest.php
Normal file
76
tests/Domain/Admin/DashboardTest.php
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Tests\Domain\Admin;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use DB;
|
||||||
|
use Domain\Files\Models\File;
|
||||||
|
use Domain\Settings\Models\Setting;
|
||||||
|
use Laravel\Sanctum\Sanctum;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
|
class DashboardTest extends TestCase
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_dashboard_data()
|
||||||
|
{
|
||||||
|
$user = User::factory(User::class)
|
||||||
|
->create(['role' => 'admin']);
|
||||||
|
|
||||||
|
File::factory(File::class)
|
||||||
|
->count(2)
|
||||||
|
->create(['filesize' => 1000000]);
|
||||||
|
|
||||||
|
Setting::forceCreate([
|
||||||
|
'name' => 'license',
|
||||||
|
'value' => 'Regular',
|
||||||
|
]);
|
||||||
|
|
||||||
|
DB::table('subscriptions')
|
||||||
|
->insert([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'name' => 'main',
|
||||||
|
'stripe_id' => 'sub_Hp4jgdIpPDDWXw',
|
||||||
|
'stripe_status' => 'active',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this
|
||||||
|
->actingAs($user)
|
||||||
|
->getJson('/api/admin/dashboard')
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertExactJson([
|
||||||
|
'license' => 'Regular',
|
||||||
|
'app_version' => config('vuefilemanager.version'),
|
||||||
|
'total_users' => 1,
|
||||||
|
'total_used_space' => '2.00MB',
|
||||||
|
'total_premium_users' => 1,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_new_users_for_dashboard()
|
||||||
|
{
|
||||||
|
$users = User::factory(User::class)
|
||||||
|
->count(5)
|
||||||
|
->create(['role' => 'user']);
|
||||||
|
|
||||||
|
$admin = User::factory(User::class)
|
||||||
|
->create(['role' => 'admin']);
|
||||||
|
|
||||||
|
Sanctum::actingAs($admin);
|
||||||
|
|
||||||
|
$users->each(function ($user) {
|
||||||
|
$this->getJson('/api/admin/dashboard/newbies')
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertJsonFragment([
|
||||||
|
'id' => $user->id,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,11 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Tests\Domain\Languages;
|
namespace Tests\Domain\Languages;
|
||||||
|
|
||||||
|
use Tests\TestCase;
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Domain\Settings\Models\Setting;
|
use Domain\Settings\Models\Setting;
|
||||||
use Domain\Localization\Models\Language;
|
use Domain\Localization\Models\Language;
|
||||||
use Domain\SetupWizard\Services\SetupService;
|
use Domain\SetupWizard\Services\SetupService;
|
||||||
use Tests\TestCase;
|
|
||||||
|
|
||||||
class AdminLanguageTranslatorTest extends TestCase
|
class AdminLanguageTranslatorTest extends TestCase
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Tests\Domain\Pages;
|
namespace Tests\Domain\Pages;
|
||||||
|
|
||||||
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use Domain\SetupWizard\Services\SetupService;
|
|
||||||
use Laravel\Sanctum\Sanctum;
|
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Laravel\Sanctum\Sanctum;
|
||||||
|
use Domain\SetupWizard\Services\SetupService;
|
||||||
|
|
||||||
class AdminPagesTest extends TestCase
|
class AdminPagesTest extends TestCase
|
||||||
{
|
{
|
||||||
@@ -73,4 +70,4 @@ class AdminPagesTest extends TestCase
|
|||||||
'title' => 'New Title',
|
'title' => 'New Title',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user