mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 08:12:15 +00:00
controller refactoring part 16
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -81,8 +81,8 @@
|
|||||||
"/chunks/upgrade-billing.js": "/chunks/upgrade-billing.js?id=10416cb784a62f3c8fd7",
|
"/chunks/upgrade-billing.js": "/chunks/upgrade-billing.js?id=10416cb784a62f3c8fd7",
|
||||||
"/chunks/upgrade-billing~chunks/upgrade-plan.js": "/chunks/upgrade-billing~chunks/upgrade-plan.js?id=43888143d0a6afe67d7a",
|
"/chunks/upgrade-billing~chunks/upgrade-plan.js": "/chunks/upgrade-billing~chunks/upgrade-plan.js?id=43888143d0a6afe67d7a",
|
||||||
"/chunks/upgrade-plan.js": "/chunks/upgrade-plan.js?id=5979a154f760a992e617",
|
"/chunks/upgrade-plan.js": "/chunks/upgrade-plan.js?id=5979a154f760a992e617",
|
||||||
"/chunks/user.js": "/chunks/user.js?id=41076be9126702330159",
|
"/chunks/user.js": "/chunks/user.js?id=6ba666410f40ecdc965d",
|
||||||
"/chunks/user-create.js": "/chunks/user-create.js?id=0d0040fbb5361bb061d6",
|
"/chunks/user-create.js": "/chunks/user-create.js?id=355fa2701524f0feccf0",
|
||||||
"/chunks/user-delete.js": "/chunks/user-delete.js?id=ecebc7e50b64744420c3",
|
"/chunks/user-delete.js": "/chunks/user-delete.js?id=ecebc7e50b64744420c3",
|
||||||
"/chunks/user-detail.js": "/chunks/user-detail.js?id=7ae038f6b4a4683c5bdb",
|
"/chunks/user-detail.js": "/chunks/user-detail.js?id=7ae038f6b4a4683c5bdb",
|
||||||
"/chunks/user-invoices.js": "/chunks/user-invoices.js?id=1395c30e08946026fbc4",
|
"/chunks/user-invoices.js": "/chunks/user-invoices.js?id=1395c30e08946026fbc4",
|
||||||
@@ -286,5 +286,7 @@
|
|||||||
"/chunks/upgrade-billing.3c553438a1090569af54.hot-update.js": "/chunks/upgrade-billing.3c553438a1090569af54.hot-update.js",
|
"/chunks/upgrade-billing.3c553438a1090569af54.hot-update.js": "/chunks/upgrade-billing.3c553438a1090569af54.hot-update.js",
|
||||||
"/chunks/settings-invoices.4ab4d27b8447516929d2.hot-update.js": "/chunks/settings-invoices.4ab4d27b8447516929d2.hot-update.js",
|
"/chunks/settings-invoices.4ab4d27b8447516929d2.hot-update.js": "/chunks/settings-invoices.4ab4d27b8447516929d2.hot-update.js",
|
||||||
"/chunks/profile.5902d31a95da744acd2b.hot-update.js": "/chunks/profile.5902d31a95da744acd2b.hot-update.js",
|
"/chunks/profile.5902d31a95da744acd2b.hot-update.js": "/chunks/profile.5902d31a95da744acd2b.hot-update.js",
|
||||||
"/chunks/settings~chunks/settings-password.5902d31a95da744acd2b.hot-update.js": "/chunks/settings~chunks/settings-password.5902d31a95da744acd2b.hot-update.js"
|
"/chunks/settings~chunks/settings-password.5902d31a95da744acd2b.hot-update.js": "/chunks/settings~chunks/settings-password.5902d31a95da744acd2b.hot-update.js",
|
||||||
|
"/chunks/user-create.ca38aa5d23cce5399b5d.hot-update.js": "/chunks/user-create.ca38aa5d23cce5399b5d.hot-update.js",
|
||||||
|
"/chunks/user.8e87c89c5f6cc9b7d635.hot-update.js": "/chunks/user.8e87c89c5f6cc9b7d635.hot-update.js"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -131,7 +131,7 @@
|
|||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
fetchUser() {
|
fetchUser() {
|
||||||
axios.get('/api/admin/users/' + this.$route.params.id + '/detail')
|
axios.get('/api/admin/users/' + this.$route.params.id)
|
||||||
.then(response => {
|
.then(response => {
|
||||||
this.user = response.data
|
this.user = response.data
|
||||||
this.isLoading = false
|
this.isLoading = false
|
||||||
|
|||||||
@@ -162,7 +162,7 @@
|
|||||||
|
|
||||||
// Send request to get user token
|
// Send request to get user token
|
||||||
axios
|
axios
|
||||||
.post('/api/admin/users/create', formData, {
|
.post('/api/admin/users', formData, {
|
||||||
headers: {
|
headers: {
|
||||||
'Content-Type': 'multipart/form-data',
|
'Content-Type': 'multipart/form-data',
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,25 +1,26 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Domain\Admin\Controllers\Dashboard\GetNewbiesController;
|
|
||||||
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\Users\UserController;
|
||||||
use Domain\Pages\Controllers\AdminPagesController;
|
use Domain\Pages\Controllers\AdminPagesController;
|
||||||
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\Settings\Controllers\FlushCacheController;
|
||||||
|
use Domain\Invoices\Controllers\AdminInvoiceController;
|
||||||
use Domain\Localization\Controllers\LanguageController;
|
use Domain\Localization\Controllers\LanguageController;
|
||||||
|
use Domain\Plans\Controllers\PlanSubscribersController;
|
||||||
|
use Domain\Admin\Controllers\Users\DeleteUserController;
|
||||||
use Domain\Settings\Controllers\GetSettingsValueController;
|
use Domain\Settings\Controllers\GetSettingsValueController;
|
||||||
|
use Domain\Admin\Controllers\Dashboard\GetNewbiesController;
|
||||||
|
use Domain\Admin\Controllers\Users\ChangeUserRoleController;
|
||||||
use Domain\Settings\Controllers\UpdateSettingValueController;
|
use Domain\Settings\Controllers\UpdateSettingValueController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserInvoicesController;
|
||||||
|
use Domain\Admin\Controllers\Users\ResetUserPasswordController;
|
||||||
|
use Domain\Admin\Controllers\Dashboard\GetWidgetsValuesController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserSubscriptionController;
|
||||||
use Domain\Localization\Controllers\UpdateLanguageStringController;
|
use Domain\Localization\Controllers\UpdateLanguageStringController;
|
||||||
|
use Domain\Admin\Controllers\Users\ShowUserStorageCapacityController;
|
||||||
|
use Domain\Admin\Controllers\Users\ChangeUserStorageCapacityController;
|
||||||
|
|
||||||
// Dashboard
|
// Dashboard
|
||||||
Route::group(['prefix' => 'dashboard'], function () {
|
Route::group(['prefix' => 'dashboard'], function () {
|
||||||
@@ -38,26 +39,19 @@ Route::group(['prefix' => 'users'], function () {
|
|||||||
// Subscription
|
// Subscription
|
||||||
Route::get('/{user}/subscription', ShowUserSubscriptionController::class);
|
Route::get('/{user}/subscription', ShowUserSubscriptionController::class);
|
||||||
Route::get('/{user}/invoices', ShowUserInvoicesController::class);
|
Route::get('/{user}/invoices', ShowUserInvoicesController::class);
|
||||||
|
|
||||||
// Resource
|
|
||||||
Route::apiResource('/', UserController::class);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Route::apiResource('/users', UserController::class);
|
||||||
|
|
||||||
// Plans
|
// Plans
|
||||||
Route::group(['prefix' => 'plans'], function () {
|
Route::get('/plans/{id}/subscribers', PlanSubscribersController::class);
|
||||||
Route::get('/{id}/subscribers', [PlansController::class, 'subscribers']);
|
Route::apiResource('/', PlansController::class);
|
||||||
Route::delete('/{id}', [PlansController::class, 'delete']);
|
|
||||||
Route::patch('/{id}', [PlansController::class, 'update']);
|
|
||||||
Route::get('/{id}', [PlansController::class, 'show']);
|
|
||||||
Route::post('/', [PlansController::class, 'store']);
|
|
||||||
Route::get('/', [PlansController::class, 'index']);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Pages
|
// Pages
|
||||||
Route::apiResource('/pages', AdminPagesController::class);
|
Route::apiResource('/pages', AdminPagesController::class);
|
||||||
|
|
||||||
// Invoices
|
// Invoices
|
||||||
Route::get('/invoices', [InvoiceController::class, 'index']);
|
Route::get('/invoices', [AdminInvoiceController::class, 'index']);
|
||||||
|
|
||||||
// Settings
|
// Settings
|
||||||
Route::group(['prefix' => 'settings'], function () {
|
Route::group(['prefix' => 'settings'], function () {
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
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\AccountDetailsController;
|
||||||
use App\Users\Controllers\Account\UpdatePasswordController;
|
use App\Users\Controllers\Account\UpdatePasswordController;
|
||||||
use App\Users\Controllers\Account\StorageCapacityController;
|
use App\Users\Controllers\Account\StorageCapacityController;
|
||||||
use App\Users\Controllers\Verification\VerifyEmailController;
|
use App\Users\Controllers\Verification\VerifyEmailController;
|
||||||
|
use Domain\Invoices\Controllers\UserProfileInvoiceController;
|
||||||
use Domain\Subscriptions\Controllers\GetSetupIntentController;
|
use Domain\Subscriptions\Controllers\GetSetupIntentController;
|
||||||
use App\Users\Controllers\Verification\ResendVerificationEmail;
|
use App\Users\Controllers\Verification\ResendVerificationEmail;
|
||||||
use App\Users\Controllers\Authentication\CheckAccountController;
|
use App\Users\Controllers\Authentication\CheckAccountController;
|
||||||
@@ -40,7 +40,7 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
|
|||||||
Route::get('/setup-intent', GetSetupIntentController::class);
|
Route::get('/setup-intent', GetSetupIntentController::class);
|
||||||
|
|
||||||
Route::apiResource('/payment-cards', PaymentMethodsController::class);
|
Route::apiResource('/payment-cards', PaymentMethodsController::class);
|
||||||
Route::get('/invoices', UserInvoicesController::class);
|
Route::get('/invoices', UserProfileInvoiceController::class);
|
||||||
Route::get('/', SubscriptionDetailsController::class);
|
Route::get('/', SubscriptionDetailsController::class);
|
||||||
|
|
||||||
Route::post('/upgrade', SubscriptionUpgradeController::class);
|
Route::post('/upgrade', SubscriptionUpgradeController::class);
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Domain\Admin\Controllers\InvoiceController;
|
|
||||||
use Domain\Homepage\Controllers\IndexController;
|
use Domain\Homepage\Controllers\IndexController;
|
||||||
use Domain\Sharing\Controllers\OGSiteController;
|
use Domain\Sharing\Controllers\OGSiteController;
|
||||||
|
use Domain\Admin\Controllers\AdminInvoiceController;
|
||||||
use Domain\Sharing\Controllers\SharePublicIndexController;
|
use Domain\Sharing\Controllers\SharePublicIndexController;
|
||||||
use Domain\Subscriptions\Controllers\StripeWebhookController;
|
use Domain\Subscriptions\Controllers\StripeWebhookController;
|
||||||
use Domain\SetupWizard\Controllers\CreateAdminAccountController;
|
use Domain\SetupWizard\Controllers\CreateAdminAccountController;
|
||||||
@@ -13,7 +13,7 @@ Route::post('/admin-setup', CreateAdminAccountController::class);
|
|||||||
|
|
||||||
// Subscription Services
|
// Subscription Services
|
||||||
Route::post('/stripe/webhook', [StripeWebhookController::class, 'handleWebhook']);
|
Route::post('/stripe/webhook', [StripeWebhookController::class, 'handleWebhook']);
|
||||||
Route::get('/invoice/{customer}/{token}', [InvoiceController::class, 'show'])->middleware(['auth:sanctum']);
|
Route::get('/invoice/{customer}/{token}', [AdminInvoiceController::class, 'show'])->middleware(['auth:sanctum']);
|
||||||
|
|
||||||
// Translations
|
// Translations
|
||||||
Route::get('/translations/{lang}', CurrentLocalizationController::class);
|
Route::get('/translations/{lang}', CurrentLocalizationController::class);
|
||||||
|
|||||||
@@ -1,11 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Admin\Actions;
|
namespace Domain\Admin\Actions;
|
||||||
|
|
||||||
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use DB;
|
use DB;
|
||||||
|
use App\Users\Models\User;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
|
||||||
class DeleteUserDataAction
|
class DeleteUserDataAction
|
||||||
@@ -31,4 +28,4 @@ class DeleteUserDataAction
|
|||||||
->delete();
|
->delete();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Admin\Controllers\Dashboard;
|
namespace Domain\Admin\Controllers\Dashboard;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UsersCollection;
|
use App\Users\Resources\UsersCollection;
|
||||||
|
|
||||||
class GetNewbiesController extends Controller
|
class GetNewbiesController extends Controller
|
||||||
@@ -13,10 +10,10 @@ class GetNewbiesController extends Controller
|
|||||||
public function __invoke(): UsersCollection
|
public function __invoke(): UsersCollection
|
||||||
{
|
{
|
||||||
$users = User::sortable([
|
$users = User::sortable([
|
||||||
'created_at' => 'desc'
|
'created_at' => 'desc',
|
||||||
])
|
])
|
||||||
->paginate(10);
|
->paginate(10);
|
||||||
|
|
||||||
return new UsersCollection($users);
|
return new UsersCollection($users);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Admin\Controllers\Dashboard;
|
namespace Domain\Admin\Controllers\Dashboard;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use ByteUnits\Metric;
|
use ByteUnits\Metric;
|
||||||
|
use App\Users\Models\User;
|
||||||
use Laravel\Cashier\Subscription;
|
use Laravel\Cashier\Subscription;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
|
||||||
class GetWidgetsValuesController extends Controller
|
class GetWidgetsValuesController extends Controller
|
||||||
{
|
{
|
||||||
@@ -30,4 +27,4 @@ class GetWidgetsValuesController extends Controller
|
|||||||
'total_premium_users' => $premium_users,
|
'total_premium_users' => $premium_users,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserResource;
|
use App\Users\Resources\UserResource;
|
||||||
use Domain\Admin\Requests\ChangeRoleRequest;
|
use Domain\Admin\Requests\ChangeRoleRequest;
|
||||||
|
|
||||||
@@ -17,9 +17,8 @@ class ChangeUserRoleController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update user role
|
// Update user role
|
||||||
$user->update([
|
$user->role = $request->input('attributes.role');
|
||||||
'role' => $request->input('attributes.role'),
|
$user->update();
|
||||||
]);
|
|
||||||
|
|
||||||
return new UserResource($user);
|
return new UserResource($user);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserStorageResource;
|
use App\Users\Resources\UserStorageResource;
|
||||||
use Domain\Admin\Requests\ChangeStorageCapacityRequest;
|
use Domain\Admin\Requests\ChangeStorageCapacityRequest;
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Domain\Admin\Actions\DeleteUserDataAction;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Domain\Admin\Requests\DeleteUserRequest;
|
use Domain\Admin\Requests\DeleteUserRequest;
|
||||||
|
use Domain\Admin\Actions\DeleteUserDataAction;
|
||||||
|
|
||||||
class DeleteUserController extends Controller
|
class DeleteUserController extends Controller
|
||||||
{
|
{
|
||||||
@@ -18,7 +18,6 @@ class DeleteUserController extends Controller
|
|||||||
User $user,
|
User $user,
|
||||||
DeleteUserDataAction $deleteUserData,
|
DeleteUserDataAction $deleteUserData,
|
||||||
): Response {
|
): Response {
|
||||||
|
|
||||||
if (is_demo()) {
|
if (is_demo()) {
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Password;
|
use Illuminate\Support\Facades\Password;
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
||||||
|
|
||||||
class ResetUserPasswordController extends Controller
|
class ResetUserPasswordController extends Controller
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Invoices\Resources\InvoiceCollection;
|
use Domain\Invoices\Resources\InvoiceCollection;
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
|
|
||||||
@@ -11,7 +10,8 @@ class ShowUserInvoicesController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private StripeService $stripe
|
private StripeService $stripe
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get user storage details
|
* Get user storage details
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserStorageResource;
|
use App\Users\Resources\UserStorageResource;
|
||||||
|
|
||||||
class ShowUserStorageCapacityController extends Controller
|
class ShowUserStorageCapacityController extends Controller
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserSubscription;
|
use App\Users\Resources\UserSubscription;
|
||||||
|
|
||||||
class ShowUserSubscriptionController extends Controller
|
class ShowUserSubscriptionController extends Controller
|
||||||
@@ -11,7 +11,7 @@ class ShowUserSubscriptionController extends Controller
|
|||||||
/**
|
/**
|
||||||
* Get user subscription details
|
* Get user subscription details
|
||||||
*/
|
*/
|
||||||
public function __invoke(User $user): UserSubscription|Response
|
public function __invoke(User $user): UserSubscription | Response
|
||||||
{
|
{
|
||||||
if (! $user->stripeId() || ! $user->subscription('main')) {
|
if (! $user->stripeId() || ! $user->subscription('main')) {
|
||||||
return response("User doesn't have any subscription.", 404);
|
return response("User doesn't have any subscription.", 404);
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Admin\Controllers;
|
namespace Domain\Invoices\Controllers;
|
||||||
|
|
||||||
|
use Illuminate\View\View;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Invoices\Resources\InvoiceResource;
|
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
use Domain\Admin\Resources\InvoiceAdminCollection;
|
use Domain\Admin\Resources\InvoiceAdminCollection;
|
||||||
|
|
||||||
class InvoiceController extends Controller
|
class AdminInvoiceController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private StripeService $stripe
|
private StripeService $stripe
|
||||||
@@ -15,10 +15,8 @@ class InvoiceController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all invoices
|
* Get all invoices
|
||||||
*
|
|
||||||
* @return InvoiceAdminCollection
|
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index(): InvoiceAdminCollection
|
||||||
{
|
{
|
||||||
return new InvoiceAdminCollection(
|
return new InvoiceAdminCollection(
|
||||||
$this->stripe->getInvoices()['data']
|
$this->stripe->getInvoices()['data']
|
||||||
@@ -27,12 +25,8 @@ class InvoiceController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Get single invoice by invoice $token
|
* Get single invoice by invoice $token
|
||||||
*
|
|
||||||
* @param $customer
|
|
||||||
* @param $token
|
|
||||||
* @return InvoiceResource|\Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View
|
|
||||||
*/
|
*/
|
||||||
public function show($customer, $token)
|
public function show(string $customer, string $token): View
|
||||||
{
|
{
|
||||||
return view('vuefilemanager.invoice')
|
return view('vuefilemanager.invoice')
|
||||||
->with('settings', get_settings_in_json())
|
->with('settings', get_settings_in_json())
|
||||||
@@ -5,7 +5,7 @@ use App\Http\Controllers\Controller;
|
|||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Domain\Invoices\Resources\InvoiceCollection;
|
use Domain\Invoices\Resources\InvoiceCollection;
|
||||||
|
|
||||||
class UserInvoicesController extends Controller
|
class UserProfileInvoiceController extends Controller
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Get user invoices
|
* Get user invoices
|
||||||
24
src/Domain/Plans/Controllers/PlanSubscribersController.php
Normal file
24
src/Domain/Plans/Controllers/PlanSubscribersController.php
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Plans\Controllers;
|
||||||
|
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Laravel\Cashier\Subscription;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Users\Resources\UsersCollection;
|
||||||
|
|
||||||
|
class PlanSubscribersController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get plan subscriptions
|
||||||
|
*/
|
||||||
|
public function __invoke(string $id): UsersCollection
|
||||||
|
{
|
||||||
|
$subscribers = Subscription::whereStripePlan($id)
|
||||||
|
->pluck('user_id');
|
||||||
|
|
||||||
|
$users = User::sortable()
|
||||||
|
->findMany($subscribers);
|
||||||
|
|
||||||
|
return new UsersCollection($users);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,18 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Plans\Controllers;
|
namespace Domain\Plans\Controllers;
|
||||||
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
use Laravel\Cashier\Subscription;
|
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Cache;
|
|
||||||
use App\Users\Resources\UsersCollection;
|
|
||||||
use Domain\Plans\Resources\PlanResource;
|
use Domain\Plans\Resources\PlanResource;
|
||||||
use Domain\Plans\Resources\PlanCollection;
|
use Domain\Plans\Resources\PlanCollection;
|
||||||
use Domain\Subscriptions\Services\StripeService;
|
use Domain\Subscriptions\Services\StripeService;
|
||||||
use Illuminate\Contracts\Foundation\Application;
|
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
|
||||||
|
|
||||||
class PlansController extends Controller
|
class PlansController extends Controller
|
||||||
{
|
{
|
||||||
@@ -23,60 +17,43 @@ class PlansController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all plans
|
* Get all plans
|
||||||
*
|
|
||||||
* @return PlanCollection|Application|ResponseFactory|Response
|
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index(): Response
|
||||||
{
|
{
|
||||||
// Store or Get plans to cache
|
// Store or Get plans to cache
|
||||||
if (Cache::has('plans')) {
|
$plans = cache()
|
||||||
$plans = Cache::get('plans');
|
->rememberForever('plans', function () {
|
||||||
} else {
|
|
||||||
$plans = Cache::rememberForever('plans', function () {
|
|
||||||
return $this->stripe->getPlans();
|
return $this->stripe->getPlans();
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
return response(new PlanCollection($plans), 200);
|
return response(new PlanCollection($plans), 200);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get plan record
|
* Get plan record
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @return PlanResource|Application|ResponseFactory|Response
|
|
||||||
*/
|
*/
|
||||||
public function show($id)
|
public function show(string $id): Response
|
||||||
{
|
{
|
||||||
// Store or Get plan to cache
|
// Store or Get plan to cache
|
||||||
if (Cache::has('plan-' . $id)) {
|
$plan = cache()
|
||||||
$plan = Cache::get('plan-' . $id);
|
->rememberForever("plan-$id", function () use ($id) {
|
||||||
} else {
|
|
||||||
$plan = Cache::rememberForever('plan-' . $id, function () use ($id) {
|
|
||||||
return $this->stripe->getPlan($id);
|
return $this->stripe->getPlan($id);
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
return response(new PlanResource($plan), 200);
|
return response(new PlanResource($plan), 200);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create new plan
|
* Create new plan
|
||||||
*
|
* TODO: store request
|
||||||
* @param Request $request
|
|
||||||
* @return PlanResource|Application|ResponseFactory|Response
|
|
||||||
*/
|
*/
|
||||||
public function store(Request $request)
|
public function store(Request $request): Response | PlanResource
|
||||||
{
|
{
|
||||||
// TODO: inline request
|
|
||||||
if (is_demo()) {
|
if (is_demo()) {
|
||||||
if (Cache::has('plan-starter-pack')) {
|
$plan = cache()
|
||||||
$plan = Cache::get('plan-starter-pack');
|
->rememberForever('plan-starter-pack', function () {
|
||||||
} else {
|
|
||||||
$plan = Cache::rememberForever('plan-starter-pack', function () {
|
|
||||||
return $this->stripe->getPlan('starter-pack');
|
return $this->stripe->getPlan('starter-pack');
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
return new PlanResource($plan);
|
return new PlanResource($plan);
|
||||||
}
|
}
|
||||||
@@ -93,12 +70,8 @@ class PlansController extends Controller
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Update plan attribute
|
* Update plan attribute
|
||||||
*
|
|
||||||
* @param Request $request
|
|
||||||
* @param $id
|
|
||||||
* @return ResponseFactory|Response
|
|
||||||
*/
|
*/
|
||||||
public function update(Request $request, $id)
|
public function update(Request $request, string $id): Response
|
||||||
{
|
{
|
||||||
// Abort in demo mode
|
// Abort in demo mode
|
||||||
abort_if(is_demo(), 204, 'Done.');
|
abort_if(is_demo(), 204, 'Done.');
|
||||||
@@ -107,18 +80,15 @@ class PlansController extends Controller
|
|||||||
$this->stripe->updatePlan($request, $id);
|
$this->stripe->updatePlan($request, $id);
|
||||||
|
|
||||||
// Clear cached plans
|
// Clear cached plans
|
||||||
cache_forget_many(['plans', 'pricing', 'plan-' . $id]);
|
cache_forget_many(['plans', 'pricing', "plan-$id"]);
|
||||||
|
|
||||||
return response('Saved!', 201);
|
return response('Saved!', 201);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Delete plan
|
* Delete plan
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @return ResponseFactory|Response
|
|
||||||
*/
|
*/
|
||||||
public function delete($id)
|
public function delete($id): Response
|
||||||
{
|
{
|
||||||
// Abort in demo mode
|
// Abort in demo mode
|
||||||
abort_if(is_demo(), 204, 'Done.');
|
abort_if(is_demo(), 204, 'Done.');
|
||||||
@@ -131,21 +101,4 @@ class PlansController extends Controller
|
|||||||
|
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get subscriptions
|
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @return mixed
|
|
||||||
*/
|
|
||||||
public function subscribers($id)
|
|
||||||
{
|
|
||||||
$subscribers = Subscription::whereStripePlan($id)
|
|
||||||
->pluck('user_id');
|
|
||||||
|
|
||||||
return new UsersCollection(
|
|
||||||
User::sortable()
|
|
||||||
->findMany($subscribers)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Support\Services;
|
namespace Support\Services;
|
||||||
|
|
||||||
use DB;
|
|
||||||
use Illuminate\Support\Arr;
|
use Illuminate\Support\Arr;
|
||||||
use Aws\S3\MultipartUploader;
|
use Aws\S3\MultipartUploader;
|
||||||
use Domain\Files\Models\File;
|
use Domain\Files\Models\File;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
<?php
|
`<?php
|
||||||
|
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use ByteUnits\Metric;
|
use ByteUnits\Metric;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Tests\Domain\Admin;
|
namespace Tests\Domain\Admin;
|
||||||
|
|
||||||
use DB;
|
|
||||||
use Storage;
|
use Storage;
|
||||||
use Notification;
|
use Notification;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
@@ -12,7 +11,6 @@ use Domain\Zipping\Models\Zip;
|
|||||||
use Domain\Sharing\Models\Share;
|
use Domain\Sharing\Models\Share;
|
||||||
use Domain\Folders\Models\Folder;
|
use Domain\Folders\Models\Folder;
|
||||||
use Illuminate\Http\UploadedFile;
|
use Illuminate\Http\UploadedFile;
|
||||||
use Domain\Settings\Models\Setting;
|
|
||||||
use App\Users\Notifications\ResetPassword;
|
use App\Users\Notifications\ResetPassword;
|
||||||
use Domain\SetupWizard\Services\SetupService;
|
use Domain\SetupWizard\Services\SetupService;
|
||||||
|
|
||||||
@@ -61,7 +59,7 @@ class AdminTest extends TestCase
|
|||||||
// TODO: pridat exactjson po refaktorovani userresource
|
// TODO: pridat exactjson po refaktorovani userresource
|
||||||
$this
|
$this
|
||||||
->actingAs($admin)
|
->actingAs($admin)
|
||||||
->getJson("/api/admin/users/$user->id/detail")
|
->getJson("/api/admin/users/$user->id")
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJsonFragment([
|
->assertJsonFragment([
|
||||||
'id' => $user->id,
|
'id' => $user->id,
|
||||||
@@ -225,7 +223,7 @@ class AdminTest extends TestCase
|
|||||||
|
|
||||||
$this
|
$this
|
||||||
->actingAs($admin)
|
->actingAs($admin)
|
||||||
->postJson('/api/admin/users/create', [
|
->postJson('/api/admin/users', [
|
||||||
'name' => 'John Doe',
|
'name' => 'John Doe',
|
||||||
'role' => 'user',
|
'role' => 'user',
|
||||||
'email' => 'john@doe.com',
|
'email' => 'john@doe.com',
|
||||||
|
|||||||
@@ -1,15 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Tests\Domain\Admin;
|
namespace Tests\Domain\Admin;
|
||||||
|
|
||||||
|
|
||||||
use App\Users\Models\User;
|
|
||||||
use DB;
|
use DB;
|
||||||
|
use Tests\TestCase;
|
||||||
|
use App\Users\Models\User;
|
||||||
|
use Laravel\Sanctum\Sanctum;
|
||||||
use Domain\Files\Models\File;
|
use Domain\Files\Models\File;
|
||||||
use Domain\Settings\Models\Setting;
|
use Domain\Settings\Models\Setting;
|
||||||
use Laravel\Sanctum\Sanctum;
|
|
||||||
use Tests\TestCase;
|
|
||||||
|
|
||||||
class DashboardTest extends TestCase
|
class DashboardTest extends TestCase
|
||||||
{
|
{
|
||||||
@@ -73,4 +70,4 @@ class DashboardTest extends TestCase
|
|||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user