我怎样才能触发观看无控制器核心模块的Magento 在 从外部脚本的config.xml(

2019-08-05 22:59发布

有关背景参考,请参阅: Magento的:如何让观察员在外部脚本工作?

我想问问从外部脚本“重复”一个前端控制器的操作的首选方法是什么。 我创建一个外部SSO登录了Magento的EE 1.12。

我的代码中存在作为一个php文件如下。 您可以通过创建test.php的,并不管你的用户ID是更换我的用户(185)进行测试。 导航到该页面,然后再。 你会发现你和退出登录,但是在管理它不会告诉你处于在线状态。 阅读...

<?php

    umask(0);
    require_once 'app/Mage.php';

    Mage::app("default");

    // Set the session to frontend according to many suggestions
    Mage::getSingleton("core/session", array("name" => "frontend"));

    // Alan Storm suggestion to load specific area in Magento (frontend)
    Mage::app()->loadArea(Mage_Core_Model_App_Area::AREA_FRONTEND);

    // Load My Specific User
    $user = Mage::getModel('customer/customer')->load(185)->setWebsiteId(Mage::app()->getStore()->getWebsiteId());

    // Get the session object
    $session = Mage::getSingleton('customer/session');

    // Make it look good for debugging
    echo "<PRE>";

    // Toggle the customer logged in / logged out upon page load
    if ($session->isLoggedIn())
    {
        try
        {
            $session->session->setCustomer($user);
            echo "LOGGED IN<br>";
            var_dump($session->getCustomer()->getIsJustConfirmed());
        } catch (Mage_Core_Exception $e) {
            $message = $e->getMessage();
            var_dump($message);
        }

    } else {
        $session->logout();
    }

    var_dump($session->getCustomer());
    echo $session->isLoggedIn() ? $user->getName().' is online!' : 'not logged in';

?>

在用户这段代码的日志,但没有Mage_Log,Mage_Persistent的,或依赖于连接到前端区域config.xml中曾经将火controller_action_predispatch和controller_action_postdispatch事件控制器的任何其他模块。

Mage_Log是这种情况下它手表customer_login并触发bindCustomerLogin()函数(因为我使用的艾伦风暴的建议上文),但是控制器调度不火,导致模块故障正常工作一个很好的例子。

如何能够将这些其他模块永远不可能从外部脚本(或全球观察者观看controller_front_init_routers事件)被触发?

编辑:这里的解决方案是建议通过上述benmarks最终的结果...我模仿Mage_Customer控制器。 下面的脚本演示了如何执行完整的Magento的登录。 它不是广泛的测试,但它确实表明用户如被记录在后端。 这是最完整的解决方案,我已经看到了日期。

public function autoMageLogin() {
                // Include the controller itself so the object can be used
                include ('/var/www/app/code/core/Mage/Customer/controllers/AccountController.php');

                // Configure Magento to think its using the frontend
                Mage::getSingleton("core/session", array("name" => "frontend"));
                Mage::getConfig()->init();
                Mage::getConfig()->loadEventObservers('frontend');
                Mage::app()->addEventArea('frontend');
                Mage::app()->loadArea(Mage_Core_Model_App_Area::AREA_FRONTEND);

                // Prepare the request as if it were coming from the specific
                // controller (I've chosed Mage_Customer as my chosen controller
                // to 'emulate' in php code
                $request = Mage::app()->getRequest();
                $request->setRouteName('customer');
                $request->setControllerModule('Mage_Customer');
                $request->setRoutingInfo('');
                $request->setModuleName('customer');
                $request->setControllerName('account');
                $request->setModuleKey('module');
                $request->setControllerKey('account');
                $request->setActionName('loginPost');
                $request->setActionKey('action');


                $response = Mage::app()->getResponse();

                // Instantiate a new AccountController object using the modified request
                // and the modified response (see the include() above)
                $accountControl = new Mage_Customer_AccountController($request, $response);

                // Dispatch events associated to the controller
                Mage::dispatchEvent('controller_action_predispatch', array('controller_action' => $accountControl));
                Mage::dispatchEvent('controller_action_predispatch_customer', array('controller_action' => $accountControl));
                Mage::dispatchEvent('controller_action_predispatch_customer_account_loginPost', array('controller_action' => $accountControl));


                // Load the current user
                $user = Mage::getModel('customer/customer')->load(185)->setWebsiteId(Mage::app()->getStore()->getWebsiteId());

                // Grab the current session
                $session = Mage::getSingleton('customer/session');

                // From this point forward, emulate the controller actions    
                if (!$session->isLoggedIn()){
                        try{

                                $session->setCustomerAsLoggedIn($user);
                                $session->renewSession();
                                echo "LOGGED IN<br>";
                        } catch (Mage_Core_Exception $e) {
                                $message = $e->getMessage();
                                var_dump($message);
                        }

                } else {
                        echo "LOGGED OUT<br>";

                        $session->logout();
                }


                    // Now fire the post controller action events
                    Mage::dispatchEvent('controller_action_postdispatch_customer_account_loginPost', array('controller_action'=>$accountControl));
                    Mage::dispatchEvent('controller_action_postdispatch_customer', array('controller_action'=>$accountControl));
                    Mage::dispatchEvent('controller_action_postdispatch', array('controller_action'=>$accountControl));


                // log to the screen and be done
                var_dump($session->getCustomer());
                echo $session->isLoggedIn() ? $session->getCustomer()->getName().' is online!' : 'not logged in';

                die();

        }

Answer 1:

您将需要手动调度此事件与原有PARAMS如

Mage::dispatchEvent(
    'controller_action_predispatch',
    array('controller_action',Mage::app()->getRequest()
);

Mage_Core_Controller_Varien_Action::preDispatch() (链接)的更多信息。 请注意,前和后派遣调度方法基于routename PARAMS可能会或可能不会成为问题动态事件。



Answer 2:

如果你重写外部脚本作为自定义控制器和行动,那么所有的事件自然会火。 但是,你必须有使它成为首位外部原因。



文章来源: How can I trigger controllerless core Magento modules that watch in in config.xml from external script