2021-12-11 23:29:33 +01:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
namespace BookStack\Activity;
|
2021-12-11 23:29:33 +01:00
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
use BookStack\Activity\Models\Loggable;
|
|
|
|
use BookStack\Activity\Models\Webhook;
|
|
|
|
use BookStack\Activity\Tools\WebhookFormatter;
|
2022-01-03 19:22:03 +01:00
|
|
|
use BookStack\Facades\Theme;
|
2023-09-08 15:16:09 +02:00
|
|
|
use BookStack\Http\HttpRequestService;
|
2022-01-03 19:22:03 +01:00
|
|
|
use BookStack\Theming\ThemeEvents;
|
2023-05-17 18:56:55 +02:00
|
|
|
use BookStack\Users\Models\User;
|
2023-08-26 16:28:29 +02:00
|
|
|
use BookStack\Util\SsrUrlValidator;
|
2021-12-11 23:29:33 +01: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\Log;
|
|
|
|
|
|
|
|
class DispatchWebhookJob implements ShouldQueue
|
|
|
|
{
|
2021-12-18 12:43:05 +01:00
|
|
|
use Dispatchable;
|
|
|
|
use InteractsWithQueue;
|
|
|
|
use Queueable;
|
|
|
|
use SerializesModels;
|
2021-12-11 23:29:33 +01:00
|
|
|
|
2022-03-26 17:44:34 +01:00
|
|
|
protected Webhook $webhook;
|
|
|
|
protected User $initiator;
|
|
|
|
protected int $initiatedTime;
|
2023-07-12 17:16:12 +02:00
|
|
|
protected array $webhookData;
|
2021-12-11 23:29:33 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new job instance.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2023-07-12 17:16:12 +02:00
|
|
|
public function __construct(Webhook $webhook, string $event, Loggable|string $detail)
|
2021-12-11 23:29:33 +01:00
|
|
|
{
|
|
|
|
$this->webhook = $webhook;
|
|
|
|
$this->initiator = user();
|
|
|
|
$this->initiatedTime = time();
|
2023-07-12 17:16:12 +02:00
|
|
|
|
|
|
|
$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-11 23:29:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the job.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2023-09-08 15:16:09 +02:00
|
|
|
public function handle(HttpRequestService $http)
|
2021-12-11 23:29:33 +01:00
|
|
|
{
|
2022-01-03 20:42:48 +01:00
|
|
|
$lastError = null;
|
2022-01-03 19:22:03 +01:00
|
|
|
|
2022-01-03 19:37:05 +01:00
|
|
|
try {
|
2023-08-26 16:28:29 +02:00
|
|
|
(new SsrUrlValidator())->ensureAllowed($this->webhook->endpoint);
|
|
|
|
|
2023-09-08 15:16:09 +02:00
|
|
|
$client = $http->buildClient($this->webhook->timeout, [
|
|
|
|
'connect_timeout' => 10,
|
|
|
|
'allow_redirects' => ['strict' => true],
|
|
|
|
]);
|
2021-12-11 23:29:33 +01:00
|
|
|
|
2023-09-08 15:16:09 +02:00
|
|
|
$response = $client->sendRequest($http->jsonRequest('POST', $this->webhook->endpoint, $this->webhookData));
|
|
|
|
$statusCode = $response->getStatusCode();
|
|
|
|
|
|
|
|
if ($statusCode >= 400) {
|
|
|
|
$lastError = "Response status from endpoint was {$statusCode}";
|
|
|
|
Log::error("Webhook call to endpoint {$this->webhook->endpoint} failed with status {$statusCode}");
|
|
|
|
}
|
2023-09-08 18:16:57 +02:00
|
|
|
} catch (\Exception $error) {
|
2023-09-08 15:16:09 +02:00
|
|
|
$lastError = $error->getMessage();
|
|
|
|
Log::error("Webhook call to endpoint {$this->webhook->endpoint} failed with error \"{$lastError}\"");
|
2021-12-11 23:29:33 +01:00
|
|
|
}
|
2022-01-03 20:42:48 +01: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-11 23:29:33 +01:00
|
|
|
}
|
|
|
|
}
|