jjarroyo / tinify-laravel
Tinify API support with laravel (TinyPNG)
1.0
2023-01-05 01:23 UTC
Requires
- php: >=7.2.0
- illuminate/support: ^6.0 || ^7.0 || ^8.0 || ^9.0
- tinify/tinify: *
This package is auto-updated.
Last update: 2025-01-05 05:48:46 UTC
README
Tinify API support for Laravel 7+
Install
$ composer require jjarroyo/tinify-laravel
Add this to your config/app.php,
under "providers":
JJArroyo\TinifyLaravel\TinifyLaravelServiceProvider::class,
under "aliases":
'Tinify' => JJArroyo\TinifyLaravel\Facades\Tinify::class
And set a env variable TINIFY_APIKEY
with your TinyPNG API key.
If you want to directly upload the image to aws s3
, you need set the env variables of following with your aws s3 credentials.
S3_KEY= S3_SECRET= S3_REGION= S3_BUCKET=
Examples
$result = Tinify::fromFile('\path\to\file'); $result = Tinify::fromBuffer($source_data); $result = Tinify::fromUrl($image_url); /** To save as File **/ $result->toFile('\path\to\save'); /** To get image as data **/ $data = $result->toBuffer();
$s3_result = Tinify::fileToS3('\path\to\file', $s3_bucket_name, '/path/to/save/in/bucket'); $s3_result = Tinify::bufferToS3($source_data, $s3_bucket_name, '/path/to/save/in/bucket'); $s3_result = Tinify::urlToS3($image_url, $s3_bucket_name, '/path/to/save/in/bucket'); /** To get the url of saved image **/ $s3_image_url = $s3_result->location(); $s3_image_width = $s3_result->width(); $s3_image_hight = $s3_result->height();
NOTE:
All the images directly save to s3 is publicably readable. And you can set permissions for s3 bucket folder in your aws console to make sure the privacy of images.