BookStack/app/Activity/DispatchWebhookJob.php

82 lines
2.6 KiB
PHP
Raw Normal View History

2021-12-12 06:29:33 +08:00
<?php
2023-05-18 00:56:55 +08:00
namespace BookStack\Activity;
2021-12-12 06:29:33 +08:00
2023-05-18 00:56:55 +08:00
use BookStack\Activity\Models\Loggable;
use BookStack\Activity\Models\Webhook;
use BookStack\Activity\Tools\WebhookFormatter;
use BookStack\Facades\Theme;
use BookStack\Theming\ThemeEvents;
2023-05-18 00:56:55 +08:00
use BookStack\Users\Models\User;
use BookStack\Util\SsrUrlValidator;
2021-12-12 06:29:33 +08:00
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Http;
2021-12-12 06:29:33 +08:00
use Illuminate\Support\Facades\Log;
class DispatchWebhookJob implements ShouldQueue
{
2021-12-18 19:43:05 +08:00
use Dispatchable;
use InteractsWithQueue;
use Queueable;
use SerializesModels;
2021-12-12 06:29:33 +08:00
protected Webhook $webhook;
protected User $initiator;
protected int $initiatedTime;
protected array $webhookData;
2021-12-12 06:29:33 +08:00
/**
* Create a new job instance.
*
* @return void
*/
public function __construct(Webhook $webhook, string $event, Loggable|string $detail)
2021-12-12 06:29:33 +08:00
{
$this->webhook = $webhook;
$this->initiator = user();
$this->initiatedTime = time();
$themeResponse = Theme::dispatch(ThemeEvents::WEBHOOK_CALL_BEFORE, $event, $this->webhook, $detail, $this->initiator, $this->initiatedTime);
$this->webhookData = $themeResponse ?? WebhookFormatter::getDefault($event, $this->webhook, $detail, $this->initiator, $this->initiatedTime)->format();
2021-12-12 06:29:33 +08:00
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
$lastError = null;
try {
(new SsrUrlValidator())->ensureAllowed($this->webhook->endpoint);
$response = Http::asJson()
->withOptions(['allow_redirects' => ['strict' => true]])
->timeout($this->webhook->timeout)
->post($this->webhook->endpoint, $this->webhookData);
} catch (\Exception $exception) {
$lastError = $exception->getMessage();
Log::error("Webhook call to endpoint {$this->webhook->endpoint} failed with error \"{$lastError}\"");
}
2021-12-12 06:29:33 +08:00
if (isset($response) && $response->failed()) {
$lastError = "Response status from endpoint was {$response->status()}";
Log::error("Webhook call to endpoint {$this->webhook->endpoint} failed with status {$response->status()}");
2021-12-12 06:29:33 +08:00
}
$this->webhook->last_called_at = now();
if ($lastError) {
$this->webhook->last_errored_at = now();
$this->webhook->last_error = $lastError;
}
$this->webhook->save();
2021-12-12 06:29:33 +08:00
}
}