mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-11-26 00:03: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