<?php

namespace App\Jobs\ImageOptimizePipeline;

use App\Media;
use App\Util\Media\Image;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Log;

class ImageResize implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    protected $media;

    /**
     * Delete the job if its models no longer exist.
     *
     * @var bool
     */
    public $deleteWhenMissingModels = true;
    
    /**
     * 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;
        if(!$media) {
            return;
        }
        $path = storage_path('app/'.$media->media_path);
        if (!is_file($path) || $media->skip_optimize) {
            Log::info('Tried to optimize media that does not exist or is not readable. ' . $path);
            return;
        }

        if((bool) config_cache('pixelfed.optimize_image') === false) {
        	ImageThumbnail::dispatch($media)->onQueue('mmo');
        	return;
        }
        try {
            $img = new Image();
            $img->resizeImage($media);
        } catch (Exception $e) {
            Log::error($e);
        }

        ImageThumbnail::dispatch($media)->onQueue('mmo');
    }
}