PageRenderTime 45ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/magento/app/code/core/Mage/Persistent/Model/Observer/Session.php

https://bitbucket.org/jit_bec/shopifine
PHP | 188 lines | 97 code | 20 blank | 71 comment | 36 complexity | 2397ee6037b90ca6ca8c2732582d167e MD5 | raw file
Possible License(s): LGPL-3.0
  1. <?php
  2. /**
  3. * Magento
  4. *
  5. * NOTICE OF LICENSE
  6. *
  7. * This source file is subject to the Open Software License (OSL 3.0)
  8. * that is bundled with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://opensource.org/licenses/osl-3.0.php
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@magentocommerce.com so we can send you a copy immediately.
  14. *
  15. * DISCLAIMER
  16. *
  17. * Do not edit or add to this file if you wish to upgrade Magento to newer
  18. * versions in the future. If you wish to customize Magento for your
  19. * needs please refer to http://www.magentocommerce.com for more information.
  20. *
  21. * @category Mage
  22. * @package Mage_Persistent
  23. * @copyright Copyright (c) 2012 Magento Inc. (http://www.magentocommerce.com)
  24. * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
  25. */
  26. /**
  27. * Persistent Session Observer
  28. *
  29. * @category Mage
  30. * @package Mage_Persistent
  31. * @author Magento Core Team <core@magentocommerce.com>
  32. */
  33. class Mage_Persistent_Model_Observer_Session
  34. {
  35. /**
  36. * Create/Update and Load session when customer log in
  37. *
  38. * @param Varien_Event_Observer $observer
  39. */
  40. public function synchronizePersistentOnLogin(Varien_Event_Observer $observer)
  41. {
  42. /** @var $customer Mage_Customer_Model_Customer */
  43. $customer = $observer->getEvent()->getCustomer();
  44. // Check if customer is valid (remove persistent cookie for invalid customer)
  45. if (!$customer || !$customer->getId() || !Mage::helper('persistent/session')->isRememberMeChecked()) {
  46. Mage::getModel('persistent/session')->removePersistentCookie();
  47. return;
  48. }
  49. $persistentLifeTime = Mage::helper('persistent')->getLifeTime();
  50. // Delete persistent session, if persistent could not be applied
  51. if (Mage::helper('persistent')->isEnabled() && ($persistentLifeTime <= 0)) {
  52. // Remove current customer persistent session
  53. Mage::getModel('persistent/session')->deleteByCustomerId($customer->getId());
  54. return;
  55. }
  56. /** @var $sessionModel Mage_Persistent_Model_Session */
  57. $sessionModel = Mage::helper('persistent/session')->getSession();
  58. // Check if session is wrong or not exists, so create new session
  59. if (!$sessionModel->getId() || ($sessionModel->getCustomerId() != $customer->getId())) {
  60. $sessionModel = Mage::getModel('persistent/session')
  61. ->setLoadExpired()
  62. ->loadByCustomerId($customer->getId());
  63. if (!$sessionModel->getId()) {
  64. $sessionModel = Mage::getModel('persistent/session')
  65. ->setCustomerId($customer->getId())
  66. ->save();
  67. }
  68. Mage::helper('persistent/session')->setSession($sessionModel);
  69. }
  70. // Set new cookie
  71. if ($sessionModel->getId()) {
  72. Mage::getSingleton('core/cookie')->set(
  73. Mage_Persistent_Model_Session::COOKIE_NAME,
  74. $sessionModel->getKey(),
  75. $persistentLifeTime
  76. );
  77. }
  78. }
  79. /**
  80. * Unload persistent session (if set in config)
  81. *
  82. * @param Varien_Event_Observer $observer
  83. */
  84. public function synchronizePersistentOnLogout(Varien_Event_Observer $observer)
  85. {
  86. if (!Mage::helper('persistent')->isEnabled() || !Mage::helper('persistent')->getClearOnLogout()) {
  87. return;
  88. }
  89. /** @var $customer Mage_Customer_Model_Customer */
  90. $customer = $observer->getEvent()->getCustomer();
  91. // Check if customer is valid
  92. if (!$customer || !$customer->getId()) {
  93. return;
  94. }
  95. Mage::getModel('persistent/session')->removePersistentCookie();
  96. // Unset persistent session
  97. Mage::helper('persistent/session')->setSession(null);
  98. }
  99. /**
  100. * Synchronize persistent session info
  101. *
  102. * @param Varien_Event_Observer $observer
  103. */
  104. public function synchronizePersistentInfo(Varien_Event_Observer $observer)
  105. {
  106. if (!Mage::helper('persistent')->isEnabled() || !Mage::helper('persistent/session')->isPersistent()) {
  107. return;
  108. }
  109. /** @var $sessionModel Mage_Persistent_Model_Session */
  110. $sessionModel = Mage::helper('persistent/session')->getSession();
  111. /** @var $request Mage_Core_Controller_Request_Http */
  112. $request = $observer->getEvent()->getFront()->getRequest();
  113. // Quote Id could be changed only by logged in customer
  114. if (Mage::getSingleton('customer/session')->isLoggedIn()
  115. || ($request && $request->getActionName() == 'logout' && $request->getControllerName() == 'account')
  116. ) {
  117. $sessionModel->save();
  118. }
  119. }
  120. /**
  121. * Set Checked status of "Remember Me"
  122. *
  123. * @param Varien_Event_Observer $observer
  124. */
  125. public function setRememberMeCheckedStatus(Varien_Event_Observer $observer)
  126. {
  127. if (!Mage::helper('persistent')->canProcess($observer)
  128. || !Mage::helper('persistent')->isEnabled() || !Mage::helper('persistent')->isRememberMeEnabled()
  129. ) {
  130. return;
  131. }
  132. /** @var $controllerAction Mage_Core_Controller_Varien_Action */
  133. $controllerAction = $observer->getEvent()->getControllerAction();
  134. if ($controllerAction) {
  135. $rememberMeCheckbox = $controllerAction->getRequest()->getPost('persistent_remember_me');
  136. Mage::helper('persistent/session')->setRememberMeChecked((bool)$rememberMeCheckbox);
  137. if (
  138. $controllerAction->getFullActionName() == 'checkout_onepage_saveBilling'
  139. || $controllerAction->getFullActionName() == 'customer_account_createpost'
  140. ) {
  141. Mage::getSingleton('checkout/session')->setRememberMeChecked((bool)$rememberMeCheckbox);
  142. }
  143. }
  144. }
  145. /**
  146. * Renew persistent cookie
  147. *
  148. * @param Varien_Event_Observer $observer
  149. */
  150. public function renewCookie(Varien_Event_Observer $observer)
  151. {
  152. if (!Mage::helper('persistent')->canProcess($observer)
  153. || !Mage::helper('persistent')->isEnabled() || !Mage::helper('persistent/session')->isPersistent()
  154. ) {
  155. return;
  156. }
  157. /** @var $controllerAction Mage_Core_Controller_Front_Action */
  158. $controllerAction = $observer->getEvent()->getControllerAction();
  159. if (Mage::getSingleton('customer/session')->isLoggedIn()
  160. || $controllerAction->getFullActionName() == 'customer_account_logout'
  161. ) {
  162. Mage::getSingleton('core/cookie')->renew(
  163. Mage_Persistent_Model_Session::COOKIE_NAME,
  164. Mage::helper('persistent')->getLifeTime()
  165. );
  166. }
  167. }
  168. }