mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-11-29 17:53:16 +00:00
Add ImageOptimizePipeline
This commit is contained in:
parent
e3590c3768
commit
343757b1ea
4 changed files with 207 additions and 0 deletions
45
app/Jobs/ImageOptimizePipeline/ImageOptimize.php
Normal file
45
app/Jobs/ImageOptimizePipeline/ImageOptimize.php
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Jobs\ImageOptimizePipeline;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use ImageOptimizer;
|
||||||
|
use App\{Media, Status};
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
|
||||||
|
class ImageOptimize implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
protected $media;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new job instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct(Media $media)
|
||||||
|
{
|
||||||
|
$this->media = $media;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the job.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$media = $this->media;
|
||||||
|
$path = storage_path('app/'. $media->media_path);
|
||||||
|
if(!is_file($path)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ImageResize::dispatch($media);
|
||||||
|
}
|
||||||
|
}
|
53
app/Jobs/ImageOptimizePipeline/ImageResize.php
Normal file
53
app/Jobs/ImageOptimizePipeline/ImageResize.php
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Jobs\ImageOptimizePipeline;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use ImageOptimizer;
|
||||||
|
use App\{Media, Status};
|
||||||
|
use App\Util\Media\Image;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
|
||||||
|
class ImageResize implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
protected $media;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new job instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct(Media $media)
|
||||||
|
{
|
||||||
|
$this->media = $media;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the job.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$media = $this->media;
|
||||||
|
$path = storage_path('app/'. $media->media_path);
|
||||||
|
if(!is_file($path)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$img = new Image;
|
||||||
|
$img->resizeImage($media);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ImageThumbnail::dispatch($media);
|
||||||
|
}
|
||||||
|
}
|
55
app/Jobs/ImageOptimizePipeline/ImageThumbnail.php
Normal file
55
app/Jobs/ImageOptimizePipeline/ImageThumbnail.php
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Jobs\ImageOptimizePipeline;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use App\{Media, Status};
|
||||||
|
use App\Util\Media\Image;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
|
||||||
|
class ImageThumbnail implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
protected $media;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new job instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct(Media $media)
|
||||||
|
{
|
||||||
|
$this->media = $media;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the job.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$media = $this->media;
|
||||||
|
$path = storage_path('app/'. $media->media_path);
|
||||||
|
if(!is_file($path)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$img = new Image;
|
||||||
|
$img->resizeThumbnail($media);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
$media->processed_at = Carbon::now();
|
||||||
|
$media->save();
|
||||||
|
|
||||||
|
ImageUpdate::dispatch($media);
|
||||||
|
}
|
||||||
|
}
|
54
app/Jobs/ImageOptimizePipeline/ImageUpdate.php
Normal file
54
app/Jobs/ImageOptimizePipeline/ImageUpdate.php
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Jobs\ImageOptimizePipeline;
|
||||||
|
|
||||||
|
use ImageOptimizer;
|
||||||
|
use App\{Media, Status};
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
|
||||||
|
class ImageUpdate implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
protected $media;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new job instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct(Media $media)
|
||||||
|
{
|
||||||
|
$this->media = $media;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the job.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$media = $this->media;
|
||||||
|
$path = storage_path('app/'. $media->media_path);
|
||||||
|
$thumb = storage_path('app/'. $media->thumbnail_path);
|
||||||
|
try {
|
||||||
|
ImageOptimizer::optimize($thumb);
|
||||||
|
ImageOptimizer::optimize($path);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!is_file($path) || !is_file($thumb)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$photo_size = filesize($path);
|
||||||
|
$thumb_size = filesize($thumb);
|
||||||
|
$total = ($photo_size + $thumb_size);
|
||||||
|
$media->size = $total;
|
||||||
|
$media->save();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue