src/EventSubscriber/CoreEventsSubscriber.php line 87

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Controller\SecurePageInterface;
  4. use Doctrine\ORM\EntityManagerInterface;
  5. use Empire\Core\Core;
  6. use Exception;
  7. use Psr\Log\LoggerInterface;
  8. use Symfony\Component\HttpFoundation\Response;
  9. use Symfony\Component\HttpFoundation\Session\SessionInterface;
  10. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  11. use Symfony\Component\HttpFoundation\RequestStack;
  12. use Symfony\Component\HttpFoundation\RedirectResponse;
  13. use Symfony\Component\HttpKernel\Event\ControllerEvent;
  14. use Symfony\Component\HttpKernel\KernelEvents;
  15. use Symfony\Component\Routing\RequestContext;
  16. use Twig\Environment;
  17. class CoreEventsSubscriber implements EventSubscriberInterface
  18. {
  19.     private $request;
  20.     private $session;
  21.     private $requestStack;
  22.     private $resolver;
  23.     private $logger;
  24.     public function __construct (
  25.             EntityManagerInterface $entityManager,
  26.             RequestStack $request,
  27.             RequestContext $rc,
  28.             Environment $twig,
  29.             RequestStack $requestStack,
  30.             LoggerInterface $logger
  31.             //ControllerResolver $resolver
  32.     ) {
  33.         Core::setDB($entityManager->getConnection());
  34.         //$this->connection = $entityManager->getConnection();
  35.         Core::set('version''8.5.1' trim(file_exists(EMPIRE_WEBROOT '/VERSION') ? '-'file_get_contents(EMPIRE_WEBROOT '/VERSION') : ''));
  36.         $base_url $rc->getScheme() . "://" $rc->getHost() . "/" $rc->getBaseUrl();
  37.         $this->request $request->getCurrentRequest();
  38.         Core::set('base_url'$base_url);
  39.         $this->requestStack $requestStack;
  40.         $this->session $this->requestStack->getSession();
  41.         Core::setSession($this->session);
  42.         Core::setTwig($twig);
  43.         //$this->resolver = $resolver;
  44.         $this->logger $logger;
  45.         Core::set('discord.guild'"503020279136649250");
  46.         Core::set('discord.token'"NTAzMTc1OTE5MDA4MjE5MTQ2.DqyrLQ.d4W-wNoNGUORjnudyx0bdmJkle8");
  47.         Core::set('discord.clientid'"503175919008219146");
  48.         Core::set('discord.clientse'"0coE9mZSGpOXkPZkiL5rOOwDL4WcfTZN");
  49.         Core::set('discord.botname'"Bot"); // Name of the ROLE in discord server
  50.         Core::set('discord.postINB'true); // Keep disabled for now
  51.         Core::set('discord.dev.inb.webhookUrl'"https://discord.com/api/webhooks/1086305402221772951/shyH8ajqj7PnDrV3cWiLK3zorihe-rmVyPc14UZL2RZCRpuhUnR15S5qPHZ-UIdtsCne");
  52.         Core::set('discord.dev.inb.avatarUrl''https://swc-empire.com/assets/uploads/image_26_MmM3ZGM0M2_empire-logo-large.png');
  53.         Core::set('discord.dev.inb.username''DEV Imperial News Bureau');
  54.         Core::set('discord.membersLinkEnabled'false); // If set to false: Individual Overwrite via Access-Key 'Discord-Release'
  55.         Core::set('discord.imperialRole'"887246214549090365");
  56.         Core::set('discord.recruitRole'"1326892381412392981");
  57.         Core::set('discord.tier1'"888688878431662110");
  58.         Core::set('discord.tier2'"888688794621083669");
  59.         Core::set('discord.tier3'"888688698424696883");
  60.         Core::set('discord.tier4'"888688420463980605");
  61.         
  62.         Core::set('combine.dev.clientid'"65b86ccb18fe01e20e39f10236574a5ae5c56127");
  63.         Core::set('combine.dev.clientse'"77a8cda2e4e0218a4c116a6c0c11fda7b7646e35");
  64.         Core::set('combine.prod.clientid'"4d2974503f6f59966386378879b18467734ff054");
  65.         Core::set('combine.prod.clientse'"94895db6fb9ee1846a3242118d1217e0ae84b5be");
  66.     }
  67.     /**
  68.      * @inheritDoc
  69.      * @return Array
  70.      */
  71.     public static function getSubscribedEvents()
  72.     {
  73.         return [
  74.             KernelEvents::CONTROLLER =>  [['pathInfo'50],['loginSetup'99], ['loginCheck'0]]
  75.         ];
  76.     }
  77.     public function pathInfo(ControllerEvent $event) {
  78.         Core::set('fullPage'explode("~",$this->request->getPathInfo())[0]);
  79.         Core::set('secure'false);
  80.     }
  81.     public function loginSetup(ControllerEvent $event) {
  82.         $request $this->request;
  83.         $this->logger->info('irms_token: ' $request->cookies->get('irms_token') );
  84.         $this->logger->info('member_id: ' $this->session->get('irms_token') );
  85.         if($request->cookies->get('irms_token') && !$this->session->get('member_id')) {
  86.             try {
  87.                 \Empire\Core\Login::cookieLogin($request->cookies->get('irms_token'));
  88.             } catch (Exception $ex) {
  89.                 $this->session->getFlashBag()->add('error''While attempting to remember your login, the following error occurred: ' $ex->getMessage());
  90.             }
  91.         }
  92.         if($request->request->get('login')) {
  93.             try {
  94.                 $getLogin = \Empire\Core\Login::processLogin($request);
  95.             } catch (Exception $ex) {
  96.                 $getLogin false;
  97.                 $this->session->getFlashBag()->add('error''While attempting to login, the following error occured: ' $ex->getMessage());
  98.             }
  99.             if ($getLogin) {
  100.                 if($request->request->get('rememberMe'false)) {
  101.                     try {
  102.                         \Empire\Core\Login::setLoginCookie();
  103.                     } catch (Exception $e) {
  104.                         $this->session->getFlashBag()->add('error'$e->getMessage());
  105.                     }
  106.                 }
  107.             } else {
  108.                 $this->session->getFlashBag()->add('error''Unable to log you in.');
  109.             }
  110.         }
  111.         Core::setUser(\Empire\Core\Login::getLoggedIn());
  112.         $redirectUrl $request->request->get('redirectUrl');
  113.         if ($redirectUrl != null ) {
  114.             $event->setController(function() use ($redirectUrl) {
  115.                 return new RedirectResponse(urldecode($redirectUrl));
  116.             });
  117.         }
  118.         $referer $request->headers->get('referer');
  119.         if (!is_null($referer)) {
  120.             return new RedirectResponse($referer);
  121.         }
  122.     }
  123.     public function loginCheck(ControllerEvent $event) {
  124.         $controller $event->getController();
  125.         if(is_array($controller)) $controller $controller[0];
  126.         if($controller instanceof SecurePageInterface) {
  127.             $resp Core::loginCheck();
  128.             if($resp instanceof Response) {
  129.                 $event->setController(function () use ($resp) {
  130.                    return $resp;
  131.                 });
  132.             }
  133.             Core::set('secure'true);
  134.         }
  135.     }
  136. }