anourvalar / eloquent-file
Database (Eloquent) layer for files management
Installs: 3 614
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: ^8.3
- anourvalar/eloquent-validation: ^3.16
- anourvalar/laravel-atom: ^2.21
- intervention/image: ^3.8
- laravel/framework: ^9.0|^10.0|^11.0|^12.0
Requires (Dev)
- fakerphp/faker: ^1.9.1
- friendsofphp/php-cs-fixer: ^3.26
- phpstan/phpstan: ^2.0
- psalm/plugin-laravel: ^3.0
- squizlabs/php_codesniffer: ^3.7
- dev-master
- 1.43.6
- 1.43.5
- 1.43.4
- 1.43.3
- 1.43.2
- 1.43.1
- 1.43.0
- 1.42.6
- 1.42.5
- 1.42.4
- 1.42.3
- 1.42.2
- 1.42.1
- 1.42.0
- 1.41.5
- 1.41.4
- 1.41.3
- 1.41.2
- 1.41.1
- 1.41.0
- 1.40.0
- 1.39.19
- 1.39.18
- 1.39.17
- 1.39.16
- 1.39.15
- 1.39.14
- 1.39.13
- 1.39.12
- 1.39.11
- 1.39.10
- 1.39.9
- 1.39.8
- 1.39.7
- 1.39.6
- 1.39.5
- 1.39.4
- 1.39.3
- 1.39.2
- 1.39.1
- 1.39.0
- 1.38.1
- 1.38.0
- 1.37.6
- 1.37.5
- 1.37.4
- 1.37.3
- 1.37.2
- 1.37.1
- 1.37.0
- 1.36.0
- 1.35.6
- 1.35.5
- 1.35.4
- 1.35.3
- 1.35.2
- 1.35.1
- 1.35.0
- 1.34.4
- 1.34.3
- 1.34.2
- 1.34.1
- 1.34.0
- 1.33.0
- 1.32.0
- 1.31.2
- 1.31.1
- 1.31.0
- 1.30.2
- 1.30.1
- 1.30.0
- 1.29.0
- 1.28.1
- 1.28.0
- 1.27.0
- 1.26.1
- 1.26.0
- 1.25.0
- 1.24.0
- 1.23.0
- 1.22.0
- 1.21.0
- 1.20.2
- 1.20.1
- 1.20.0
- 1.19.1
- 1.19.0
- 1.18.1
- 1.18.0
- 1.17.0
- 1.16.0
- 1.15.2
- 1.15.1
- 1.15.0
- 1.14.0
- 1.13.0
- 1.12.0
- 1.11.1
- 1.11.0
- 1.10.3
- 1.10.2
- 1.10.1
- 1.10.0
- 1.9.1
- 1.9.0
- 1.8.0
- 1.7.1
- 1.7.0
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.0
- 1.0.2
- 1.0.1
- 1.0.0
This package is auto-updated.
Last update: 2025-10-01 20:01:55 UTC
README
Installation
composer require anourvalar/eloquent-file
php artisan vendor:publish --tag=AnourValar\EloquentFile\Providers\EloquentFileServiceProvider
Prune command
$schedule->command('eloquent-file:on-zero --days=10')->dailyAt('00:30')->runInBackground()->onOneServer();
Relation
/** * @return \Illuminate\Database\Eloquent\Relations\MorphMany */ public function fileVirtuals(): \Illuminate\Database\Eloquent\Relations\MorphMany { return $this->morphMany(\App\FileVirtual::class, 'entity', 'entity')->orderBy('id', 'ASC'); }
Observer
public function deleting(Model $model) { // FileVirtuals foreach ($model->fileVirtuals()->get() as $item) { $item->delete(); } }
Proxy download
// Url signed Route::controller(App\Http\Controllers\FileController::class)->group(function () { Route::any('/file/{file_virtual}/download/{filename}', 'download') ->middleware('throttle:lax')->name('file.download'); // $this->proxyUrlSigned($request); }); // User authorized Route::controller(App\Http\Controllers\FileController::class)->group(function () { Route::any('/file/{file_virtual}/download/{filename}', 'download') ->middleware('auth:sanctum', 'throttle:lax')->name('file.download'); // $this->proxyUserAuthorize($request); });
Route
\Route::pattern('file_virtual', '[0-9]{1,18}'); // RouteServiceProvider \Route::pattern('entity_id', '[0-9]{1,18}'); // RouteServiceProvider Route::prefix('/file') ->controller(App\Http\Controllers\Api\FileController::class) ->group(function () { Route::post('/upload/{entity}/{entity_id}/{name}', 'upload'); // + middleware Route::post('/delete/{file_virtual}', 'delete'); // + middleware });
Controller
class FileController extends Controller { use \AnourValar\EloquentFile\Traits\ControllerTrait; /** * Web-service: Upload a file * * @param \Illuminate\Http\Request $request * @return array */ public function upload(Request $request): array { $fileVirtual = \DB::transaction(function () use ($request) { return $this->uploadFileFrom($request); }); return ['file_virtual' => ['id' => $fileVirtual->id]]; } /** * Web-service: Delete a file * * @param \Illuminate\Http\Request $request * @return array */ public function delete(Request $request) { \DB::transaction(function () use ($request) { $this->deleteFileFrom($request); }); return ['file_virtual' => ['id' => (int) $request->route('file_virtual')]]; } }