00001 <?php 00002 /** 00003 * Magento 00004 * 00005 * NOTICE OF LICENSE 00006 * 00007 * This source file is subject to the Open Software License (OSL 3.0) 00008 * that is bundled with this package in the file LICENSE.txt. 00009 * It is also available through the world-wide-web at this URL: 00010 * http://opensource.org/licenses/osl-3.0.php 00011 * If you did not receive a copy of the license and are unable to 00012 * obtain it through the world-wide-web, please send an email 00013 * to license@magentocommerce.com so we can send you a copy immediately. 00014 * 00015 * DISCLAIMER 00016 * 00017 * Do not edit or add to this file if you wish to upgrade Magento to newer 00018 * versions in the future. If you wish to customize Magento for your 00019 * needs please refer to http://www.magentocommerce.com for more information. 00020 * 00021 * @category Mage 00022 * @package Mage_AdminNotification 00023 * @copyright Copyright (c) 2008 Irubin Consulting Inc. DBA Varien (http://www.varien.com) 00024 * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) 00025 */ 00026 00027 00028 /** 00029 * AdminNotification Inbox model 00030 * 00031 * @category Mage 00032 * @package Mage_AdminNotification 00033 * @author Magento Core Team <core@magentocommerce.com> 00034 */ 00035 class Mage_AdminNotification_Model_Mysql4_Inbox extends Mage_Core_Model_Mysql4_Abstract 00036 { 00037 protected function _construct() 00038 { 00039 $this->_init('adminnotification/inbox', 'notification_id'); 00040 } 00041 00042 public function loadLatestNotice(Mage_AdminNotification_Model_Inbox $object) 00043 { 00044 $select = $this->_getReadAdapter()->select() 00045 ->from($this->getMainTable()) 00046 ->order($this->getIdFieldName() . ' desc') 00047 ->where('is_read <> 1') 00048 ->where('is_remove <> 1') 00049 ->limit(1); 00050 $data = $this->_getReadAdapter()->fetchRow($select); 00051 00052 if ($data) { 00053 $object->setData($data); 00054 } 00055 00056 $this->_afterLoad($object); 00057 00058 return $this; 00059 } 00060 00061 public function getNoticeStatus(Mage_AdminNotification_Model_Inbox $object) 00062 { 00063 $select = $this->_getReadAdapter()->select() 00064 ->from($this->getMainTable(), array( 00065 'severity' => 'severity', 00066 'count_notice' => 'COUNT(' . $this->getIdFieldName() . ')')) 00067 ->group('severity') 00068 ->where('is_remove=?', 0) 00069 ->where('is_read=?', 0); 00070 $return = array(); 00071 $rowSet = $this->_getReadAdapter()->fetchAll($select); 00072 foreach ($rowSet as $row) { 00073 $return[$row['severity']] = $row['count_notice']; 00074 } 00075 return $return; 00076 } 00077 00078 public function parse(Mage_AdminNotification_Model_Inbox $object, array $data) 00079 { 00080 $write = $this->_getWriteAdapter(); 00081 foreach ($data as $item) { 00082 $select = $write->select() 00083 ->from($this->getMainTable()) 00084 ->where('url=?', $item['url']); 00085 $row = $write->fetchRow($select); 00086 00087 if (!$row) { 00088 $write->insert($this->getMainTable(), $item); 00089 } 00090 } 00091 } 00092 }