2017-01-04 22:36:30 +00:00
|
|
|
<?php
|
2023-04-01 16:53:42 +00:00
|
|
|
declare(strict_types=1);
|
2017-01-04 22:36:30 +00:00
|
|
|
|
2023-04-01 16:53:42 +00:00
|
|
|
namespace App\Controller\Telegram;
|
2017-01-04 22:36:30 +00:00
|
|
|
|
2023-04-09 21:30:51 +00:00
|
|
|
use App\Service\Telegram\IncomingUpdateDispatcher;
|
2017-11-05 13:20:35 +00:00
|
|
|
use Psr\Log\LoggerInterface;
|
2017-11-05 02:03:26 +00:00
|
|
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
2017-11-05 01:42:08 +00:00
|
|
|
use Symfony\Component\HttpFoundation\{JsonResponse, Request, Response};
|
2023-04-09 21:30:51 +00:00
|
|
|
use TelegramBot\Api\Types\Update;
|
2017-01-04 22:36:30 +00:00
|
|
|
|
2017-11-05 02:03:26 +00:00
|
|
|
class WebHookController extends AbstractController
|
2017-01-04 22:36:30 +00:00
|
|
|
{
|
2023-04-01 16:53:42 +00:00
|
|
|
public function __construct(
|
|
|
|
private readonly string $telegramToken,
|
|
|
|
private readonly bool $debugEnabled,
|
|
|
|
) {
|
2017-11-05 02:03:26 +00:00
|
|
|
}
|
|
|
|
|
2017-11-05 13:20:35 +00:00
|
|
|
public function receiveUpdateAction(Request $request, string $token, IncomingUpdateDispatcher $updateDispatcher, LoggerInterface $logger): Response
|
2017-01-04 22:36:30 +00:00
|
|
|
{
|
2017-11-05 02:03:26 +00:00
|
|
|
if ($token !== $savedToken = $this->telegramToken) {
|
2017-01-04 22:36:30 +00:00
|
|
|
throw $this->createNotFoundException();
|
|
|
|
}
|
|
|
|
|
2023-04-09 21:30:51 +00:00
|
|
|
try {
|
|
|
|
$content = \json_decode($request->getContent(), flags: JSON_THROW_ON_ERROR);
|
|
|
|
} catch (\JsonException $e) {
|
|
|
|
return new JsonResponse('bad json', JsonResponse::HTTP_UNPROCESSABLE_ENTITY);
|
|
|
|
}
|
2017-01-04 22:36:30 +00:00
|
|
|
|
2023-04-09 21:30:51 +00:00
|
|
|
$update = Update::fromResponse($content);
|
2017-01-04 22:36:30 +00:00
|
|
|
|
2017-01-05 20:17:19 +00:00
|
|
|
try {
|
2017-11-05 01:42:08 +00:00
|
|
|
$updateDispatcher->process($update);
|
2017-01-05 20:17:19 +00:00
|
|
|
} catch (\Exception $e) {
|
2023-04-01 16:53:42 +00:00
|
|
|
if ($this->debugEnabled) {
|
2017-01-05 20:17:19 +00:00
|
|
|
throw $e;
|
|
|
|
}
|
|
|
|
|
2023-04-01 16:53:42 +00:00
|
|
|
$logger->error('Telegram bot error', [
|
2017-01-05 20:17:19 +00:00
|
|
|
'exception' => get_class($e),
|
|
|
|
'file' => $e->getFile(),
|
|
|
|
'line' => $e->getLine(),
|
|
|
|
'code' => $e->getCode(),
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
'trace' => $e->getTraceAsString(),
|
|
|
|
]);
|
|
|
|
}
|
2017-01-04 22:36:30 +00:00
|
|
|
|
|
|
|
return new JsonResponse('received');
|
|
|
|
}
|
|
|
|
}
|