api refactoring

This commit is contained in:
Čarodej
2022-05-31 15:12:31 +02:00
parent a4b18c26b5
commit 7659cc7221
9 changed files with 38 additions and 18 deletions

View File

@@ -213,6 +213,7 @@ export default {
isExpiration: false, isExpiration: false,
isEmailSharing: false, isEmailSharing: false,
shareOptions: { shareOptions: {
id: undefined,
isPassword: undefined, isPassword: undefined,
expiration: undefined, expiration: undefined,
password: undefined, password: undefined,
@@ -244,7 +245,7 @@ export default {
// Send request to get share link // Send request to get share link
axios axios
.post(`/api/share/${this.id}`, this.shareOptions) .post('/api/share', this.shareOptions)
.then((response) => { .then((response) => {
// End loading // End loading
this.isGeneratedShared = true this.isGeneratedShared = true
@@ -278,18 +279,18 @@ export default {
this.pickedItem = args.item this.pickedItem = args.item
this.shareOptions.type = args.item.data.type this.shareOptions.type = args.item.data.type
this.id = args.item.data.id this.shareOptions.id = args.item.data.id
}) })
// Close popup // Close popup
events.$on('popup:close', () => { events.$on('popup:close', () => {
// Restore data // Restore data
setTimeout(() => { setTimeout(() => {
this.id = undefined
this.isGeneratedShared = false this.isGeneratedShared = false
this.isExpiration = false this.isExpiration = false
this.isEmailSharing = false this.isEmailSharing = false
this.shareOptions = { this.shareOptions = {
id: undefined,
isPassword: false, isPassword: false,
expiration: undefined, expiration: undefined,
password: undefined, password: undefined,

View File

@@ -83,7 +83,7 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
Route::get('/share/{token}/qr', GetShareLinkViaQrCodeController::class); Route::get('/share/{token}/qr', GetShareLinkViaQrCodeController::class);
Route::post('/share/{token}/email', ShareViaEmailController::class); Route::post('/share/{token}/email', ShareViaEmailController::class);
Route::apiResource('/share', ShareController::class); Route::apiResource('/share', ShareController::class);
Route::post('/share/{id}', ShareItemController::class); Route::post('/share', ShareItemController::class);
// Notifications // Notifications
Route::post('/notifications/read', MarkUserNotificationsAsReadController::class); Route::post('/notifications/read', MarkUserNotificationsAsReadController::class);

View File

@@ -13,7 +13,9 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
Route::get('/shared-with-me/{id}', BrowseSharedWithMeController::class); Route::get('/shared-with-me/{id}', BrowseSharedWithMeController::class);
Route::apiResource('/folders', TeamFoldersController::class); Route::apiResource('/folders', TeamFoldersController::class);
Route::post('/folders/{folder}/convert', ConvertFolderIntoTeamFolderController::class); Route::group(['prefix' => '/folders'], function() {
Route::delete('/folders/{folder}/leave', LeaveTeamFolderController::class); Route::post('/{folder}/convert', ConvertFolderIntoTeamFolderController::class);
Route::get('/folders/{folder}/tree', NavigationTreeController::class); Route::delete('/{folder}/leave', LeaveTeamFolderController::class);
Route::get('/{folder}/tree', NavigationTreeController::class);
});
}); });

View File

@@ -23,7 +23,7 @@ class UpdateAvatarRequest extends FormRequest
public function rules() public function rules()
{ {
return [ return [
'avatar' => 'required|file', 'avatar' => 'required|file|mimes:jpg,jpeg,png',
]; ];
} }
} }

View File

@@ -38,7 +38,10 @@ class SpotlightSearchController
): JsonResponse { ): JsonResponse {
// Prevent to show non admin user searching // Prevent to show non admin user searching
if (Auth::user()->role !== 'admin') { if (Auth::user()->role !== 'admin') {
abort(response()->json(accessDeniedError()), 403); abort(response()->json([
'type' => 'error',
'message' => 'Access denied. You need administrator privileges to search the users.',
]), 403);
} }
// Get user ids // Get user ids

View File

@@ -10,6 +10,7 @@ use Domain\Folders\Resources\FolderResource;
use Domain\Folders\Resources\FolderCollection; use Domain\Folders\Resources\FolderCollection;
use Domain\Sharing\Actions\ProtectShareRecordAction; use Domain\Sharing\Actions\ProtectShareRecordAction;
use Domain\Sharing\Actions\VerifyAccessToItemAction; use Domain\Sharing\Actions\VerifyAccessToItemAction;
use Str;
/** /**
* Browse shared folder * Browse shared folder
@@ -26,14 +27,19 @@ class VisitorBrowseFolderController
string $id, string $id,
Share $shared, Share $shared,
): JsonResponse { ): JsonResponse {
$folderId = Str::isUuid($id)
? $id
: $shared->item_id;
// Check ability to access protected share record // Check ability to access protected share record
($this->protectShareRecord)($shared); ($this->protectShareRecord)($shared);
// Check if user can get directory // Check if user can get directory
($this->verifyAccessToItem)($id, $shared); ($this->verifyAccessToItem)($folderId, $shared);
// Get requested folder // Get requested folder
$requestedFolder = Folder::findOrFail($id); $requestedFolder = Folder::findOrFail($folderId);
$page = request()->has('page') $page = request()->has('page')
? request()->input('page') ? request()->input('page')
@@ -43,13 +49,13 @@ class VisitorBrowseFolderController
$query = [ $query = [
'folder' => [ 'folder' => [
'where' => [ 'where' => [
'parent_id' => $id, 'parent_id' => $folderId,
'user_id' => $shared->user_id, 'user_id' => $shared->user_id,
], ],
], ],
'file' => [ 'file' => [
'where' => [ 'where' => [
'parent_id' => $id, 'parent_id' => $folderId,
'user_id' => $shared->user_id, 'user_id' => $shared->user_id,
], ],
], ],

View File

@@ -21,9 +21,8 @@ class ShareItemController extends Controller
*/ */
public function __invoke( public function __invoke(
CreateShareRequest $request, CreateShareRequest $request,
string $id,
): JsonResponse { ): JsonResponse {
$item = get_item($request->input('type'), $id); $item = get_item($request->input('type'), $request->input('id'));
// Check if item is currently shared // Check if item is currently shared
if ($item->shared()->exists()) { if ($item->shared()->exists()) {

View File

@@ -24,6 +24,7 @@ class CreateShareRequest extends FormRequest
public function rules() public function rules()
{ {
return [ return [
'id' => 'required|uuid',
'isPassword' => 'sometimes|boolean', 'isPassword' => 'sometimes|boolean',
'password' => 'required_if:isPassword,true', 'password' => 'required_if:isPassword,true',
'type' => 'required|string', 'type' => 'required|string',

View File

@@ -1,6 +1,7 @@
<?php <?php
namespace Domain\Teams\Controllers; namespace Domain\Teams\Controllers;
use Gate;
use Illuminate\Support\Str; use Illuminate\Support\Str;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
@@ -41,9 +42,16 @@ class TeamFoldersController extends Controller
$entriesPerPage = config('vuefilemanager.paginate.perPage'); $entriesPerPage = config('vuefilemanager.paginate.perPage');
// TODO: check privileges
if ($id) { if ($id) {
// Get team folder
$teamFolder = Folder::findOrFail($id)
->getLatestParent();
// Check privileges
if (! Gate::any(['can-edit', 'can-view'], [$teamFolder, null])) {
return response()->json(accessDeniedError(), 403);
}
$query = [ $query = [
'folder' => [ 'folder' => [
'where' => [ 'where' => [
@@ -111,7 +119,7 @@ class TeamFoldersController extends Controller
'meta' => [ 'meta' => [
'paginate' => $paginate, 'paginate' => $paginate,
'teamFolder' => $id 'teamFolder' => $id
? new FolderResource(Folder::findOrFail($id)->getLatestParent()) ? new FolderResource($teamFolder)
: null, : null,
'root' => $id 'root' => $id
? new FolderResource(Folder::findOrFail($id)) ? new FolderResource(Folder::findOrFail($id))