mrfrkayvaz / impono
A flexible Laravel package that handles uploads from links, raw data, or files, turning them into a unified upload process.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/mrfrkayvaz/impono
Requires
- php: ^8.2
- illuminate/database: ^12.0
- illuminate/http: ^12.0
- illuminate/support: ^12.0
- spatie/image: ^3.8
- spatie/image-optimizer: ^1.8
Requires (Dev)
- orchestra/testbench: ^10.6
- pestphp/pest: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
- phpstan/phpstan: ^1.10.50
README
A flexible Laravel package that handles uploads from links, raw data, or files, turning them into a unified upload process. Impono provides powerful image manipulation, compression, and storage capabilities with an intuitive API.
Features
- 🔗 Multiple Upload Sources: Upload from files, URLs, or raw data (base64)
- 🖼️ Image Manipulation: Resize, convert, apply filters, and more
- 🗜️ Smart Compression: Automatic image optimization
- 🎨 Built-in Filters: Sepia, blur, brightness adjustments
- 💾 Flexible Storage: Support for multiple Laravel storage disks
- 🔧 Extensible: Easy to add custom manipulation drivers
- 🧪 Well Tested: Comprehensive test suite with Pest PHP
- ⚡ Performance: Optimized for speed and memory efficiency
Installation
You can install the package via Composer:
composer require mrfrkayvaz/impono
Laravel Auto-Discovery
The package will automatically register itself with Laravel 5.5+.
Manual Registration
If you're using an older version of Laravel, add the service provider to your config/app.php:
'providers' => [ // ... Impono\ImponoServiceProvider::class, ],
And add the facade alias:
'aliases' => [ // ... 'Impono' => Impono\Facades\Impono::class, ],
Configuration
Publish the configuration file:
php artisan vendor:publish --provider="Impono\ImponoServiceProvider" --tag="impono-config"
Environment Variables
Add these variables to your .env file:
FILESYSTEM_DISK=local IMPOONO_TEMP_PATH=impono/tmp IMPOONO_LOCATION=uploads
Usage
Basic Upload from File
use Impono\Facades\Impono; use Illuminate\Http\Request; public function upload(Request $request) { $file = $request->file('image'); $result = Impono::fromFile($file) ->disk('local') ->location('uploads/2025/jan') ->push('my-image.png'); echo $result->getURL(); // uploads/2025/jan/my-image.png }
Upload from URL
use Impono\Facades\Impono; $result = Impono::fromUrl('https://example.com/image.jpg') ->resize(800, 600) ->quality(85) ->convert(Extension::WEBP) ->compress() ->push('optimized-image.webp'); echo $result->getURL();
Upload from Base64 Data
use Impono\Facades\Impono; $base64Data = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA...'; $result = Impono::fromData($base64Data) ->resize(400, 300) ->sepia() ->push('vintage-photo.png');
Image Manipulation
use Impono\Facades\Impono; use Impono\Enums\Extension; $result = Impono::fromFile($file) ->resize(1200, 800) // Resize to specific dimensions ->quality(90) // Set JPEG quality ->convert(Extension::WEBP) // Convert to WebP format ->sepia() // Apply sepia filter ->blur(5) // Apply blur effect ->brightness(20) // Adjust brightness ->compress() // Optimize file size ->disk('s3') // Store on S3 ->location('images/gallery') // Custom storage path ->push('processed-image.webp');
Available Image Operations
Resizing
->resize(800, 600) // Resize to exact dimensions ->width(800) // Set width only ->height(600) // Set height only
Format Conversion
use Impono\Enums\Extension; ->convert(Extension::WEBP) // Convert to WebP ->convert(Extension::PNG) // Convert to PNG ->convert(Extension::JPEG) // Convert to JPEG ->convert(Extension::GIF) // Convert to GIF ->convert(Extension::AVIF) // Convert to AVIF ->convert(Extension::HEIC) // Convert to HEIC ->convert(Extension::TIFF) // Convert to TIFF
Filters and Effects
->sepia() // Apply sepia filter ->blur(5) // Apply blur (1-100) ->brightness(20) // Adjust brightness (-100 to 100) ->quality(85) // Set JPEG quality (1-100)
Compression
->compress() // Optimize file size
Storage Configuration
// Use different storage disks ->disk('local') // Local storage ->disk('s3') // Amazon S3 ->disk('gcs') // Google Cloud Storage // Set custom storage location ->location('uploads/2025/jan') ->location('images/products')
File Information
$result = Impono::fromFile($file)->push(); // Get file information echo $result->getURL(); // File path echo $result->getFilename(); // Filename without extension echo $result->getExtension(); // File extension echo $result->getDisk(); // Storage disk echo $result->getLocation(); // Storage location echo $result->getIsTemp(); // Is temporary file // Get image dimensions (for images) $width = $result->getWidth(); $height = $result->getHeight(); $fileSize = $result->getFileSize();
Configuration Options
Basic Configuration
// config/impono.php return [ 'temp_path' => 'impono/tmp', // Temporary file storage path 'location' => 'uploads', // Default storage location 'mimes' => [ // Supported file types ['extension' => 'jpg', 'type' => 'image', 'mime' => 'image/jpeg'], ['extension' => 'png', 'type' => 'image', 'mime' => 'image/png'], ['extension' => 'gif', 'type' => 'image', 'mime' => 'image/gif'], ['extension' => 'webp', 'type' => 'image', 'mime' => 'image/webp'], // ... more file types ] ];
Supported File Types
The package supports a wide range of file types:
Images:
- JPEG, PNG, GIF, WebP, AVIF, HEIC, TIFF, BMP, SVG
Videos:
- MP4, WebM
Documents:
- PDF, DOC, DOCX, XLS, XLSX, PPT, PPTX, CSV
Audio:
- MP3, WebA
Archives:
- ZIP, RAR
Other:
- TXT, XML
Advanced Usage
Custom Storage Paths
$result = Impono::fromFile($file) ->disk('s3') ->location('user-uploads/' . auth()->id() . '/profile') ->push('avatar.jpg');
Batch Processing
$files = $request->file('images'); $results = []; foreach ($files as $file) { $results[] = Impono::fromFile($file) ->resize(800, 600) ->compress() ->push(); }
Error Handling
try { $result = Impono::fromUrl('https://example.com/image.jpg') ->resize(800, 600) ->push(); } catch (\InvalidArgumentException $e) { // Handle unsupported file type return response()->json(['error' => 'Unsupported file type'], 400); } catch (\RuntimeException $e) { // Handle download/processing errors return response()->json(['error' => 'Failed to process image'], 500); }
Testing
The package includes a comprehensive test suite. Run tests using:
composer test
Requirements
- PHP 8.2+
- Laravel 12.0+
- GD or Imagick extension
- Spatie Image package
Dependencies
illuminate/support^12.0illuminate/database^12.0illuminate/http^12.0spatie/image^3.8spatie/image-optimizer^1.8
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This package is open-sourced software licensed under the MIT license.
Support
If you find this package useful, please consider starring it on GitHub. For issues and feature requests, please use the GitHub issue tracker.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Roadmap
- Video manipulation support
- PDF processing capabilities
- Advanced compression algorithms
- CDN integration
- Batch processing queue support
- Watermark functionality
Made with ❤️ for the Laravel community