FuelPHP - घटनाएँ

एक eventप्रोग्राम द्वारा पहचानी जाने वाली क्रिया या घटना को प्रोग्राम द्वारा ही नियंत्रित किया जा सकता है। उदाहरण के लिए, हम my_fuel_event नाम की एक क्रिया या घटना को परिभाषित कर सकते हैं और फिर जब भी कोई कार्य करते हैं, तो my_fuel_event कहा जाता है। FuelPHP वर्ग प्रदान करता है,Event आवेदन में घटनाओं के साथ काम करने के लिए।

सिस्टम इवेंट

फ्यूलफेप ने कुछ घटना को परिभाषित किया जिसके माध्यम से हम कुछ काम कर सकते हैं जब भी परिभाषित घटनाओं को कॉल किया जाता है या एप्लिकेशन द्वारा निकाल दिया जाता है। यह मदद फ्यूलपीपी के कोर कोड फाइलों को बदले बिना फ्यूलपीपी के व्यवहार को बदल रही है। पूर्व-परिभाषित घटनाएं इस प्रकार हैं -

  • app_created - फ्यूलपीईपी ढांचे को शुरू करने के बाद इस घटना को चालू किया जाएगा।

  • request_created - नए अनुरोध ऑब्जेक्ट के जाली होने के बाद इस घटना को चालू किया जाएगा।

  • request_started - अनुरोध के निष्पादन का अनुरोध होने पर यह घटना शुरू हो जाएगी।

  • controller_started - इस घटना से पहले () विधि कहा जाता है नियंत्रकों से पहले शुरू हो जाएगा।

  • controller_finished - इस घटना के बाद नियंत्रकों के बाद ट्रिगर किया जाएगा () विधि को बुलाया गया है और प्रतिक्रिया प्राप्त हुई है।

  • response_created - एक नई प्रतिक्रिया वस्तु जाली होने के बाद इस घटना को चालू किया जाएगा।

  • request_finished - अनुरोध के निष्पादन के पूरा होने और प्रतिक्रिया मिलने पर यह घटना शुरू हो जाएगी।

  • shutdown - मुख्य अनुरोध के संसाधित होने और आउटपुट भेजे जाने के बाद इस घटना को चालू किया जाएगा।

हम विशेष कॉन्फ़िगरेशन फ़ाइल में घटनाओं को संभाल सकते हैं, fuel/app/config/events.php निम्नानुसार है -

<?php  
   return array ( 
      'fuelphp' => array ( 
         'app_created' => function() { 
            // After FuelPHP initialised
         }, 
         'request_created' => function() { 
            // After Request forged 
         }, 
         'request_started' => function() { 
            // Request is requested 
         }, 
         'controller_started' => function() { 
            // Before controllers before() method called 
         }, 
         'controller_finished' => function() { 
            // After controllers after() method called 
         }, 
         'response_created' => function() { 
            // After Response forged 
         }, 
         'request_finished' => function() { 
            // Request is complete and Response received 
         }, 
         'shutdown' => function() { 
            // Output has been send out 
         }, 
      ), 
   );

घटना के तरीके

इवेंट क्लास रजिस्टर, अपंजीकृत और आग की घटनाओं को दर्ज करने के तरीके प्रदान करता है। वे इस प्रकार हैं,

रजिस्टर करें()

रजिस्टर विधि फ़ाइलों को एक ऑब्जेक्ट को पंजीकृत करने की अनुमति देती है जो ट्रिगर विधि कहा जाता है जब चलाया जाएगा।

$my_event_code = function() { 
   echo 'my event'; 
} 
Event::register('my_event', $my_event_code);

अपंजीकृत ()

अपंजीकृत विधि उन फ़ाइलों को अपंजीकृत करने की अनुमति देती है जो ट्रिगर विधि कहे जाने पर चलाई जाएंगी।

Event::unregister('my_event', $my_event_code);

ट्रिगर ()

ट्रिगर विधि का उपयोग उन कॉलबैक को ट्रिगर या सक्रिय करने के लिए किया जाता है जो रजिस्टर विधि के माध्यम से जुड़े होते हैं।

Event::trigger('my_event');

has_events ()

Has_events मेथड उपलब्ध है जिससे आप जांच सकते हैं कि कोई विशेष पंजीकृत ईवेंट ट्रिगर है या नहीं।

Event::has_events('my_event');

फोर्ज ()

फोर्ज एक नई ईवेंट ऑब्जेक्ट लौटाता है।

$event = Event::forge();

उदाहरण ()

उदाहरण एक नया ईवेंट ऑब्जेक्ट सिंगलटन देता है।

$event = Event::instance('event_instance');