2016-06-30 16:01:12 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Jobs;
|
|
|
|
|
|
|
|
use Log;
|
|
|
|
use App\Jobs\Job;
|
|
|
|
use Illuminate\Queue\SerializesModels;
|
|
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
|
|
use App\Model\Photo;
|
|
|
|
|
|
|
|
class PhotoDelete extends Job implements ShouldQueue
|
|
|
|
{
|
|
|
|
use InteractsWithQueue, SerializesModels;
|
|
|
|
|
|
|
|
private $photo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new job instance.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct(Photo $photo)
|
|
|
|
{
|
|
|
|
$this->photo = $photo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the job.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
|
|
|
if (! $this->photo->remove)
|
|
|
|
{
|
2016-06-30 21:34:18 +10:00
|
|
|
Log::warning(sprintf('%s: NOT Deleting [%s] not marked for deletion',__METHOD__,$this->photo->file_path()));
|
2016-06-30 16:01:12 +10:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove tags;
|
2016-07-01 14:37:55 +10:00
|
|
|
if ($this->photo->Tags->count())
|
|
|
|
$this->photo->Tags()->detach();
|
2016-06-30 16:01:12 +10:00
|
|
|
|
|
|
|
// Remove People;
|
2016-07-01 14:37:55 +10:00
|
|
|
if ($this->photo->People->count())
|
|
|
|
$this->photo->People()->detach();
|
2016-06-30 16:01:12 +10:00
|
|
|
|
|
|
|
// Make sure our parent is writable
|
|
|
|
if (! is_writable(dirname($this->photo->file_path())))
|
2016-06-30 21:34:18 +10:00
|
|
|
Log::warning(sprintf('%s: NOT Deleting [%s] parent directory not writable',__METHOD__,$this->photo->file_path()));
|
2016-06-30 16:01:12 +10:00
|
|
|
|
|
|
|
// Perform delete
|
|
|
|
if (file_exists($this->photo->file_path()))
|
|
|
|
unlink($this->photo->file_path());
|
|
|
|
|
2016-06-30 21:34:18 +10:00
|
|
|
Log::warning(sprintf('%s: Deleted [%s]',__METHOD__,$this->photo->file_path()));
|
2016-06-30 16:01:12 +10:00
|
|
|
$this->photo->delete();
|
|
|
|
}
|
|
|
|
}
|