瀏覽代碼

Add ImageOptimizePipeline

Daniel Supernault 7 年之前
父節點
當前提交
343757b1ea

+ 45 - 0
app/Jobs/ImageOptimizePipeline/ImageOptimize.php

@@ -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 - 0
app/Jobs/ImageOptimizePipeline/ImageResize.php

@@ -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 - 0
app/Jobs/ImageOptimizePipeline/ImageThumbnail.php

@@ -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 - 0
app/Jobs/ImageOptimizePipeline/ImageUpdate.php

@@ -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();
+    }
+}