create folder in upload request

This commit is contained in:
Čarodej
2022-02-23 08:26:16 +01:00
parent 0501e3e3d5
commit fdfb5f57d7
8 changed files with 113 additions and 25 deletions

View File

@@ -27,25 +27,25 @@
<hard-drive-icon <hard-drive-icon
v-if="['public', 'files'].includes(nodes.location)" v-if="['public', 'files'].includes(nodes.location)"
size="17" size="17"
class="icon vue-feather" class="icon vue-feather shrink-0"
:class="{ 'text-theme dark-text-theme': isSelectedItem }" :class="{ 'text-theme dark-text-theme': isSelectedItem }"
/> />
<users-icon <users-icon
v-if="nodes.location === 'team-folders'" v-if="nodes.location === 'team-folders'"
size="17" size="17"
class="icon vue-feather" class="icon vue-feather shrink-0"
:class="{ 'text-theme dark-text-theme': isSelectedItem }" :class="{ 'text-theme dark-text-theme': isSelectedItem }"
/> />
<user-plus-icon <user-plus-icon
v-if="nodes.location === 'shared-with-me'" v-if="nodes.location === 'shared-with-me'"
size="17" size="17"
class="icon vue-feather" class="icon vue-feather shrink-0"
:class="{ 'text-theme dark-text-theme': isSelectedItem }" :class="{ 'text-theme dark-text-theme': isSelectedItem }"
/> />
<folder-icon <folder-icon
v-if="!nodes.location" v-if="!nodes.location"
size="17" size="17"
class="icon vue-feather" class="icon vue-feather shrink-0"
:class="{ 'text-theme dark-text-theme': isSelectedItem }" :class="{ 'text-theme dark-text-theme': isSelectedItem }"
/> />

View File

@@ -22,7 +22,7 @@
}" }"
/> />
</div> </div>
<folder-icon size="17" class="vue-feather mr-2.5" :class="{ 'text-theme': isSelected }" /> <folder-icon size="17" class="vue-feather mr-2.5 shrink-0" :class="{ 'text-theme': isSelected }" />
<b <b
class="max-w-1 overflow-hidden text-ellipsis whitespace-nowrap text-xs font-bold" class="max-w-1 overflow-hidden text-ellipsis whitespace-nowrap text-xs font-bold"
:class="{ 'text-theme': isSelected }" :class="{ 'text-theme': isSelected }"

View File

