1 | <?php |
||
2 | |||
3 | namespace Mostafaznv\PdfOptimizer\Jobs; |
||
4 | |||
5 | use Illuminate\Bus\Queueable; |
||
6 | use Illuminate\Contracts\Queue\ShouldQueue; |
||
7 | use Illuminate\Foundation\Bus\Dispatchable; |
||
8 | use Illuminate\Queue\InteractsWithQueue; |
||
9 | use Illuminate\Queue\SerializesModels; |
||
10 | use Mostafaznv\PdfOptimizer\Actions\OptimizePdfAction; |
||
11 | use Mostafaznv\PdfOptimizer\DTOs\PdfOptimizerJobData; |
||
12 | use Mostafaznv\PdfOptimizer\Events\PdfOptimizerJobFinished; |
||
13 | |||
14 | |||
15 | class PdfOptimizerJob implements ShouldQueue |
||
16 | { |
||
17 | use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; |
||
0 ignored issues
–
show
introduced
by
![]() |
|||
18 | |||
19 | public function __construct(private readonly PdfOptimizerJobData $data) {} |
||
20 | |||
21 | |||
22 | public function handle(): void |
||
23 | { |
||
24 | $this->data->logger?->info("Job {$this->data->id} started."); |
||
25 | |||
26 | $result = OptimizePdfAction::init($this->data->file, $this->data->disk) |
||
27 | ->logger($this->data->logger) |
||
28 | ->setTimeout($this->data->timeout) |
||
29 | ->execute( |
||
30 | $this->data->commands, |
||
31 | $this->data->input, |
||
32 | $this->data->output |
||
33 | ); |
||
34 | |||
35 | event( |
||
36 | new PdfOptimizerJobFinished($this->data->id, $result->status, $result->message) |
||
37 | ); |
||
38 | |||
39 | if ($result->status) { |
||
40 | $this->data->logger?->info('Job finished successfully.'); |
||
41 | } |
||
42 | else { |
||
43 | $this->data->logger?->error('Job finished with error.'); |
||
44 | |||
45 | $this->fail($result->message); |
||
46 | } |
||
47 | } |
||
48 | } |
||
49 |