point-tools/src/Skobkin/Bundle/PointToolsBundle/Controller/Telegram/WebHookController.php

61 lines
1.7 KiB
PHP
Raw Normal View History

2017-01-04 22:36:30 +00:00
<?php
namespace Skobkin\Bundle\PointToolsBundle\Controller\Telegram;
2017-11-05 13:20:35 +00:00
use Psr\Log\LoggerInterface;
use Skobkin\Bundle\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};
2017-01-04 22:36:30 +00:00
use unreal4u\TelegramAPI\Telegram\Types\Update;
/**
* {@inheritdoc}
*/
2017-11-05 02:03:26 +00:00
class WebHookController extends AbstractController
2017-01-04 22:36:30 +00:00
{
2017-11-05 02:03:26 +00:00
/** @var string */
private $telegramToken;
/** @var bool */
private $debug;
public function __construct(string $telegramToken, bool $debug)
{
$this->telegramToken = $telegramToken;
$this->debug = $debug;
}
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();
}
$content = json_decode($request->getContent(), true);
$update = new Update(
$content,
$logger
2017-01-04 22:36:30 +00:00
);
try {
$updateDispatcher->process($update);
} catch (\Exception $e) {
2017-11-05 02:03:26 +00:00
if ($this->debug) {
throw $e;
}
$logger->addError('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');
}
}