@@ -84,17 +84,16 @@ const actions = {
}, },
createFolder: ({ commit, getters, dispatch }, folder) => { createFolder: ({ commit, getters, dispatch }, folder) => {
// Get route // Get route
let route = getters.sharedDetail let route = {
? `/api/editor/create-folder/${router.currentRoute.params.token}` RequestUpload: `/api/upload-request/${router.currentRoute.params.token}/create-folder`,
: '/api/create-folder' Public: `/api/editor/create-folder/${router.currentRoute.params.token}`,
}[router.currentRoute.name] || '/api/create-folder'
let parent_id = getters.currentFolder ? getters.currentFolder.data.id : undefined
axios axios
.post(route, { .post(route, {
parent_id: parent_id,
name: folder.name, name: folder.name,
emoji: folder.emoji, emoji: folder.emoji,
parent_id: getters.currentFolder?.data.id,
}) })
.then((response) => { .then((response) => {
commit('ADD_NEW_FOLDER', response.data) commit('ADD_NEW_FOLDER', response.data)
@@ -120,7 +119,7 @@ const actions = {
}, },
renameItem: ({ commit, getters, dispatch }, data) => { renameItem: ({ commit, getters, dispatch }, data) => {
// Updated name in favourites panel // Updated name in favourites panel
if (getters.permission === 'master' && data.type === 'folder') if (data.type === 'folder' && getters.user)
commit('UPDATE_NAME_IN_FAVOURITES', data) commit('UPDATE_NAME_IN_FAVOURITES', data)
// Get route // Get route

View File

@@ -1,5 +1,6 @@
<?php <?php
use Domain\UploadRequest\Controllers\CreateFolderController;
use Tests\Domain\UploadRequest\RenameFileOrFolderController; use Tests\Domain\UploadRequest\RenameFileOrFolderController;
use Domain\UploadRequest\Controllers\GetUploadRequestController; use Domain\UploadRequest\Controllers\GetUploadRequestController;
use Domain\UploadRequest\Controllers\CreateUploadRequestController; use Domain\UploadRequest\Controllers\CreateUploadRequestController;
@@ -12,6 +13,7 @@ Route::post('/{uploadRequest}/upload', UploadFilesForUploadRequestController::cl
// Edit // Edit
Route::patch('/{uploadRequest}/rename/{id}', RenameFileOrFolderController::class); Route::patch('/{uploadRequest}/rename/{id}', RenameFileOrFolderController::class);
Route::post('/{uploadRequest}/create-folder', CreateFolderController::class);
Route::group(['middleware' => ['auth:sanctum']], function () { Route::group(['middleware' => ['auth:sanctum']], function () {
Route::post('/', CreateUploadRequestController::class); Route::post('/', CreateUploadRequestController::class);

View File

@@ -0,0 +1,46 @@
<?php
namespace Domain\UploadRequest\Controllers;
use Domain\Folders\Actions\CreateFolderAction;
use Domain\Folders\Models\Folder;
use Domain\Folders\Requests\CreateFolderRequest;
use Domain\Folders\Resources\FolderResource;
use Domain\UploadRequest\Models\UploadRequest;
use Support\Demo\Actions\FakeCreateFolderAction;
class CreateFolderController
{
public function __construct(
public CreateFolderAction $createFolder,
public FakeCreateFolderAction $fakeCreateFolder,
) {
}
public function __invoke(CreateFolderRequest $request, UploadRequest $uploadRequest)
{
// Check if upload request is active
if ($uploadRequest->status !== 'active') {
return response('Gone', 410);
}
// Check privileges
if (! in_array($request->input('parent_id'), getChildrenFolderIds($uploadRequest->id))) {
return response('Access Denied', 403);
}
// Create new folder
$folder = Folder::create([
'parent_id' => $request->input('parent_id'),
'name' => $request->input('name'),
'color' => $request->input('color') ?? null,
'emoji' => $request->input('emoji') ?? null,
'author' => 'visitor',
'user_id' => $uploadRequest->user_id,
'team_folder' => false,
]);
// Return new folder
return response(new FolderResource($folder), 201);
}
}

View File

@@ -3,6 +3,7 @@
use Carbon\Carbon; use Carbon\Carbon;
use ByteUnits\Metric; use ByteUnits\Metric;
use App\Users\Models\User; use App\Users\Models\User;
use Illuminate\Support\Arr;
use Illuminate\Support\Str; use Illuminate\Support\Str;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Sharing\Models\Share; use Domain\Sharing\Models\Share;
@@ -27,6 +28,22 @@ if (! function_exists('isRunningCron')) {
} }
} }
if (! function_exists('getInnerFolderIds')) {
/**
* Get all folder children ids
*/
function getChildrenFolderIds(string $id): array
{
// Get folders within upload request
$folderWithinIds = Folder::with('folders:id,parent_id')
->where('parent_id', $id)
->get(['id']);
// Then get all accessible folders within
return Arr::flatten([filter_folders_ids($folderWithinIds), $id]);
}
}
if (! function_exists('obfuscate_email')) { if (! function_exists('obfuscate_email')) {
/** /**
* Obfuscate email * Obfuscate email

View File

@@ -1,8 +1,6 @@
<?php <?php
namespace Tests\Domain\UploadRequest; namespace Tests\Domain\UploadRequest;
use Illuminate\Support\Arr;
use Domain\Folders\Models\Folder;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Domain\Files\Resources\FileResource; use Domain\Files\Resources\FileResource;
use Domain\Folders\Resources\FolderResource; use Domain\Folders\Resources\FolderResource;
@@ -29,16 +27,8 @@ class RenameFileOrFolderController extends Controller
// Get item // Get item
$item = get_item($request->input('type'), $id); $item = get_item($request->input('type'), $id);
// Get folders within upload request
$folderWithinIds = Folder::with('folders:id,parent_id')
->where('parent_id', $uploadRequest->id)
->get(['id']);
// Then get all accessible folders within
$accessibleParentIds = Arr::flatten([filter_folders_ids($folderWithinIds), $uploadRequest->id]);
// Check privileges // Check privileges
if (! in_array($item->parent_id, $accessibleParentIds)) { if (! in_array($item->parent_id, getChildrenFolderIds($uploadRequest->id))) {
return response('Access Denied', 403); return response('Access Denied', 403);
} }

View File

@@ -1,4 +1,5 @@
<?php <?php
namespace Tests\Domain\UploadRequest; namespace Tests\Domain\UploadRequest;
use Tests\TestCase; use Tests\TestCase;
@@ -32,7 +33,7 @@ class UploadRequestEditingTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson("/api/upload-request/$uploadRequest->id/rename/$folder->id", [ ->patchJson("/api/upload-request/$uploadRequest->id/rename/$folder->id", [
'name' => 'Renamed Folder', 'name' => 'Renamed Folder',
'type' => 'folder', 'type' => 'folder',
]) ])
@@ -45,6 +46,7 @@ class UploadRequestEditingTest extends TestCase
'name' => 'Renamed Folder', 'name' => 'Renamed Folder',
]); ]);
} }
/** /**
* @test * @test
*/ */
@@ -68,7 +70,7 @@ class UploadRequestEditingTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson("/api/upload-request/$uploadRequest->id/rename/$file->id", [ ->patchJson("/api/upload-request/$uploadRequest->id/rename/$file->id", [
'name' => 'Renamed File', 'name' => 'Renamed File',
'type' => 'file', 'type' => 'file',
]) ])
@@ -81,4 +83,36 @@ class UploadRequestEditingTest extends TestCase
'name' => 'Renamed File', 'name' => 'Renamed File',
]); ]);
} }
/**
* @test
*/
public function it_create_new_folder_in_upload_request()
{
$user = User::factory()
->hasSettings()
->create();
$uploadRequest = UploadRequest::factory()
->create([
'status' => 'active',
'user_id' => $user->id,
]);
$this
->actingAs($user)
->postJson("/api/upload-request/$uploadRequest->id/create-folder", [
'name' => 'New Folder',
'parent_id' => $uploadRequest->id,
])
->assertStatus(201)
->assertJsonFragment([
'name' => 'New Folder',
]);
$this->assertDatabaseHas('folders', [
'name' => 'New Folder',
'parent_id' => $uploadRequest->id,
]);
}
} }