|
2 | 2 |
|
3 | 3 | namespace Level23\AwsQueue\Queue\Jobs; |
4 | 4 |
|
| 5 | +use Illuminate\Support\Collection; |
| 6 | + |
5 | 7 | class BatchJob extends SqsJob |
6 | 8 | { |
7 | 9 | /** |
@@ -38,58 +40,83 @@ public function attempts() |
38 | 40 | /** |
39 | 41 | * Delete the job from the queue. |
40 | 42 | * |
41 | | - * @return void |
| 43 | + * @return Collection |
42 | 44 | */ |
43 | 45 | public function delete() |
44 | 46 | { |
45 | | - $entries = collect($this->jobs) |
46 | | - ->filter(function(SqsJob $job) { |
47 | | - return !$job->isDeletedOrReleased(); |
48 | | - }) |
49 | | - ->transform(function(SqsJob $job) { |
50 | | - return [ |
51 | | - 'Id' => $job->getJobId(), |
52 | | - 'ReceiptHandle' => $job->getReceiptHandle() |
53 | | - ]; |
54 | | - }); |
55 | | - |
56 | | - if($entries->isNotEmpty()) { |
| 47 | + $jobs = collect($this->jobs)->filter(function (SqsJob $job) { |
| 48 | + return !$job->isDeletedOrReleased(); |
| 49 | + }); |
| 50 | + |
| 51 | + $response = $this->deleteJobs($jobs); |
| 52 | + |
| 53 | + $this->deleted = true; |
| 54 | + |
| 55 | + return $response; |
| 56 | + } |
| 57 | + |
| 58 | + /** |
| 59 | + * @param Collection $jobs |
| 60 | + * @return Collection |
| 61 | + */ |
| 62 | + public function deleteJobs(Collection $jobs) |
| 63 | + { |
| 64 | + $jobs = $jobs->keyBy(function(SqsJob $job) { |
| 65 | + return $job->getJobId(); |
| 66 | + }); |
| 67 | + |
| 68 | + $entries = $jobs->map(function (SqsJob $job) { |
| 69 | + return [ |
| 70 | + 'Id' => $job->getJobId(), |
| 71 | + 'ReceiptHandle' => $job->getReceiptHandle(), |
| 72 | + ]; |
| 73 | + }); |
| 74 | + |
| 75 | + $failedJobs = collect(); |
| 76 | + |
| 77 | + if ($entries->isNotEmpty()) { |
57 | 78 |
|
58 | 79 | $response = $this->sqs->deleteMessageBatch([ |
59 | 80 | 'QueueUrl' => $this->queue, |
60 | | - 'Entries' => $entries->values()->toArray(), |
| 81 | + 'Entries' => $entries->values()->toArray(), |
61 | 82 | ]); |
62 | 83 |
|
63 | | - foreach ($response['Successful'] as $message) { |
| 84 | + foreach (collect($response->get('Successful')) as $message) { |
64 | 85 | $this->jobs[$message['Id']]->setDeleted(); |
65 | 86 | } |
| 87 | + |
| 88 | + foreach (collect($response->get('Failed')) as $message) { |
| 89 | + $job = $jobs->get($message['Id']); |
| 90 | + $job->error(array_except($message,'Id')); |
| 91 | + $failedJobs->put($message['Id'],$job); |
| 92 | + } |
66 | 93 | } |
67 | 94 |
|
68 | | - $this->deleted = true; |
| 95 | + return $failedJobs; |
69 | 96 | } |
70 | 97 |
|
71 | 98 | /** |
72 | 99 | * Release the job back into the queue. |
73 | 100 | * |
74 | | - * @param int $delay |
| 101 | + * @param int $delay |
75 | 102 | * @return void |
76 | 103 | */ |
77 | 104 | public function release($delay = 0) |
78 | 105 | { |
79 | | - $entries = collect($this->jobs)->transform(function(SqsJob $job) use ($delay) { |
| 106 | + $entries = collect($this->jobs)->transform(function (SqsJob $job) use ($delay) { |
80 | 107 | return [ |
81 | | - 'Id' => $job->getJobId(), |
82 | | - 'ReceiptHandle' => $job->getReceiptHandle(), |
| 108 | + 'Id' => $job->getJobId(), |
| 109 | + 'ReceiptHandle' => $job->getReceiptHandle(), |
83 | 110 | 'VisibilityTimeout' => $delay, |
84 | 111 | ]; |
85 | 112 | }); |
86 | 113 |
|
87 | 114 | $response = $this->sqs->changeMessageVisibilityBatch([ |
88 | 115 | 'QueueUrl' => $this->queue, |
89 | | - 'Entries' => $entries->values()->toArray(), |
| 116 | + 'Entries' => $entries->values()->toArray(), |
90 | 117 | ]); |
91 | 118 |
|
92 | | - foreach ($response['Successful'] as $message) { |
| 119 | + foreach (collect($response->get('Successful')) as $message) { |
93 | 120 | $this->jobs[$message['Id']]->setDeleted(); |
94 | 121 | } |
95 | 122 | } |
|
0 commit comments