mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 08:12:15 +00:00
controller refactoring part 6
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -1,20 +1,20 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use App\Users\Actions\CreateNewUserAction;
|
use App\Users\Actions\CreateNewUserAction;
|
||||||
use Domain\Files\Controllers\UploadFilesController;
|
|
||||||
use Domain\Pages\Controllers\PagesController;
|
use Domain\Pages\Controllers\PagesController;
|
||||||
use Domain\Sharing\Controllers\ShareController;
|
|
||||||
use Domain\Items\Controllers\EditItemsController;
|
use Domain\Items\Controllers\EditItemsController;
|
||||||
|
use Domain\Sharing\Controllers\ShareController;
|
||||||
|
use Domain\Sharing\Controllers\ShareViaEmailController;
|
||||||
use Domain\Trash\Controllers\DumpTrashController;
|
use Domain\Trash\Controllers\DumpTrashController;
|
||||||
use App\Users\Controllers\ResetPasswordController;
|
use App\Users\Controllers\ResetPasswordController;
|
||||||
use Domain\Zipping\Controllers\ZipFilesController;
|
use Domain\Zipping\Controllers\ZipFilesController;
|
||||||
use App\Users\Controllers\ForgotPasswordController;
|
use App\Users\Controllers\ForgotPasswordController;
|
||||||
|
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\SettingsController;
|
use Domain\Settings\Controllers\SettingsController;
|
||||||
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\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,23 +1,28 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Domain\Sharing\Controllers\ShareController;
|
use Domain\Files\Controllers\EditorUploadFilesController;
|
||||||
use Domain\Sharing\Controllers\BrowseShareController;
|
|
||||||
use Domain\Homepage\Controllers\AppFunctionsController;
|
use Domain\Homepage\Controllers\AppFunctionsController;
|
||||||
|
use Domain\Folders\Controllers\EditorCreateFolderController;
|
||||||
|
use Domain\Sharing\Controllers\BrowseShareController;
|
||||||
use Domain\Sharing\Controllers\ManipulateShareItemsController;
|
use Domain\Sharing\Controllers\ManipulateShareItemsController;
|
||||||
|
use Domain\Sharing\Controllers\ShareController;
|
||||||
|
use Domain\Zipping\Controllers\EditorZipFilesController;
|
||||||
|
use Domain\Zipping\Controllers\EditorZipFolderController;
|
||||||
|
|
||||||
// Browse functions
|
// Browse functions
|
||||||
Route::group(['prefix' => 'editor'], function () {
|
Route::group(['prefix' => 'editor'], function () {
|
||||||
Route::post('/create-folder/{shared}', [ManipulateShareItemsController::class, 'create_folder']);
|
Route::post('/create-folder/{shared}', EditorCreateFolderController::class);
|
||||||
|
Route::post('/upload/{shared}', EditorUploadFilesController::class);
|
||||||
|
|
||||||
Route::patch('/rename/{id}/{shared}', [ManipulateShareItemsController::class, 'rename_item']);
|
Route::patch('/rename/{id}/{shared}', [ManipulateShareItemsController::class, 'rename_item']);
|
||||||
Route::post('/remove/{shared}', [ManipulateShareItemsController::class, 'delete_item']);
|
Route::post('/remove/{shared}', [ManipulateShareItemsController::class, 'delete_item']);
|
||||||
Route::post('/upload/{shared}', [ManipulateShareItemsController::class, 'upload']);
|
|
||||||
Route::post('/move/{shared}', [ManipulateShareItemsController::class, 'move']);
|
Route::post('/move/{shared}', [ManipulateShareItemsController::class, 'move']);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Zip shared items
|
// Zip shared items
|
||||||
Route::group(['prefix' => 'zip'], function () {
|
Route::group(['prefix' => 'zip'], function () {
|
||||||
Route::post('/files/{shared}', [ManipulateShareItemsController::class, 'zip_multiple_files']);
|
Route::post('/files/{shared}', EditorZipFilesController::class);
|
||||||
Route::get('/folder/{id}/{shared}', [ManipulateShareItemsController::class, 'zip_folder']);
|
Route::get('/folder/{id}/{shared}', EditorZipFolderController::class);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Browse share content
|
// Browse share content
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
use Domain\Admin\Controllers\InvoiceController;
|
use Domain\Admin\Controllers\InvoiceController;
|
||||||
use Domain\Homepage\Controllers\IndexController;
|
use Domain\Homepage\Controllers\IndexController;
|
||||||
use Domain\Sharing\Controllers\BrowseShareController;
|
use Domain\Folders\Controllers\BrowseShareController;
|
||||||
use Domain\Homepage\Controllers\AppFunctionsController;
|
use Domain\Homepage\Controllers\AppFunctionsController;
|
||||||
use Domain\SetupWizard\Controllers\SetupWizardController;
|
use Domain\SetupWizard\Controllers\SetupWizardController;
|
||||||
use Domain\Subscriptions\Controllers\StripeWebhookController;
|
use Domain\Subscriptions\Controllers\StripeWebhookController;
|
||||||
|
|||||||
@@ -1,23 +1,21 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Files\Actions;
|
namespace Domain\Files\Actions;
|
||||||
|
|
||||||
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Domain\Files\Models\File as UserFile;
|
|
||||||
use Domain\Files\Requests\UploadRequest;
|
|
||||||
use Domain\Sharing\Models\Share;
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Support\Services\HelperService;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Illuminate\Support\Facades\File;
|
use Illuminate\Support\Facades\File;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Support\Services\HelperService;
|
use Domain\Files\Requests\UploadRequest;
|
||||||
|
use Domain\Files\Models\File as UserFile;
|
||||||
|
|
||||||
class UploadFilesAction
|
class UploadFilesAction
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Upload new file
|
* Upload new file
|
||||||
@@ -97,4 +95,4 @@ class UploadFilesAction
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
51
src/Domain/Files/Controllers/EditorUploadFilesController.php
Normal file
51
src/Domain/Files/Controllers/EditorUploadFilesController.php
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Files\Controllers;
|
||||||
|
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Support\Services\HelperService;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Support\Demo\Actions\DemoService;
|
||||||
|
use Domain\Files\Requests\UploadRequest;
|
||||||
|
use Domain\Files\Actions\UploadFilesAction;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* guest user upload file into shared folder
|
||||||
|
*/
|
||||||
|
class EditorUploadFilesController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
public HelperService $helper,
|
||||||
|
public DemoService $demo,
|
||||||
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
UploadFilesAction $uploadFile,
|
||||||
|
UploadRequest $request,
|
||||||
|
Share $shared,
|
||||||
|
): Response | array {
|
||||||
|
if (is_demo_account($shared->user->email)) {
|
||||||
|
return $this->demo->upload($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check ability to access protected share record
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
// Check shared permission
|
||||||
|
if (is_visitor($shared)) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check access to requested directory
|
||||||
|
$this->helper->check_item_access($request->folder_id, $shared);
|
||||||
|
|
||||||
|
// Return new uploaded file
|
||||||
|
$new_file = ($uploadFile)($request, $shared);
|
||||||
|
|
||||||
|
// Set public access url
|
||||||
|
$new_file->setPublicUrl($shared->token);
|
||||||
|
|
||||||
|
return response($new_file, 201);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,13 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
namespace Domain\Files\Controllers;
|
namespace Domain\Files\Controllers;
|
||||||
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Domain\Files\Actions\UploadFilesAction;
|
|
||||||
use Domain\Files\Models\File;
|
use Domain\Files\Models\File;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Files\Requests\UploadRequest;
|
use Domain\Files\Requests\UploadRequest;
|
||||||
|
use Domain\Files\Actions\UploadFilesAction;
|
||||||
|
|
||||||
class UploadFilesController extends Controller
|
class UploadFilesController extends Controller
|
||||||
{
|
{
|
||||||
@@ -24,4 +21,4 @@ class UploadFilesController extends Controller
|
|||||||
|
|
||||||
return ($uploadFiles)($request);
|
return ($uploadFiles)($request);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,7 +11,8 @@ class CreateFolderController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public DemoService $demo
|
public DemoService $demo
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create new folder for authenticated master|editor user
|
* Create new folder for authenticated master|editor user
|
||||||
|
|||||||
@@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
namespace Domain\Folders\Controllers;
|
||||||
|
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Support\Services\HelperService;
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Support\Demo\Actions\DemoService;
|
||||||
|
use Domain\Folders\Actions\CreateFolderAction;
|
||||||
|
use Domain\Folders\Requests\CreateFolderRequest;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create new folder for guest user with edit permission
|
||||||
|
*/
|
||||||
|
class EditorCreateFolderController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
public HelperService $helper,
|
||||||
|
public DemoService $demo,
|
||||||
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
CreateFolderAction $createFolder,
|
||||||
|
CreateFolderRequest $request,
|
||||||
|
Share $shared,
|
||||||
|
): Response | array {
|
||||||
|
if (is_demo_account($shared->user->email)) {
|
||||||
|
return $this->demo->create_folder($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check ability to access protected share record
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
// Check shared permission
|
||||||
|
if (is_visitor($shared)) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check access to requested directory
|
||||||
|
$this->helper->check_item_access($request->parent_id, $shared);
|
||||||
|
|
||||||
|
// Create folder
|
||||||
|
$folder = ($createFolder)($request, $shared);
|
||||||
|
|
||||||
|
return response($folder, 201);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -3,12 +3,9 @@ namespace Domain\Items\Controllers;
|
|||||||
|
|
||||||
use Exception;
|
use Exception;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Domain\Files\Models\File;
|
|
||||||
use Support\Services\HelperService;
|
use Support\Services\HelperService;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Support\Demo\Actions\DemoService;
|
use Support\Demo\Actions\DemoService;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
use Domain\Files\Requests\UploadRequest;
|
|
||||||
use Support\Services\FileManagerService;
|
use Support\Services\FileManagerService;
|
||||||
use Domain\Items\Requests\MoveItemRequest;
|
use Domain\Items\Requests\MoveItemRequest;
|
||||||
use Domain\Items\Requests\DeleteItemRequest;
|
use Domain\Items\Requests\DeleteItemRequest;
|
||||||
|
|||||||
@@ -9,15 +9,12 @@ use Domain\Folders\Models\Folder;
|
|||||||
use Support\Services\HelperService;
|
use Support\Services\HelperService;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Support\Demo\Actions\DemoService;
|
use Support\Demo\Actions\DemoService;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
use Domain\Files\Requests\UploadRequest;
|
|
||||||
use Support\Services\FileManagerService;
|
use Support\Services\FileManagerService;
|
||||||
use Domain\Items\Requests\MoveItemRequest;
|
use Domain\Items\Requests\MoveItemRequest;
|
||||||
use Domain\Zipping\Actions\ZipFilesAction;
|
use Domain\Zipping\Actions\ZipFilesAction;
|
||||||
use Domain\Zipping\Actions\ZipFolderAction;
|
use Domain\Zipping\Actions\ZipFolderAction;
|
||||||
use Domain\Items\Requests\DeleteItemRequest;
|
use Domain\Items\Requests\DeleteItemRequest;
|
||||||
use Domain\Items\Requests\RenameItemRequest;
|
use Domain\Items\Requests\RenameItemRequest;
|
||||||
use Domain\Folders\Requests\CreateFolderRequest;
|
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
||||||
|
|
||||||
class ManipulateShareItemsController extends Controller
|
class ManipulateShareItemsController extends Controller
|
||||||
@@ -29,37 +26,6 @@ class ManipulateShareItemsController extends Controller
|
|||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Create new folder for guest user with edit permission
|
|
||||||
*
|
|
||||||
* @param CreateFolderRequest $request
|
|
||||||
* @param Share $shared
|
|
||||||
* @return array|\Illuminate\Contracts\Foundation\Application|ResponseFactory|\Illuminate\Http\Response
|
|
||||||
* @throws \Exception
|
|
||||||
*/
|
|
||||||
public function create_folder(CreateFolderRequest $request, Share $shared)
|
|
||||||
{
|
|
||||||
if (is_demo_account($shared->user->email)) {
|
|
||||||
return $this->demo->create_folder($request);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check ability to access protected share record
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
// Check shared permission
|
|
||||||
if (is_visitor($shared)) {
|
|
||||||
abort(403);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check access to requested directory
|
|
||||||
$this->helper->check_item_access($request->parent_id, $shared);
|
|
||||||
|
|
||||||
// Create folder
|
|
||||||
$folder = $this->filemanager->create_folder($request, $shared);
|
|
||||||
|
|
||||||
return response($folder, 201);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Rename item for guest user with edit permission
|
* Rename item for guest user with edit permission
|
||||||
*
|
*
|
||||||
@@ -147,40 +113,6 @@ class ManipulateShareItemsController extends Controller
|
|||||||
return response('Done', 204);
|
return response('Done', 204);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Delete file for guest user with edit permission
|
|
||||||
*
|
|
||||||
* @param UploadRequest $request
|
|
||||||
* @param Share $shared
|
|
||||||
* @return File|\Illuminate\Contracts\Foundation\Application|ResponseFactory|Model|\Illuminate\Http\Response
|
|
||||||
* @throws \Exception
|
|
||||||
*/
|
|
||||||
public function upload(UploadRequest $request, Share $shared)
|
|
||||||
{
|
|
||||||
if (is_demo_account($shared->user->email)) {
|
|
||||||
return $this->demo->upload($request);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check ability to access protected share record
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
// Check shared permission
|
|
||||||
if (is_visitor($shared)) {
|
|
||||||
abort(403);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check access to requested directory
|
|
||||||
$this->helper->check_item_access($request->folder_id, $shared);
|
|
||||||
|
|
||||||
// Return new uploaded file
|
|
||||||
$new_file = $this->filemanager->upload($request, $shared);
|
|
||||||
|
|
||||||
// Set public access url
|
|
||||||
$new_file->setPublicUrl($shared->token);
|
|
||||||
|
|
||||||
return response($new_file, 201);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Move item for guest user with edit permission
|
* Move item for guest user with edit permission
|
||||||
*
|
*
|
||||||
@@ -222,75 +154,4 @@ class ManipulateShareItemsController extends Controller
|
|||||||
|
|
||||||
return response('Done!', 204);
|
return response('Done!', 204);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Guest download folder via zip
|
|
||||||
*/
|
|
||||||
public function zip_folder(
|
|
||||||
string $id,
|
|
||||||
Share $shared,
|
|
||||||
ZipFolderAction $zipFolder,
|
|
||||||
): Response {
|
|
||||||
// Check ability to access protected share record
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
// Check access to requested folder
|
|
||||||
$this->helper->check_item_access($id, $shared);
|
|
||||||
|
|
||||||
// Get folder
|
|
||||||
$folder = Folder::whereUserId($shared->user_id)
|
|
||||||
->where('id', $id);
|
|
||||||
|
|
||||||
if (! $folder->exists()) {
|
|
||||||
abort(404, 'Requested folder doesn\'t exists.');
|
|
||||||
}
|
|
||||||
|
|
||||||
$zip = ($zipFolder)($id, $shared);
|
|
||||||
|
|
||||||
// Get file
|
|
||||||
return response([
|
|
||||||
'url' => route('zip_public', [
|
|
||||||
'id' => $zip->id,
|
|
||||||
'token' => $shared->token,
|
|
||||||
]),
|
|
||||||
'name' => $zip->basename,
|
|
||||||
], 201);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Guest download multiple files via zip
|
|
||||||
*/
|
|
||||||
public function zip_multiple_files(
|
|
||||||
Request $request,
|
|
||||||
Share $shared,
|
|
||||||
ZipFilesAction $zipFiles,
|
|
||||||
): Response {
|
|
||||||
// Check ability to access protected share record
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
$file_parent_folders = File::whereUserId($shared->user_id)
|
|
||||||
->whereIn('id', $request->items)
|
|
||||||
->get()
|
|
||||||
->pluck('folder_id')
|
|
||||||
->toArray();
|
|
||||||
|
|
||||||
// Check access to requested directory
|
|
||||||
$this->helper->check_item_access($file_parent_folders, $shared);
|
|
||||||
|
|
||||||
// Get requested files
|
|
||||||
$files = File::whereUserId($shared->user_id)
|
|
||||||
->whereIn('id', $request->items)
|
|
||||||
->get();
|
|
||||||
|
|
||||||
$zip = ($zipFiles)($files, $shared);
|
|
||||||
|
|
||||||
// Get file
|
|
||||||
return response([
|
|
||||||
'url' => route('zip_public', [
|
|
||||||
'id' => $zip->id,
|
|
||||||
'token' => $shared->token,
|
|
||||||
]),
|
|
||||||
'name' => $zip->basename,
|
|
||||||
], 201);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
57
src/Domain/Zipping/Controllers/EditorZipFilesController.php
Normal file
57
src/Domain/Zipping/Controllers/EditorZipFilesController.php
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Zipping\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Files\Models\File;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Domain\Zipping\Actions\ZipFilesAction;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Support\Services\HelperService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Guest download multiple files via zip
|
||||||
|
*/
|
||||||
|
class EditorZipFilesController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
public HelperService $helper,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
ZipFilesAction $zipFiles,
|
||||||
|
Request $request,
|
||||||
|
Share $shared,
|
||||||
|
): Response {
|
||||||
|
// Check ability to access protected share record
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
$file_parent_folders = File::whereUserId($shared->user_id)
|
||||||
|
->whereIn('id', $request->items)
|
||||||
|
->get()
|
||||||
|
->pluck('folder_id')
|
||||||
|
->toArray();
|
||||||
|
|
||||||
|
// Check access to requested directory
|
||||||
|
$this->helper->check_item_access($file_parent_folders, $shared);
|
||||||
|
|
||||||
|
// Get requested files
|
||||||
|
$files = File::whereUserId($shared->user_id)
|
||||||
|
->whereIn('id', $request->items)
|
||||||
|
->get();
|
||||||
|
|
||||||
|
$zip = ($zipFiles)($files, $shared);
|
||||||
|
|
||||||
|
// Get file
|
||||||
|
return response([
|
||||||
|
'url' => route('zip_public', [
|
||||||
|
'id' => $zip->id,
|
||||||
|
'token' => $shared->token,
|
||||||
|
]),
|
||||||
|
'name' => $zip->basename,
|
||||||
|
], 201);
|
||||||
|
}
|
||||||
|
}
|
||||||
53
src/Domain/Zipping/Controllers/EditorZipFolderController.php
Normal file
53
src/Domain/Zipping/Controllers/EditorZipFolderController.php
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Zipping\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Folders\Models\Folder;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Domain\Zipping\Actions\ZipFolderAction;
|
||||||
|
use Illuminate\Http\Response;
|
||||||
|
use Support\Services\HelperService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Guest download folder via zip
|
||||||
|
*/
|
||||||
|
class EditorZipFolderController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
public HelperService $helper,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
ZipFolderAction $zipFolder,
|
||||||
|
string $id,
|
||||||
|
Share $shared,
|
||||||
|
): Response {
|
||||||
|
// Check ability to access protected share record
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
// Check access to requested folder
|
||||||
|
$this->helper->check_item_access($id, $shared);
|
||||||
|
|
||||||
|
// Get folder
|
||||||
|
$folder = Folder::whereUserId($shared->user_id)
|
||||||
|
->where('id', $id);
|
||||||
|
|
||||||
|
if (! $folder->exists()) {
|
||||||
|
abort(404, 'Requested folder doesn\'t exists.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$zip = ($zipFolder)($id, $shared);
|
||||||
|
|
||||||
|
// Get file
|
||||||
|
return response([
|
||||||
|
'url' => route('zip_public', [
|
||||||
|
'id' => $zip->id,
|
||||||
|
'token' => $shared->token,
|
||||||
|
]),
|
||||||
|
'name' => $zip->basename,
|
||||||
|
], 201);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user