added it_get_navigator_tree and it_get_folder_content

This commit is contained in:
Peter Papp
2021-02-28 18:21:23 +01:00
parent 486d8de378
commit 674290edfc
9 changed files with 194 additions and 67 deletions
@@ -2,16 +2,16 @@
namespace App\Http\Controllers; namespace App\Http\Controllers;
use App\Content; use App\Models\Content;
use App\File; use App\Models\File;
use App\Folder; use App\Models\Folder;
use App\Http\Requests\PublicPages\SendMessageRequest; use App\Http\Requests\PublicPages\SendMessageRequest;
use App\Http\Resources\PageResource; use App\Http\Resources\PageResource;
use App\Http\Tools\Demo; use App\Http\Tools\Demo;
use App\Mail\SendSupportForm; use App\Mail\SendSupportForm;
use App\Page; use App\Models\Setting;
use App\Setting; use App\Models\Page;
use App\User; use App\Models\User;
use Artisan; use Artisan;
use Doctrine\DBAL\Driver\PDOException; use Doctrine\DBAL\Driver\PDOException;
use Illuminate\Http\Request; use Illuminate\Http\Request;
@@ -3,15 +3,14 @@
namespace App\Http\Controllers\FileBrowser; namespace App\Http\Controllers\FileBrowser;
use App\Http\Requests\FileBrowser\SearchRequest; use App\Http\Requests\FileBrowser\SearchRequest;
use App\User; use App\Models\User;
use Illuminate\Support\Facades\Validator;
use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Auth;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Collection; use Illuminate\Support\Collection;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use App\Folder; use App\Models\Folder;
use App\File; use App\Models\File;
use App\Share; use App\Models\Share;
class BrowseController extends Controller class BrowseController extends Controller
{ {
@@ -71,13 +70,13 @@ class BrowseController extends Controller
->pluck('item_id'); ->pluck('item_id');
// Get folders and files // Get folders and files
$folders = Folder::with(['parent', 'shared:token,id,item_id,permission,protected,expire_in']) $folders = Folder::with(['parent', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('user_id', $user_id) ->where('user_id', $user_id)
->whereIn('unique_id', $folder_ids) ->whereIn('unique_id', $folder_ids)
->sortable() ->sortable()
->get(); ->get();
$files = File::with(['parent', 'shared:token,id,item_id,permission,protected,expire_in']) $files = File::with(['parent', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('user_id', $user_id) ->where('user_id', $user_id)
->whereIn('unique_id', $file_ids) ->whereIn('unique_id', $file_ids)
->sortable() ->sortable()
@@ -92,10 +91,11 @@ class BrowseController extends Controller
* *
* @return mixed * @return mixed
*/ */
public function latest() { public function latest()
{
// Get User // Get User
$user = User::with(['latest_uploads' => function($query) { $user = User::with(['latest_uploads' => function ($query) {
$query->sortable(['created_at' => 'desc']); $query->sortable(['created_at' => 'desc']);
}]) }])
->where('id', Auth::id()) ->where('id', Auth::id())
@@ -109,7 +109,8 @@ class BrowseController extends Controller
* *
* @return mixed * @return mixed
*/ */
public function participant_uploads() { public function participant_uploads()
{
// Get User // Get User
$uploads = File::with(['parent']) $uploads = File::with(['parent'])
@@ -125,29 +126,24 @@ class BrowseController extends Controller
* Get directory with files * Get directory with files
* *
* @param Request $request * @param Request $request
* @param $unique_id * @param $id
* @return Collection * @return Collection
*/ */
public function folder(Request $request, $unique_id) public function folder(Request $request, $id)
{ {
// Get user
$user_id = Auth::id();
// Get folder trash items // Get folder trash items
if ($request->query('trash')) { if ($request->query('trash')) {
// Get folders and files // Get folders and files
$folders = Folder::onlyTrashed() $folders = Folder::onlyTrashed()
->with('parent') ->with('parent')
->where('user_id', $user_id) ->where('parent_id', $id)
->where('parent_id', $unique_id)
->sortable() ->sortable()
->get(); ->get();
$files = File::onlyTrashed() $files = File::onlyTrashed()
->with('parent') ->with('parent')
->where('user_id', $user_id) ->where('folder_id', $id)
->where('folder_id', $unique_id)
->sortable() ->sortable()
->get(); ->get();
@@ -156,20 +152,19 @@ class BrowseController extends Controller
} }
// Get folders and files // Get folders and files
$folders = Folder::with(['parent', 'shared:token,id,item_id,permission,protected,expire_in']) $folders = Folder::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('user_id', $user_id) ->where('parent_id', $id)
->where('parent_id', $unique_id)
->sortable() ->sortable()
->get(); ->get();
$files = File::with(['parent', 'shared:token,id,item_id,permission,protected,expire_in']) $files = File::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('user_id', $user_id) ->where('folder_id', $id)
->where('folder_id', $unique_id)
->sortable() ->sortable()
->get(); ->get();
// Collect folders and files to single array // Collect folders and files to single array
return collect([$folders, $files])->collapse(); return collect([$folders, $files])
->collapse();
} }
/** /**
@@ -177,20 +172,18 @@ class BrowseController extends Controller
* *
* @return array * @return array
*/ */
public function navigation_tree() { public function navigation_tree()
{
$folders = Folder::with('folders:id,parent_id,unique_id,name') $folders = Folder::with('folders:id,parent_id,id,name')
->where('parent_id', 0) ->where('parent_id', null)
->where('user_id', Auth::id())
->sortable() ->sortable()
->get(['id', 'parent_id', 'unique_id', 'name']); ->get(['id', 'parent_id', 'id', 'name']);
return [ return [
[ [
'unique_id' => 0,
'name' => __('vuefilemanager.home'), 'name' => __('vuefilemanager.home'),
'location' => 'base', 'location' => 'base',
'folders' => $folders, 'folders' => $folders,
] ]
]; ];
} }
+3 -3
View File
@@ -172,7 +172,7 @@ class File extends Model
*/ */
public function parent() public function parent()
{ {
return $this->belongsTo(Folder::class, 'folder_id', 'unique_id'); return $this->belongsTo(Folder::class, 'folder_id', 'id');
} }
/** /**
@@ -180,7 +180,7 @@ class File extends Model
*/ */
public function folder() public function folder()
{ {
return $this->hasOne(Folder::class, 'unique_id', 'folder_id'); return $this->hasOne(Folder::class, 'id', 'folder_id');
} }
/** /**
@@ -188,7 +188,7 @@ class File extends Model
*/ */
public function shared() public function shared()
{ {
return $this->hasOne(Share::class, 'item_id', 'unique_id'); return $this->hasOne(Share::class, 'item_id', 'id');
} }
/** /**
+22 -15
View File
@@ -19,7 +19,9 @@ class Folder extends Model
]; ];
protected $appends = [ protected $appends = [
'items', 'trashed_items' 'items',
'trashed_items',
'type'
]; ];
protected $casts = [ protected $casts = [
@@ -40,6 +42,11 @@ class Folder extends Model
protected $keyType = 'string'; protected $keyType = 'string';
public function getTypeAttribute()
{
return 'folder';
}
/** /**
* Index folder * Index folder
* *
@@ -100,7 +107,7 @@ class Folder extends Model
*/ */
public function getDeletedAtAttribute() public function getDeletedAtAttribute()
{ {
if (! $this->attributes['deleted_at']) return null; if (!$this->attributes['deleted_at']) return null;
return format_date(set_time_by_user_timezone($this->attributes['deleted_at']), __('vuefilemanager.time')); return format_date(set_time_by_user_timezone($this->attributes['deleted_at']), __('vuefilemanager.time'));
} }
@@ -112,12 +119,12 @@ class Folder extends Model
*/ */
public function parent() public function parent()
{ {
return $this->belongsTo(Folder::class, 'parent_id', 'unique_id'); return $this->belongsTo(Folder::class, 'parent_id', 'id');
} }
public function folderIds() public function folderIds()
{ {
return $this->children()->with('folderIds')->select(['unique_id', 'parent_id']); return $this->children()->with('folderIds')->select(['id', 'parent_id']);
} }
/** /**
@@ -127,7 +134,7 @@ class Folder extends Model
*/ */
public function files() public function files()
{ {
return $this->hasMany(File::class, 'folder_id', 'unique_id'); return $this->hasMany(File::class, 'folder_id', 'id');
} }
/** /**
@@ -138,7 +145,7 @@ class Folder extends Model
public function trashed_files() public function trashed_files()
{ {
return $this->hasMany(File::class, 'folder_id', 'unique_id')->withTrashed(); return $this->hasMany(File::class, 'folder_id', 'id')->withTrashed();
} }
/** /**
@@ -158,7 +165,7 @@ class Folder extends Model
*/ */
public function trashed_folders() public function trashed_folders()
{ {
return $this->children()->with('trashed_folders')->withTrashed()->select(['parent_id', 'unique_id', 'name']); return $this->children()->with('trashed_folders')->withTrashed()->select(['parent_id', 'id', 'name']);
} }
/** /**
@@ -168,7 +175,7 @@ class Folder extends Model
*/ */
public function children() public function children()
{ {
return $this->hasMany(Folder::class, 'parent_id', 'unique_id'); return $this->hasMany(Folder::class, 'parent_id', 'id');
} }
/** /**
@@ -178,7 +185,7 @@ class Folder extends Model
*/ */
public function trashed_children() public function trashed_children()
{ {
return $this->hasMany(Folder::class, 'parent_id', 'unique_id')->withTrashed(); return $this->hasMany(Folder::class, 'parent_id', 'id')->withTrashed();
} }
/** /**
@@ -202,19 +209,19 @@ class Folder extends Model
static::deleting(function ($item) { static::deleting(function ($item) {
if ( $item->isForceDeleting() ) { if ($item->isForceDeleting()) {
$item->trashed_children()->each(function($folder) { $item->trashed_children()->each(function ($folder) {
$folder->forceDelete(); $folder->forceDelete();
}); });
} else { } else {
$item->children()->each(function($folder) { $item->children()->each(function ($folder) {
$folder->delete(); $folder->delete();
}); });
$item->files()->each(function($file) { $item->files()->each(function ($file) {
$file->delete(); $file->delete();
}); });
} }
@@ -223,12 +230,12 @@ class Folder extends Model
static::restoring(function ($item) { static::restoring(function ($item) {
// Restore children folders // Restore children folders
$item->trashed_children()->each(function($folder) { $item->trashed_children()->each(function ($folder) {
$folder->restore(); $folder->restore();
}); });
// Restore children files // Restore children files
$item->trashed_files()->each(function($files) { $item->trashed_files()->each(function ($files) {
$files->restore(); $files->restore();
}); });
}); });
+2 -2
View File
@@ -137,7 +137,7 @@ class User extends Authenticatable
*/ */
public function getFolderTreeAttribute() public function getFolderTreeAttribute()
{ {
return File::with(['folders.shared', 'shared:token,id,item_id,permission,protected,expire_in']) return File::with(['folders.shared', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('parent_id', 0) ->where('parent_id', 0)
->where('user_id', $this->id) ->where('user_id', $this->id)
->sortable() ->sortable()
@@ -244,7 +244,7 @@ class User extends Authenticatable
public function favourite_folders() public function favourite_folders()
{ {
return $this->belongsToMany(Folder::class, 'favourite_folder', 'user_id', 'folder_id', 'id', 'id') return $this->belongsToMany(Folder::class, 'favourite_folder', 'user_id', 'folder_id', 'id', 'id')
->with('shared:token,id,item_id,permission,protected,expire_in'); ->with('shared:token,id,item_id,permission,is_protected,expire_in');
} }
/** /**
+1 -1
View File
@@ -24,7 +24,7 @@ class FolderFactory extends Factory
return [ return [
'id' => $this->faker->uuid, 'id' => $this->faker->uuid,
'user_id' => $this->faker->uuid, 'user_id' => $this->faker->uuid,
'name' => $this->faker->name, 'name' => $this->faker->word,
'user_scope' => $this->faker->randomElement( 'user_scope' => $this->faker->randomElement(
['master', 'editor', 'visitor'] ['master', 'editor', 'visitor']
), ),
+2 -2
View File
@@ -49,8 +49,8 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
Route::group(['prefix' => 'browse'], function () { Route::group(['prefix' => 'browse'], function () {
Route::get('/participant-uploads', [BrowseController::class, 'participant_uploads']); Route::get('/participant-uploads', [BrowseController::class, 'participant_uploads']);
Route::get('/navigation', [BrowseController::class, 'navigation_tree']); Route::get('/navigation', [BrowseController::class, 'navigation_tree']);
Route::get('/folders/{unique_id}', [BrowseController::class, 'folder']); Route::get('/folders/{id}', [BrowseController::class, 'folder']);
Route::get('/shared-all', [BrowseController::class, 'shared']); Route::get('/sharing', [BrowseController::class, 'shared']);
Route::get('/latest', [BrowseController::class, 'latest']); Route::get('/latest', [BrowseController::class, 'latest']);
Route::get('/search', [BrowseController::class, 'search']); Route::get('/search', [BrowseController::class, 'search']);
}); });
+128 -1
View File
@@ -2,23 +2,150 @@
namespace Tests\Feature; namespace Tests\Feature;
use App\Models\File;
use App\Models\Folder;
use App\Models\User;
use Illuminate\Foundation\Testing\DatabaseMigrations; use Illuminate\Foundation\Testing\DatabaseMigrations;
use Illuminate\Foundation\Testing\RefreshDatabase; use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker; use Illuminate\Foundation\Testing\WithFaker;
use Laravel\Sanctum\Sanctum;
use Tests\TestCase; use Tests\TestCase;
class BrowseTest extends TestCase class BrowseTest extends TestCase
{ {
use DatabaseMigrations; use DatabaseMigrations;
/**
* @test
*/
public function it_get_navigator_tree() public function it_get_navigator_tree()
{ {
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$folder_level_1 = Folder::factory(Folder::class)
->create([
'name' => 'level 1',
'user_scope' => 'master',
'user_id' => $user->id,
]);
$folder_level_2 = Folder::factory(Folder::class)
->create([
'name' => 'level 2',
'parent_id' => $folder_level_1->id,
'user_scope' => 'master',
'user_id' => $user->id,
]);
$folder_level_3 = Folder::factory(Folder::class)
->create([
'name' => 'level 3',
'parent_id' => $folder_level_2->id,
'user_scope' => 'master',
'user_id' => $user->id,
]);
$folder_level_2_sibling = Folder::factory(Folder::class)
->create([
'name' => 'level 2 Sibling',
'parent_id' => $folder_level_1->id,
'user_scope' => 'master',
'user_id' => $user->id,
]);
$this->getJson("/api/browse/navigation")
->assertStatus(200)
->assertJson([
[
"name" => "Home",
"location" => "base",
"folders" => [
[
"id" => $folder_level_1->id,
"parent_id" => null,
"name" => "level 1",
"items" => 2,
"trashed_items" => 2,
"type" => "folder",
"folders" => [
[
"id" => $folder_level_2->id,
"parent_id" => $folder_level_1->id,
"name" => "level 2",
"items" => 1,
"trashed_items" => 1,
"type" => "folder",
"folders" => [
[
"id" => $folder_level_3->id,
"user_id" => $user->id,
"parent_id" => $folder_level_2->id,
"name" => "level 3",
"color" => null,
"emoji" => null,
"user_scope" => "master",
"deleted_at" => null,
"created_at" => $folder_level_3->created_at,
"updated_at" => $folder_level_3->updated_at->toJson(),
"items" => 0,
"trashed_items" => 0,
"type" => "folder",
"folders" => [],
],
],
],
[
"id" => $folder_level_2_sibling->id,
"parent_id" => $folder_level_1->id,
"name" => "level 2 Sibling",
"items" => 0,
"trashed_items" => 0,
"type" => "folder",
"folders" => []
]
]
]
]
]
]);
} }
public function it_get_folder_files() /**
* @test
*/
public function it_get_folder_content()
{ {
$root = Folder::factory(Folder::class)
->create();
$folder = Folder::factory(Folder::class)
->create([
'parent_id' => $root->id
]);
$file = File::factory(File::class)
->create([
'folder_id' => $root->id
]);
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$response = $this->getJson("/api/browse/folders/$root->id")
->assertStatus(200);
collect([$folder, $file])
->each(function ($item) use ($response) {
$response->assertJsonFragment([
'id' => $item->id,
'type' => $item->type,
]);
});
} }
public function it_get_searched_file() public function it_get_searched_file()
+2 -2
View File
@@ -27,11 +27,11 @@ class FileTest extends TestCase
*/ */
public function it_test_file_factory() public function it_test_file_factory()
{ {
$folder = File::factory(File::class) $file = File::factory(File::class)
->create(); ->create();
$this->assertDatabaseHas('files', [ $this->assertDatabaseHas('files', [
'id' => $folder->id 'id' => $file->id
]); ]);
} }