mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 16:22:14 +00:00
controller refactoring part 23
This commit is contained in:
@@ -1,20 +1,26 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
// Get avatars and system images
|
// Get avatars and system images
|
||||||
use Domain\Files\Controllers\FileAccessController;
|
use App\Users\Controllers\GetAvatarController;
|
||||||
use Domain\Sharing\Controllers\FileSharedAccessController;
|
use Domain\Files\Controllers\FileAccess\GetFileController;
|
||||||
|
use Domain\Files\Controllers\FileAccess\GetThumbnailController;
|
||||||
|
use Domain\Files\Controllers\FileAccess\VisitorGetFileController;
|
||||||
|
use Domain\Files\Controllers\FileAccess\VisitorGetThumbnailController;
|
||||||
|
use Domain\Settings\Controllers\GetIAppController;
|
||||||
|
use Domain\Zipping\Controllers\GetZipController;
|
||||||
|
use Domain\Zipping\Controllers\VisitorGetZipController;
|
||||||
|
|
||||||
Route::get('/avatars/{avatar}', [FileAccessController::class, 'get_avatar'])->name('avatar');
|
Route::get('/avatars/{avatar}', GetAvatarController::class);
|
||||||
Route::get('/system/{image}', [FileAccessController::class, 'get_system_image']);
|
Route::get('/system/{image}', GetIAppController::class);
|
||||||
|
|
||||||
// Get public thumbnails and files
|
// Get public thumbnails and files
|
||||||
Route::get('/thumbnail/{name}/{shared}', [FileSharedAccessController::class, 'get_thumbnail_public']);
|
Route::get('/thumbnail/{name}/{shared}', VisitorGetThumbnailController::class);
|
||||||
Route::get('/file/{name}/{shared}', [FileSharedAccessController::class, 'get_file_public']);
|
Route::get('/zip/{id}/public/{token}', VisitorGetZipController::class);
|
||||||
Route::get('/zip/{id}/public/{token}', [FileSharedAccessController::class, 'get_zip_public'])->name('zip_public');
|
Route::get('/file/{name}/{shared}', VisitorGetFileController::class);
|
||||||
|
|
||||||
// User master,editor,visitor access to image thumbnails and file downloads
|
// User master,editor,visitor access to image thumbnails and file downloads
|
||||||
Route::group(['middleware' => ['auth:sanctum']], function () {
|
Route::group(['middleware' => ['auth:sanctum']], function () {
|
||||||
Route::get('/thumbnail/{name}', [FileAccessController::class, 'get_thumbnail'])->name('thumbnail');
|
Route::get('/thumbnail/{name}', GetThumbnailController::class)->name('thumbnail');
|
||||||
Route::get('/file/{name}', [FileAccessController::class, 'get_file'])->name('file');
|
Route::get('/file/{name}', GetFileController::class)->name('file');
|
||||||
Route::get('/zip/{id}', [FileAccessController::class, 'get_zip'])->name('zip');
|
Route::get('/zip/{id}', GetZipController::class)->name('zip');
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -2,12 +2,12 @@
|
|||||||
|
|
||||||
use Domain\Sharing\Controllers\ShareController;
|
use Domain\Sharing\Controllers\ShareController;
|
||||||
use Domain\Sharing\Controllers\OGSiteController;
|
use Domain\Sharing\Controllers\OGSiteController;
|
||||||
use Domain\Zipping\Controllers\EditorZipFilesController;
|
use Domain\Zipping\Controllers\VisitorZipFilesController;
|
||||||
use Domain\Zipping\Controllers\EditorZipFolderController;
|
use Domain\Zipping\Controllers\VisitorZipFolderController;
|
||||||
use Domain\Files\Controllers\VisitorUploadFilesController;
|
use Domain\Files\Controllers\VisitorUploadFileController;
|
||||||
use Domain\Folders\Controllers\VisitorCreateFolderController;
|
use Domain\Folders\Controllers\VisitorCreateFolderController;
|
||||||
use Domain\Items\Controllers\VisitorMoveFileOrFolderController;
|
use Domain\Items\Controllers\VisitorMoveFileOrFolderController;
|
||||||
use Domain\Files\Controllers\VisitorGetSingleFileInfoController;
|
use Domain\Files\Controllers\VisitorShowFileController;
|
||||||
use Domain\Items\Controllers\VisitorDeleteFileOrFolderController;
|
use Domain\Items\Controllers\VisitorDeleteFileOrFolderController;
|
||||||
use Domain\Items\Controllers\VisitorRenameFileOrFolderController;
|
use Domain\Items\Controllers\VisitorRenameFileOrFolderController;
|
||||||
use Domain\Browsing\Controllers\VisitorBrowseFolderContentController;
|
use Domain\Browsing\Controllers\VisitorBrowseFolderContentController;
|
||||||
@@ -18,7 +18,7 @@ use Domain\Sharing\Controllers\VisitorAuthenticateProtectedShareController;
|
|||||||
// Browse functions
|
// Browse functions
|
||||||
Route::group(['prefix' => 'editor'], function () {
|
Route::group(['prefix' => 'editor'], function () {
|
||||||
Route::post('/create-folder/{shared}', VisitorCreateFolderController::class);
|
Route::post('/create-folder/{shared}', VisitorCreateFolderController::class);
|
||||||
Route::post('/upload/{shared}', VisitorUploadFilesController::class);
|
Route::post('/upload/{shared}', VisitorUploadFileController::class);
|
||||||
|
|
||||||
Route::patch('/rename/{id}/{shared}', VisitorRenameFileOrFolderController::class);
|
Route::patch('/rename/{id}/{shared}', VisitorRenameFileOrFolderController::class);
|
||||||
Route::post('/remove/{shared}', VisitorDeleteFileOrFolderController::class);
|
Route::post('/remove/{shared}', VisitorDeleteFileOrFolderController::class);
|
||||||
@@ -27,8 +27,8 @@ Route::group(['prefix' => 'editor'], function () {
|
|||||||
|
|
||||||
// Zip shared items
|
// Zip shared items
|
||||||
Route::group(['prefix' => 'zip'], function () {
|
Route::group(['prefix' => 'zip'], function () {
|
||||||
Route::get('/folder/{id}/{shared}', EditorZipFolderController::class);
|
Route::get('/folder/{id}/{shared}', VisitorZipFolderController::class);
|
||||||
Route::post('/files/{shared}', EditorZipFilesController::class);
|
Route::post('/files/{shared}', VisitorZipFilesController::class);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Browse share content
|
// Browse share content
|
||||||
@@ -37,7 +37,7 @@ Route::group(['prefix' => 'browse'], function () {
|
|||||||
Route::get('/folders/{id}/{shared}', VisitorBrowseFolderContentController::class);
|
Route::get('/folders/{id}/{shared}', VisitorBrowseFolderContentController::class);
|
||||||
Route::get('/navigation/{shared}', VisitorNavigationFolderTreeController::class);
|
Route::get('/navigation/{shared}', VisitorNavigationFolderTreeController::class);
|
||||||
Route::get('/search/{shared}', VisitorSearchFilesAndFoldersController::class);
|
Route::get('/search/{shared}', VisitorSearchFilesAndFoldersController::class);
|
||||||
Route::get('/file/{shared}', VisitorGetSingleFileInfoController::class);
|
Route::get('/file/{shared}', VisitorShowFileController::class);
|
||||||
Route::get('/share/{shared}', [ShareController::class, 'show']);
|
Route::get('/share/{shared}', [ShareController::class, 'show']);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
28
src/App/Users/Controllers/GetAvatarController.php
Normal file
28
src/App/Users/Controllers/GetAvatarController.php
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace App\Users\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class GetAvatarController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get user avatar
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
string $basename
|
||||||
|
): StreamedResponse|FileNotFoundException {
|
||||||
|
|
||||||
|
// Check if file exist
|
||||||
|
if (! Storage::exists("/avatars/$basename")) {
|
||||||
|
abort(404);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return avatar
|
||||||
|
return Storage::download("/avatars/$basename", $basename);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Browsing\Controllers;
|
namespace Domain\Browsing\Controllers;
|
||||||
|
|
||||||
|
use Domain\Files\Models\File;
|
||||||
|
use Domain\Folders\Models\Folder;
|
||||||
use Domain\Sharing\Models\Share;
|
use Domain\Sharing\Models\Share;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Support\Services\HelperService;
|
use Support\Services\HelperService;
|
||||||
@@ -12,8 +14,7 @@ class VisitorBrowseFolderContentController
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
) {
|
) {}
|
||||||
}
|
|
||||||
|
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
string $id,
|
string $id,
|
||||||
@@ -26,12 +27,18 @@ class VisitorBrowseFolderContentController
|
|||||||
$this->helper->check_item_access($id, $shared);
|
$this->helper->check_item_access($id, $shared);
|
||||||
|
|
||||||
// Get files and folders
|
// Get files and folders
|
||||||
list($folders, $files) = $this->helper->get_items_under_shared_by_folder_id($id, $shared);
|
$folders = Folder::where('user_id', $shared->user_id)
|
||||||
|
->where('parent_id', $id)
|
||||||
|
->sortable()
|
||||||
|
->get();
|
||||||
|
|
||||||
|
$files = File::where('user_id', $shared->user_id)
|
||||||
|
->where('folder_id', $id)
|
||||||
|
->sortable()
|
||||||
|
->get();
|
||||||
|
|
||||||
// Set thumbnail links for public files
|
// Set thumbnail links for public files
|
||||||
$files->map(function ($file) use ($shared) {
|
$files->map(fn ($file) => $file->setPublicUrl($shared->token));
|
||||||
$file->setPublicUrl($shared->token);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Collect folders and files to single array
|
// Collect folders and files to single array
|
||||||
return collect([$folders, $files])
|
return collect([$folders, $files])
|
||||||
|
|||||||
@@ -0,0 +1,42 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Files\Models\File as UserFile;
|
||||||
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class GetFileController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private RecordDownloadAction $recordDownload,
|
||||||
|
){}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get file
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
Request $request,
|
||||||
|
string $filename,
|
||||||
|
): StreamedResponse {
|
||||||
|
|
||||||
|
// Get file record
|
||||||
|
$file = UserFile::withTrashed()
|
||||||
|
->where('user_id', Auth::id())
|
||||||
|
->where('basename', $filename)
|
||||||
|
->firstOrFail();
|
||||||
|
|
||||||
|
// Store user download size
|
||||||
|
($this->recordDownload)(
|
||||||
|
file_size: (int) $file->getRawOriginal('filesize'),
|
||||||
|
user_id: Auth::id(),
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this->helper->download_file($file, Auth::id());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Files\Models\File as UserFile;
|
||||||
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class GetThumbnailController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get image thumbnail
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
Request $request,
|
||||||
|
string $filename,
|
||||||
|
): FileNotFoundException|StreamedResponse {
|
||||||
|
|
||||||
|
$file = UserFile::withTrashed()
|
||||||
|
->whereUserId(Auth::id())
|
||||||
|
->whereThumbnail($filename)
|
||||||
|
->firstOrFail();
|
||||||
|
|
||||||
|
return $this->helper->download_thumbnail_file($file, Auth::id());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,46 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Files\Models\File as UserFile;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get file public
|
||||||
|
*/
|
||||||
|
class VisitorGetFileController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private RecordDownloadAction $recordDownload
|
||||||
|
){}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
$filename,
|
||||||
|
Share $shared,
|
||||||
|
): StreamedResponse {
|
||||||
|
|
||||||
|
// Check ability to access protected share files
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
// Get file record
|
||||||
|
$file = UserFile::where('user_id', $shared->user_id)
|
||||||
|
->where('basename', $filename)
|
||||||
|
->firstOrFail();
|
||||||
|
|
||||||
|
// Check file access
|
||||||
|
$this->helper->check_guest_access_to_shared_items($shared, $file);
|
||||||
|
|
||||||
|
// Store user download size
|
||||||
|
($this->recordDownload)(
|
||||||
|
file_size: (int) $file->getRawOriginal('filesize'),
|
||||||
|
user_id: $shared->user_id,
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this->helper->download_file($file, $shared->user_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,46 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Files\Models\File as UserFile;
|
||||||
|
use Domain\Sharing\Models\Share;
|
||||||
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get public image thumbnail
|
||||||
|
*/
|
||||||
|
class VisitorGetThumbnailController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private RecordDownloadAction $recordDownload,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
public function __invoke(
|
||||||
|
|
||||||
|
$filename,
|
||||||
|
Share $shared,
|
||||||
|
): StreamedResponse {
|
||||||
|
// Check ability to access protected share files
|
||||||
|
$this->helper->check_protected_share_record($shared);
|
||||||
|
|
||||||
|
// Get file record
|
||||||
|
$file = UserFile::where('user_id', $shared->user_id)
|
||||||
|
->where('thumbnail', $filename)
|
||||||
|
->firstOrFail();
|
||||||
|
|
||||||
|
// Check file access
|
||||||
|
$this->helper->check_guest_access_to_shared_items($shared, $file);
|
||||||
|
|
||||||
|
// Store user download size
|
||||||
|
($this->recordDownload)(
|
||||||
|
file_size: (int) $file->getRawOriginal('filesize'),
|
||||||
|
user_id: $shared->user_id,
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this->helper->download_thumbnail_file($file, $shared->user_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,144 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Domain\Files\Controllers;
|
|
||||||
|
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Domain\Zipping\Models\Zip;
|
|
||||||
use Support\Services\HelperService;
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
|
||||||
use Illuminate\Support\Facades\Storage;
|
|
||||||
use Domain\Files\Models\File as UserFile;
|
|
||||||
use Domain\Traffic\Actions\RecordDownloadAction;
|
|
||||||
|
|
||||||
class FileAccessController extends Controller
|
|
||||||
{
|
|
||||||
public function __construct(
|
|
||||||
public HelperService $helper,
|
|
||||||
public RecordDownloadAction $recordDownload,
|
|
||||||
) {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get avatar
|
|
||||||
*
|
|
||||||
* @param $basename
|
|
||||||
* @return mixed
|
|
||||||
* @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
|
|
||||||
*/
|
|
||||||
public function get_avatar($basename)
|
|
||||||
{
|
|
||||||
// Check if file exist
|
|
||||||
if (! Storage::exists("/avatars/$basename")) {
|
|
||||||
abort(404);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return avatar
|
|
||||||
return Storage::download("/avatars/$basename", $basename);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get system image
|
|
||||||
*
|
|
||||||
* @param $basename
|
|
||||||
* @return mixed
|
|
||||||
* @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
|
|
||||||
*/
|
|
||||||
public function get_system_image($basename)
|
|
||||||
{
|
|
||||||
// Check if file exist
|
|
||||||
if (! Storage::exists("/system/$basename")) {
|
|
||||||
abort(404);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return avatar
|
|
||||||
return Storage::download("/system/$basename", $basename);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get file
|
|
||||||
*
|
|
||||||
* @param Request $request
|
|
||||||
* @param $filename
|
|
||||||
* @return mixed
|
|
||||||
* @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
|
|
||||||
*/
|
|
||||||
public function get_file(Request $request, $filename)
|
|
||||||
{
|
|
||||||
// Get file record
|
|
||||||
$file = UserFile::withTrashed()
|
|
||||||
->where('user_id', Auth::id())
|
|
||||||
->where('basename', $filename)
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
// Check user permission
|
|
||||||
/*if (!$request->user()->tokenCan('master')) {
|
|
||||||
|
|
||||||
// Get shared token
|
|
||||||
$shared = get_shared($request->cookie('shared_token'));
|
|
||||||
|
|
||||||
// Check access to file
|
|
||||||
$this->check_file_access($shared, $file);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
// Store user download size
|
|
||||||
($this->recordDownload)(
|
|
||||||
(int) $file->getRawOriginal('filesize'),
|
|
||||||
Auth::id()
|
|
||||||
);
|
|
||||||
|
|
||||||
return $this->helper->download_file($file, Auth::id());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get generated zip for user
|
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @return \Symfony\Component\HttpFoundation\StreamedResponse
|
|
||||||
*/
|
|
||||||
public function get_zip($id)
|
|
||||||
{
|
|
||||||
$disk = Storage::disk('local');
|
|
||||||
|
|
||||||
$zip = Zip::whereId($id)
|
|
||||||
->where('user_id', Auth::id())
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
// Store user download size
|
|
||||||
($this->recordDownload)(
|
|
||||||
$disk->size("zip/$zip->basename"),
|
|
||||||
$zip->user_id
|
|
||||||
);
|
|
||||||
|
|
||||||
return $disk->download("zip/$zip->basename", $zip->basename, [
|
|
||||||
'Content-Type' => 'application/zip',
|
|
||||||
'Content-Length' => $disk->size("zip/$zip->basename"),
|
|
||||||
'Accept-Ranges' => 'bytes',
|
|
||||||
'Content-Range' => 'bytes 0-600/' . $disk->size("zip/$zip->basename"),
|
|
||||||
'Content-Disposition' => "attachment; filename=$zip->basename",
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get image thumbnail
|
|
||||||
*
|
|
||||||
* @param Request $request
|
|
||||||
* @param $filename
|
|
||||||
* @return mixed
|
|
||||||
* @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
|
|
||||||
*/
|
|
||||||
public function get_thumbnail(Request $request, $filename)
|
|
||||||
{
|
|
||||||
// Get file record
|
|
||||||
$file = UserFile::withTrashed()
|
|
||||||
->whereUserId(Auth::id())
|
|
||||||
->whereThumbnail($filename)
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
// Check user permission
|
|
||||||
/*if (!$request->user()->tokenCan('master')) {
|
|
||||||
$this->check_file_access($request, $file);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
return $this->helper->download_thumbnail_file($file, Auth::id());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -10,7 +10,7 @@ use Domain\Files\Resources\FileResource;
|
|||||||
/**
|
/**
|
||||||
* Get shared file record
|
* Get shared file record
|
||||||
*/
|
*/
|
||||||
class VisitorGetSingleFileInfoController
|
class VisitorShowFileController
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
@@ -12,7 +12,7 @@ use Support\Demo\Actions\FakeUploadFileAction;
|
|||||||
/**
|
/**
|
||||||
* guest user upload file into shared folder
|
* guest user upload file into shared folder
|
||||||
*/
|
*/
|
||||||
class VisitorUploadFilesController extends Controller
|
class VisitorUploadFileController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
28
src/Domain/Settings/Controllers/GetIAppController.php
Normal file
28
src/Domain/Settings/Controllers/GetIAppController.php
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Settings\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class GetIAppController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get system image
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
string $basename
|
||||||
|
): StreamedResponse|FileNotFoundException {
|
||||||
|
|
||||||
|
// Check if file exist
|
||||||
|
if (! Storage::exists("/system/$basename")) {
|
||||||
|
abort(404);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return avatar
|
||||||
|
return Storage::download("/system/$basename", $basename);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,108 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Domain\Sharing\Controllers;
|
|
||||||
|
|
||||||
use Domain\Zipping\Models\Zip;
|
|
||||||
use Domain\Sharing\Models\Share;
|
|
||||||
use Support\Services\HelperService;
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Illuminate\Support\Facades\Storage;
|
|
||||||
use Domain\Files\Models\File as UserFile;
|
|
||||||
use Domain\Traffic\Actions\RecordDownloadAction;
|
|
||||||
|
|
||||||
class FileSharedAccessController extends Controller
|
|
||||||
{
|
|
||||||
public function __construct(
|
|
||||||
private HelperService $helper,
|
|
||||||
public RecordDownloadAction $recordDownload,
|
|
||||||
) {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get generated zip for guest
|
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @param $token
|
|
||||||
* @return \Symfony\Component\HttpFoundation\StreamedResponse
|
|
||||||
*/
|
|
||||||
public function get_zip_public($id, $token)
|
|
||||||
{
|
|
||||||
$disk = Storage::disk('local');
|
|
||||||
|
|
||||||
$zip = Zip::where('id', $id)
|
|
||||||
->where('shared_token', $token)
|
|
||||||
->first();
|
|
||||||
|
|
||||||
// Store user download size
|
|
||||||
($this->recordDownload)(
|
|
||||||
$disk->size("zip/$zip->basename"),
|
|
||||||
$zip->user_id
|
|
||||||
);
|
|
||||||
|
|
||||||
return $disk
|
|
||||||
->download("zip/$zip->basename", $zip->basename, [
|
|
||||||
'Content-Type' => 'application/zip',
|
|
||||||
'Content-Length' => $disk->size("zip/$zip->basename"),
|
|
||||||
'Accept-Ranges' => 'bytes',
|
|
||||||
'Content-Range' => 'bytes 0-600/' . $disk->size("zip/$zip->basename"),
|
|
||||||
'Content-Disposition' => 'attachment; filename=' . $zip->basename,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get file public
|
|
||||||
*
|
|
||||||
* @param $filename
|
|
||||||
* @param Share $shared
|
|
||||||
* @return mixed
|
|
||||||
*/
|
|
||||||
public function get_file_public($filename, Share $shared)
|
|
||||||
{
|
|
||||||
// Check ability to access protected share files
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
// Get file record
|
|
||||||
$file = UserFile::where('user_id', $shared->user_id)
|
|
||||||
->where('basename', $filename)
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
// Check file access
|
|
||||||
$this->helper->check_guest_access_to_shared_items($shared, $file);
|
|
||||||
|
|
||||||
// Store user download size
|
|
||||||
($this->recordDownload)(
|
|
||||||
(int) $file->getRawOriginal('filesize'),
|
|
||||||
$shared->user_id
|
|
||||||
);
|
|
||||||
|
|
||||||
return $this->helper->download_file($file, $shared->user_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get public image thumbnail
|
|
||||||
*
|
|
||||||
* @param $filename
|
|
||||||
* @param Share $shared
|
|
||||||
* @return mixed
|
|
||||||
*/
|
|
||||||
public function get_thumbnail_public($filename, Share $shared)
|
|
||||||
{
|
|
||||||
// Check ability to access protected share files
|
|
||||||
$this->helper->check_protected_share_record($shared);
|
|
||||||
|
|
||||||
// Get file record
|
|
||||||
$file = UserFile::where('user_id', $shared->user_id)
|
|
||||||
->where('thumbnail', $filename)
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
// Check file access
|
|
||||||
$this->helper->check_guest_access_to_shared_items($shared, $file);
|
|
||||||
|
|
||||||
// Store user download size
|
|
||||||
($this->recordDownload)(
|
|
||||||
(int) $file->getRawOriginal('filesize'),
|
|
||||||
$shared->user_id
|
|
||||||
);
|
|
||||||
|
|
||||||
return $this->helper->download_thumbnail_file($file, $shared->user_id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
48
src/Domain/Zipping/Controllers/GetZipController.php
Normal file
48
src/Domain/Zipping/Controllers/GetZipController.php
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Zipping\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
|
use Domain\Zipping\Models\Zip;
|
||||||
|
use Illuminate\Support\Facades\Auth;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class GetZipController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private RecordDownloadAction $recordDownload,
|
||||||
|
){}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get generated zip for user
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
|
||||||
|
string $id,
|
||||||
|
): StreamedResponse
|
||||||
|
{
|
||||||
|
$disk = Storage::disk('local');
|
||||||
|
|
||||||
|
$zip = Zip::whereId($id)
|
||||||
|
->where('user_id', Auth::id())
|
||||||
|
->firstOrFail();
|
||||||
|
|
||||||
|
// Store user download size
|
||||||
|
($this->recordDownload)(
|
||||||
|
file_size: $disk->size("zip/$zip->basename"),
|
||||||
|
user_id: $zip->user_id,
|
||||||
|
);
|
||||||
|
|
||||||
|
return $disk->download("zip/$zip->basename", $zip->basename, [
|
||||||
|
'Content-Type' => 'application/zip',
|
||||||
|
'Content-Length' => $disk->size("zip/$zip->basename"),
|
||||||
|
'Accept-Ranges' => 'bytes',
|
||||||
|
'Content-Range' => 'bytes 0-600/' . $disk->size("zip/$zip->basename"),
|
||||||
|
'Content-Disposition' => "attachment; filename=$zip->basename",
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
47
src/Domain/Zipping/Controllers/VisitorGetZipController.php
Normal file
47
src/Domain/Zipping/Controllers/VisitorGetZipController.php
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
namespace Domain\Zipping\Controllers;
|
||||||
|
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
|
use Domain\Zipping\Models\Zip;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
|
||||||
|
class VisitorGetZipController extends Controller
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private RecordDownloadAction $recordDownload,
|
||||||
|
){}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get generated zip for visitor
|
||||||
|
*/
|
||||||
|
public function __invoke(
|
||||||
|
$id,
|
||||||
|
$token,
|
||||||
|
): StreamedResponse
|
||||||
|
{
|
||||||
|
$disk = Storage::disk('local');
|
||||||
|
|
||||||
|
$zip = Zip::where('id', $id)
|
||||||
|
->where('shared_token', $token)
|
||||||
|
->first();
|
||||||
|
|
||||||
|
// Store user download size
|
||||||
|
($this->recordDownload)(
|
||||||
|
file_size: $disk->size("zip/$zip->basename"),
|
||||||
|
user_id: $zip->user_id,
|
||||||
|
);
|
||||||
|
|
||||||
|
return $disk->download("zip/$zip->basename", $zip->basename, [
|
||||||
|
'Content-Type' => 'application/zip',
|
||||||
|
'Content-Length' => $disk->size("zip/$zip->basename"),
|
||||||
|
'Accept-Ranges' => 'bytes',
|
||||||
|
'Content-Range' => 'bytes 0-600/' . $disk->size("zip/$zip->basename"),
|
||||||
|
'Content-Disposition' => 'attachment; filename=' . $zip->basename,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -12,7 +12,7 @@ use Domain\Zipping\Actions\ZipFilesAction;
|
|||||||
/**
|
/**
|
||||||
* Guest download multiple files via zip
|
* Guest download multiple files via zip
|
||||||
*/
|
*/
|
||||||
class EditorZipFilesController extends Controller
|
class VisitorZipFilesController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
@@ -45,10 +45,7 @@ class EditorZipFilesController extends Controller
|
|||||||
|
|
||||||
// Get file
|
// Get file
|
||||||
return response([
|
return response([
|
||||||
'url' => route('zip_public', [
|
'url' => url("/zip/{$zip->id}/public/{$shared->token}"),
|
||||||
'id' => $zip->id,
|
|
||||||
'token' => $shared->token,
|
|
||||||
]),
|
|
||||||
'name' => $zip->basename,
|
'name' => $zip->basename,
|
||||||
], 201);
|
], 201);
|
||||||
}
|
}
|
||||||
@@ -11,12 +11,11 @@ use Domain\Zipping\Actions\ZipFolderAction;
|
|||||||
/**
|
/**
|
||||||
* Guest download folder via zip
|
* Guest download folder via zip
|
||||||
*/
|
*/
|
||||||
class EditorZipFolderController extends Controller
|
class VisitorZipFolderController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public HelperService $helper,
|
public HelperService $helper,
|
||||||
) {
|
) {}
|
||||||
}
|
|
||||||
|
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
ZipFolderAction $zipFolder,
|
ZipFolderAction $zipFolder,
|
||||||
@@ -41,10 +40,7 @@ class EditorZipFolderController extends Controller
|
|||||||
|
|
||||||
// Get file
|
// Get file
|
||||||
return response([
|
return response([
|
||||||
'url' => route('zip_public', [
|
'url' => url("/zip/{$zip->id}/public/{$shared->token}"),
|
||||||
'id' => $zip->id,
|
|
||||||
'token' => $shared->token,
|
|
||||||
]),
|
|
||||||
'name' => $zip->basename,
|
'name' => $zip->basename,
|
||||||
], 201);
|
], 201);
|
||||||
}
|
}
|
||||||
@@ -115,28 +115,6 @@ class HelperService
|
|||||||
return Storage::download($path, $file->getRawOriginal('thumbnail'));
|
return Storage::download($path, $file->getRawOriginal('thumbnail'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get all folders and files under the share record
|
|
||||||
*
|
|
||||||
* @param $id
|
|
||||||
* @param $shared
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function get_items_under_shared_by_folder_id($id, $shared): array
|
|
||||||
{
|
|
||||||
$folders = Folder::where('user_id', $shared->user_id)
|
|
||||||
->where('parent_id', $id)
|
|
||||||
->sortable()
|
|
||||||
->get();
|
|
||||||
|
|
||||||
$files = File::where('user_id', $shared->user_id)
|
|
||||||
->where('folder_id', $id)
|
|
||||||
->sortable()
|
|
||||||
->get();
|
|
||||||
|
|
||||||
return [$folders, $files];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param Share $shared
|
* @param Share $shared
|
||||||
*/
|
*/
|
||||||
|
|||||||
Reference in New Issue
Block a user