div-art / filemanager
create filemanager file
Requires
This package is not auto-updated.
Last update: 2025-04-27 08:32:44 UTC
README
Filemanager package for Laravel 5.5
Installation
To install, run the following in your project directory:
$ composer require div-art/filemanager
Then in config/app.php
add the following to the providers
array:
\Divart\Filemanager\FilemanagerServiceProvider::class,
'Tymon\JWTAuth\Providers\JWTAuthServiceProvider',
Also in config/app.php, add the Facade class to the aliases array:
'Filemanager' => \Divart\Filemanager\Facades\Filemanager::class,
'JWTAuth' => 'Tymon\JWTAuth\Facades\JWTAuth'
Configuration
To publish Filemanager's configuration file, run the following vendor:publish
command:
php artisan vendor:publish --provider="Divart\Filemanager\FilemanagerServiceProvider"
php artisan vendor:publish --provider="Tymon\JWTAuth\Providers\JWTAuthServiceProvider"
Now for token encryption, I need to generate a secret key by running following line of code :
php artisan jwt:secret
Now I will create middleware to check if the token is valid or not and also You can handle the exception if the token is expired.
php artisan make:middleware VerifyJWTToken
Using this middleware, you can filter the request and validate the JWT token. Now open your VerifyJWTToken middleware and put below line of code.
app/Http/Middleware/VerifyJWTToken.php pop-uptext
<?php
namespace App\Http\Middleware;
use Closure;
use JWTAuth;
use Tymon\JWTAuth\Exceptions\JWTException;
use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException;
class VerifyJWTToken
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
try{
$user = JWTAuth::toUser($request->input('token'));
}catch (JWTException $e) {
if($e instanceof \Tymon\JWTAuth\Exceptions\TokenExpiredException) {
return response()->json(['token_expired'], $e->getStatusCode());
}else if ($e instanceof \Tymon\JWTAuth\Exceptions\TokenInvalidException) {
return response()->json(['token_invalid'], $e->getStatusCode());
}else{
return response()->json(['error'=>'Token is required']);
}
}
return $next($request);
}
}
The try block in handle method check if requested token is verified by JWTAuth or not if it is not verified then exception will be handled in catch block with their status.
Now register this middleware in your kernal to run during every HTTP request to your application. app/Http/Kernel.php
protected $routeMiddleware = [
...
'jwt.auth' => \App\Http\Middleware\VerifyJWTToken::class,
];
Usage
Add from ENV file:
#FILEMANAGER_LOCATION - File manager location
FILEMANAGER_LOCATION=myfilemanager
Since the file manager only works with authorized users, you need to make a connection to the database, and create a plaque for users with minimal fields email, password If you do not have it, you can do it using the command:
php artisan make:auth
Available routes
To work with the file manager you need to login by POST method, send an email address and password to this route to authorize and receive a token
http.youdomain.com/auth/login
File Manager Routes
All file manager paths have a prefix 'filemanager'
example:
method GET
{http.youdomain.com}/filemanager
this method open filemanager and scan him
method GET
{http.youdomain.com}/filemanager/folder/{path to folder?}
this route open this selected folder
method POST
{http.youdomain.com}/filemanager/folder/create/{path to folder?}
this method create new folder in this directory
Need to send data: 'name' - is name folder
method POST
{http.youdomain.com}/filemanager/file/create/{path to file?}
this method create file
Need to send: 'name' and 'data' where value name is name file and your expansion, 'data' is content file
method POST
{http.youdomain.com}/filemanager/file/upload/{path to file?}
this method upload file
method PUT
{http.youdomain.com}/filemanager/folder/update/{path to folder}
this method update(rename folder) selected folder in this directory
Need to send data: 'name', 'newname' where 'name' is name selected folder and 'newname' that new name folder
method PUT
{http.youdomain.com}/filemanager/file/update/{path to file?}
Need to send: 'name' and 'data' where value name is name file and your expansion, 'data' is content file
method DELETE
{http.youdomain.com}/filemanager/folder/delete/{path to folder}
this method delete selected folder in this directory
Need to send data: 'name', where value is name selected folder
method DELETE
{http.youdomain.com}/filemanager/file/delete/{path to file?}
Need to send: 'name' and the file is deleted
method GET
{http.youdomain.com}/filemanager/file/{filename}/folder/{path to file?}
this method return file data
method POST
{http.youdomain.com}/filemanager/folder/changelocation/{path to folder}
this method change location folder and the attachments in it are files
Need to send data: 'from', 'to'. 'from' - address from which of the derivatives, 'to' - where to move
method POST
{http.youdomain.com}/filemanager/file/changelocation/{path to folder?}
this method change location file Need to send data: 'from', 'to'. 'from' - address from which of the derivatives, 'to' - where to move
method POST
{http.youdomain.com}/filemanager/folder/{folder?}
this method accepts data for sorting items into a file manager
Need to send data: 'value' and 'type'. 'value' may be important 'size' or 'time', 'type' may be important 'SORT_ASC' or SORT_DESC. Defaul is 'value' = 'time', 'type' = SORT_ASC
License
The MIT License (MIT). Please see License File for more information."# Filemanager" "# Filemanager"