cleaniquecoders / laravel-media-secure
Securely display Media
Installs: 7 336
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/cleaniquecoders/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
Secure your media file access with authentication and policy-based authorization. Built on top of Spatie Laravel MediaLibrary, this package provides secure view, download, and stream endpoints with fine-grained access control.
Features
- Secure media URLs with UUID-based routing
- Three access types: view, download, and stream
- Signed URLs for time-limited access without authentication
- Authentication requirement (configurable)
- Policy-based authorization with parent model delegation
- Customizable middleware stack
- ETag/Last-Modified caching headers for performance
- Memory-efficient file streaming for large files
- Helper functions for URL generation
Installation
composer require cleaniquecoders/laravel-media-secure
Publish the config file:
php artisan vendor:publish --tag="media-secure-config"
Quick Start
1. Generate Secure URLs (Authenticated)
use Spatie\MediaLibrary\MediaCollections\Models\Media; // Get view URL: /media/view/{uuid} $viewUrl = get_view_media_url($media); // Get download URL: /media/download/{uuid} $downloadUrl = get_download_media_url($media); // Get stream URL: /media/stream/{uuid} $streamUrl = get_stream_media_url($media);
2. Generate Signed URLs (Shareable)
Signed URLs allow sharing media with external users without requiring authentication. URLs are cryptographically signed and expire after a configurable time.
// Generate signed URL (default expiration from config) $signedUrl = get_signed_view_url($media); // Generate signed URL with custom expiration (in minutes) $signedUrl = get_signed_download_url($media, 30); // Expires in 30 minutes // Generate signed URL with DateTime expiration $signedUrl = get_signed_stream_url($media, now()->addHours(24)); // Using the Facade use CleaniqueCoders\LaravelMediaSecure\Facades\LaravelMediaSecure; $url = LaravelMediaSecure::signedViewUrl($media); $url = LaravelMediaSecure::signedDownloadUrl($media, 60);
3. Create a Policy for Your Model (Required when strict = true)
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; } }
4. Register the Policy
// In AuthServiceProvider protected $policies = [ \App\Models\Document::class => \App\Policies\DocumentPolicy::class, ];
Signed URLs
Signed URLs are perfect for:
- Sharing files via email or messaging
- Embedding media in external applications
- Providing temporary access to clients
- API integrations where authentication is impractical
Configuration
// config/laravel-media-secure.php 'signed' => [ 'enabled' => env('LARAVEL_MEDIA_SECURE_SIGNED_ENABLED', true), 'prefix' => 'media-signed', 'route_name' => 'media.signed', 'expiration' => env('LARAVEL_MEDIA_SECURE_SIGNED_EXPIRATION', 60), // minutes ],
Environment Variables
LARAVEL_MEDIA_SECURE_SIGNED_ENABLED=true LARAVEL_MEDIA_SECURE_SIGNED_EXPIRATION=60
Documentation
For detailed documentation, see docs/README.md.
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.