- s3 direct download

This commit is contained in:
Čarodej
2022-03-25 19:14:32 +01:00
parent e232543ea4
commit bbd8e70c9d
5 changed files with 37 additions and 17 deletions

File diff suppressed because one or more lines are too long

2
public/js/main.js vendored

File diff suppressed because one or more lines are too long

View File

@@ -62,7 +62,7 @@
"/chunks/settings-password.js": "/chunks/settings-password.js?id=149343604362b7df", "/chunks/settings-password.js": "/chunks/settings-password.js?id=149343604362b7df",
"/chunks/settings-storage.js": "/chunks/settings-storage.js?id=68765cac4e648e90", "/chunks/settings-storage.js": "/chunks/settings-storage.js?id=68765cac4e648e90",
"/chunks/billing.js": "/chunks/billing.js?id=4f0ea0f3b2553535", "/chunks/billing.js": "/chunks/billing.js?id=4f0ea0f3b2553535",
"/chunks/platform.js": "/chunks/platform.js?id=1012744ef5111b58", "/chunks/platform.js": "/chunks/platform.js?id=90cb99dd8c57c5a0",
"/chunks/files.js": "/chunks/files.js?id=5d6eb9b9f9ecd296", "/chunks/files.js": "/chunks/files.js?id=5d6eb9b9f9ecd296",
"/chunks/recent-uploads.js": "/chunks/recent-uploads.js?id=827d3a5dcce159b5", "/chunks/recent-uploads.js": "/chunks/recent-uploads.js?id=827d3a5dcce159b5",
"/chunks/my-shared-items.js": "/chunks/my-shared-items.js?id=2a4e4e0db02cbcbb", "/chunks/my-shared-items.js": "/chunks/my-shared-items.js?id=2a4e4e0db02cbcbb",

View File

@@ -60,7 +60,7 @@
<!--Update sharing--> <!--Update sharing-->
<div v-if="pickedItem && !activeSection"> <div v-if="pickedItem && !activeSection">
<PopupContent> <PopupContent class="!overflow-initial">
<!--Item Thumbnail--> <!--Item Thumbnail-->
<ThumbnailItem class="mb-5" :item="pickedItem" /> <ThumbnailItem class="mb-5" :item="pickedItem" />

View File

@@ -3,29 +3,28 @@
namespace Domain\Sharing\Controllers; namespace Domain\Sharing\Controllers;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Domain\Files\Actions\DownloadFileAction;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Sharing\Actions\ProtectShareRecordAction; use Domain\Sharing\Actions\ProtectShareRecordAction;
use Domain\Sharing\Actions\VerifyAccessToItemWithinAction; use Domain\Sharing\Actions\VerifyAccessToItemWithinAction;
use Domain\Sharing\Models\Share; use Domain\Sharing\Models\Share;
use Domain\Traffic\Actions\RecordDownloadAction; use Domain\Traffic\Actions\RecordDownloadAction;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Response; use Illuminate\Http\Response;
use Symfony\Component\HttpFoundation\BinaryFileResponse; use Illuminate\Support\Facades\Storage;
use Symfony\Component\HttpFoundation\StreamedResponse;
class DirectlyDownloadFileController extends Controller class DirectlyDownloadFileController extends Controller
{ {
public function __construct( public function __construct(
private DownloadFileAction $downloadFile, private RecordDownloadAction $recordDownload,
private RecordDownloadAction $recordDownload, private ProtectShareRecordAction $protectShareRecord,
private ProtectShareRecordAction $protectShareRecord,
private VerifyAccessToItemWithinAction $verifyAccessToItemWithin, private VerifyAccessToItemWithinAction $verifyAccessToItemWithin,
) { ){}
}
public function __invoke( public function __invoke(
Share $share Share $share
): BinaryFileResponse|Response { ): Response|StreamedResponse|RedirectResponse
{
// Check if item is not a folder // Check if item is not a folder
if ($share->type !== 'file') { if ($share->type !== 'file') {
return response('This content is not downloadable'); return response('This content is not downloadable');
@@ -35,7 +34,7 @@ class DirectlyDownloadFileController extends Controller
($this->protectShareRecord)($share); ($this->protectShareRecord)($share);
// Check if user can download file // Check if user can download file
if (! $share->user->canDownload()) { if (!$share->user->canDownload()) {
return response([ return response([
'type' => 'error', 'type' => 'error',
'message' => 'This user action is not allowed.', 'message' => 'This user action is not allowed.',
@@ -52,11 +51,32 @@ class DirectlyDownloadFileController extends Controller
// Store user download size // Store user download size
($this->recordDownload)( ($this->recordDownload)(
file_size: (int) $file->getRawOriginal('filesize'), file_size: (int)$file->getRawOriginal('filesize'),
user_id: $share->user_id, user_id: $share->user_id,
); );
// Finally, download file // Get file path
return ($this->downloadFile)($file, $share->user_id); $path = "files/$share->user_id/$file->basename";
// Check if file exist
if (!Storage::exists($path)) {
abort(404);
}
// Get pretty name
$pretty_name = get_pretty_name($file->basename, $file->name, $file->mimetype);
// If s3 redirect to temporary url
if (is_storage_driver('s3')) {
return redirect()->away(Storage::temporaryUrl($path, now()->addHour(), [
'ResponseAcceptRanges' => 'bytes',
'ResponseContentType' => Storage::mimeType($path),
'ResponseContentLength' => Storage::size($path),
'ResponseContentRange' => 'bytes 0-600/' . Storage::size($path),
'ResponseContentDisposition' => "attachment; filename=$pretty_name",
]));
}
return Storage::download($path, $pretty_name);
} }
} }