point-tools/src/Controller/Telegram/WebHookController.php

52 lines
1.5 KiB
PHP
Raw Normal View History

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
2017-11-05 13:20:35 +00:00
use Psr\Log\LoggerInterface;
use src\PointToolsBundle\Service\Telegram\IncomingUpdateDispatcher;
2017-11-05 02:03:26 +00:00
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\{JsonResponse, Request, Response};
2023-04-01 16:53:42 +00:00
use unreal4u\Telegram\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-01 16:53:42 +00:00
$content = \json_decode($request->getContent(), flags: JSON_THROW_ON_ERROR);
2017-01-04 22:36:30 +00:00
$update = new Update(
$content,
);
try {
$updateDispatcher->process($update);
} catch (\Exception $e) {
2023-04-01 16:53:42 +00:00
if ($this->debugEnabled) {
throw $e;
}
2023-04-01 16:53:42 +00:00
$logger->error('Telegram bot error', [
'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');
}
}