bekwoh / laravel-media-secure
Securely display Media
Installs: 649
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/bekwoh/laravel-media-secure
Requires
- php: ^8.2 | ^8.3 | ^8.4
- cleaniquecoders/traitify: ^1.1
- illuminate/contracts: ^11.0 | ^12.0
- spatie/laravel-medialibrary: ^10.5 | ^11.5
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- driftingly/rector-laravel: ^1.2 | ^2.0
- larastan/larastan: ^2.9 | ^3.6
- laravel/pint: ^1.0
- nunomaduro/collision: ^8.0
- orchestra/testbench: ^9.0 | ^10.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0 || ^2.0
- phpstan/phpstan-phpunit: ^1.0 || ^2.0
- phpunit/phpunit: ^10.5 || ^11.0 || ^12.0
README
You have documents, but want to limit the access to only logged in users, and also have some other sophisticated / complex rules in order to access the documents, then this package is for you.
This package will securely display or download to your media files.
Installation
You can install the package via composer:
composer require cleaniquecoders/laravel-media-secure
Publish the config file with:
php artisan vendor:publish --tag="media-secure-config"
Usage
In case you want more control on who are able to access to the media, you can use the Laravel Policy. You just need to define the policy, then it's done. This package will use the policy to handle more sophisticated and complex rules accessing to your media files.
Make sure you are using Laravel Medialibrary package.
When the require_auth configuration is enabled ('require_auth' => true), the use who want to access to the media require to login.
When the strict configuration is enabled ('strict' => true), the parent model of the media ($media->model) is required to have its own policy registered.
This policy must define the access methods:
- view
- stream
- download
These methods will be used by MediaPolicy to determine whether the user is authorised to access the media.
Why Is This Required?
Since Spatie's Media Library uses polymorphic relationships, media items are attached to various parent models (e.g., Document, Post, User, etc.).
To enforce fine-grained control, MediaPolicy delegates authorisation checks to the parent model’s policy.
What You Must Do
- 
Create a policy for the parent model (e.g., DocumentPolicy).
- 
Define the following methods in that policy: - view(User $user, Document $document)
- stream(User $user, Document $document)
- download(User $user, Document $document)
 
Example: DocumentPolicy
namespace App\Policies; use App\Models\Document; use App\Models\User; class DocumentPolicy { public function view(User $user, Document $document): bool { return $user->id === $document->user_id; } public function stream(User $user, Document $document): bool { return $user->id === $document->user_id; } public function download(User $user, Document $document): bool { return $user->id === $document->user_id; } }
These methods must be defined because
MediaPolicyuses the value from theMediaAccessenum to callGate::allows($type, $media->model).
Register the Policy
In your AuthServiceProvider:
protected $policies = [ \App\Models\Document::class => \App\Policies\DocumentPolicy::class, ];
What Happens If No Policy Exists?
| Condition | Result | 
|---|---|
| strict = true | Access will be denied if the parent model doesn't have a policy | 
| strict = false | Access will be granted without checking the parent model's policy | 
Summary
| Requirement | Mandatory | When | 
|---|---|---|
| Parent model has a policy | ✅ | When strict = true | 
| Defines view,stream,downloadmethods | ✅ | For enum-based access control | 
| Policy registered in AuthServiceProvider | ✅ | Required by Laravel's Gate system | 
Helpers
You upload / add media as documented in Laravel Medialibrary. Then to generate links:
// Get the view URL // https://your-app.com/media/view/some-random-uuid $view_url = get_view_media_url($media); // Get the download URL // https://your-app.com/media/download/some-random-uuid $download_url = get_download_media_url($media); // Get the stream URL // https://your-app.com/media/stream/some-random-uuid $stream_url = get_stream_media_url($media);
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.