आप कर्नेलएवेंट्स :: REQUEST की सदस्यता लेने वाले कस्टम मॉड्यूल में इवेंट सब्सक्राइबर के साथ उपयोगकर्ता की स्थिति का बहुत पहले परीक्षण कर सकते हैं।
सबसे पहले, आप mymodule.services.yml
अपने मॉड्यूल फ़ोल्डर में ईवेंट सब्सक्राइबर को पंजीकृत करते हैं :
services:
mymodule.event_subscriber:
class: Drupal\mymodule\EventSubscriber\RedirectAnonymousSubscriber
arguments: []
tags:
- {name: event_subscriber}
फिर फ़ोल्डर RedirectAnonymousSubscriber.php
में अपने मॉड्यूल में अपने कस्टम इवेंट सब्सक्राइबर के लिए जोड़ें /src/EventSubscriber/
।
namespace Drupal\mymodule\EventSubscriber;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpKernel\KernelEvents;
use Symfony\Component\HttpKernel\Event\GetResponseEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
/**
* Event subscriber subscribing to KernelEvents::REQUEST.
*/
class RedirectAnonymousSubscriber implements EventSubscriberInterface {
public function __construct() {
$this->account = \Drupal::currentUser();
}
public function checkAuthStatus(GetResponseEvent $event) {
if ($this->account->isAnonymous() && \Drupal::routeMatch()->getRouteName() != 'user.login') {
// add logic to check other routes you want available to anonymous users,
// otherwise, redirect to login page.
$route_name = \Drupal::routeMatch()->getRouteName();
if (strpos($route_name, 'view') === 0 && strpos($route_name, 'rest_') !== FALSE) {
return;
}
$response = new RedirectResponse('/user/login', 301);
$event->setResponse($response);
$event->stopPropagation();
}
}
public static function getSubscribedEvents() {
$events[KernelEvents::REQUEST][] = array('checkAuthStatus');
return $events;
}
}
KernelEvents::REQUEST
ईवेंट पर कार्य करने के लिए लिखेंगे और फिर लॉगिन पेज के लिए एक रीडायरेक्ट रिप्रोंस पर प्रतिक्रिया सेट करेंगे।