Overview

Packages

  • currencysymbol
  • MAbout
  • Mage
    • Admin
    • Adminhtml
    • AdminNotification
    • Api
    • Api2
    • Authorizenet
    • Backup
    • Bundle
    • Captcha
    • Catalog
    • CatalogIndex
    • CatalogInventory
    • CatalogRule
    • CatalogSearch
    • Centinel
    • Checkout
    • Cms
    • Compiler
    • Connect
    • Contacts
    • Core
    • Cron
    • CurrencySymbol
    • Customer
    • Dataflow
    • Directory
    • DirtectPost
    • Downloadable
    • Eav
    • GiftMessage
    • GoogleAnalytics
    • GoogleBase
    • GoogleCheckout
    • ImportExport
    • Index
    • Install
    • Log
    • Media
    • Newsletter
    • Oauth
    • Page
    • PageCache
    • Paygate
    • Payment
    • Paypal
    • PaypalUk
    • Persistent
    • Poll
    • ProductAlert
    • Rating
    • Reports
    • Review
    • Rss
    • Rule
    • Sales
    • SalesRule
    • Sedfriend
    • Sendfriend
    • Shipping
    • Sitemap
    • Tag
    • Tax
    • Usa
    • Weee
    • Widget
    • Wishlist
    • XmlConnect
  • None
  • Phoenix
    • Moneybookers
  • PHP
  • Zend
    • Date
    • Mime
    • XmlRpc

Classes

  • Mage_Newsletter_Block_Subscribe
  • Mage_Newsletter_Helper_Data
  • Mage_Newsletter_ManageController
  • Mage_Newsletter_Model_Message
  • Mage_Newsletter_Model_Mysql4_Problem
  • Mage_Newsletter_Model_Mysql4_Problem_Collection
  • Mage_Newsletter_Model_Mysql4_Queue
  • Mage_Newsletter_Model_Mysql4_Queue_Collection
  • Mage_Newsletter_Model_Mysql4_Subscriber
  • Mage_Newsletter_Model_Mysql4_Subscriber_Collection
  • Mage_Newsletter_Model_Mysql4_Template
  • Mage_Newsletter_Model_Mysql4_Template_Collection
  • Mage_Newsletter_Model_Observer
  • Mage_Newsletter_Model_Problem
  • Mage_Newsletter_Model_Queue
  • Mage_Newsletter_Model_Resource_Problem
  • Mage_Newsletter_Model_Resource_Problem_Collection
  • Mage_Newsletter_Model_Resource_Queue
  • Mage_Newsletter_Model_Resource_Queue_Collection
  • Mage_Newsletter_Model_Resource_Subscriber
  • Mage_Newsletter_Model_Resource_Subscriber_Collection
  • Mage_Newsletter_Model_Resource_Template
  • Mage_Newsletter_Model_Resource_Template_Collection
  • Mage_Newsletter_Model_Session
  • Mage_Newsletter_Model_Subscriber
  • Mage_Newsletter_Model_Template
  • Mage_Newsletter_Model_Template_Filter
  • Mage_Newsletter_SubscriberController
  • Overview
  • Package
  • Class
  • Tree
  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_Newsletter
 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: 
 28: /**
 29:  * Newsletter queue resource model
 30:  *
 31:  * @category    Mage
 32:  * @package     Mage_Newsletter
 33:  * @author      Magento Core Team <core@magentocommerce.com>
 34:  */
 35: class Mage_Newsletter_Model_Resource_Queue extends Mage_Core_Model_Resource_Db_Abstract
 36: {
 37:     /**
 38:      * Define main table
 39:      *
 40:      */
 41:     protected function _construct()
 42:     {
 43:         $this->_init('newsletter/queue', 'queue_id');
 44:     }
 45: 
 46:     /**
 47:      * Add subscribers to queue
 48:      *
 49:      * @param Mage_Newsletter_Model_Queue $queue
 50:      * @param array $subscriberIds
 51:      */
 52:     public function addSubscribersToQueue(Mage_Newsletter_Model_Queue $queue, array $subscriberIds)
 53:     {
 54:         if (count($subscriberIds)==0) {
 55:             Mage::throwException(Mage::helper('newsletter')->__('No subscribers selected.'));
 56:         }
 57: 
 58:         if (!$queue->getId() && $queue->getQueueStatus()!=Mage_Newsletter_Model_Queue::STATUS_NEVER) {
 59:             Mage::throwException(Mage::helper('newsletter')->__('Invalid queue selected.'));
 60:         }
 61: 
 62:         $adapter = $this->_getWriteAdapter();
 63: 
 64:         $select = $adapter->select();
 65:         $select->from($this->getTable('newsletter/queue_link'), 'subscriber_id')
 66:             ->where('queue_id = ?', $queue->getId())
 67:             ->where('subscriber_id in (?)', $subscriberIds);
 68: 
 69:         $usedIds = $adapter->fetchCol($select);
 70:         $adapter->beginTransaction();
 71:         try {
 72:             foreach ($subscriberIds as $subscriberId) {
 73:                 if (in_array($subscriberId, $usedIds)) {
 74:                     continue;
 75:                 }
 76:                 $data = array();
 77:                 $data['queue_id'] = $queue->getId();
 78:                 $data['subscriber_id'] = $subscriberId;
 79:                 $adapter->insert($this->getTable('newsletter/queue_link'), $data);
 80:             }
 81:             $adapter->commit();
 82:         }
 83:         catch (Exception $e) {
 84:             $adapter->rollBack();
 85:         }
 86:     }
 87: 
 88:     /**
 89:      * Removes subscriber from queue
 90:      *
 91:      * @param Mage_Newsletter_Model_Queue $queue
 92:      */
 93:     public function removeSubscribersFromQueue(Mage_Newsletter_Model_Queue $queue)
 94:     {
 95:         $adapter = $this->_getWriteAdapter();
 96:         try {
 97:             $adapter->delete(
 98:                 $this->getTable('newsletter/queue_link'),
 99:                 array(
100:                     'queue_id = ?' => $queue->getId(),
101:                     'letter_sent_at IS NULL'
102:                 )
103:             );
104: 
105:             $adapter->commit();
106:         }
107:         catch (Exception $e) {
108:             $adapter->rollBack();
109:         }
110:     }
111: 
112:     /**
113:      * Links queue to store
114:      *
115:      * @param Mage_Newsletter_Model_Queue $queue
116:      * @return Mage_Newsletter_Model_Resource_Queue
117:      */
118:     public function setStores(Mage_Newsletter_Model_Queue $queue)
119:     {
120:         $adapter = $this->_getWriteAdapter();
121:         $adapter->delete(
122:             $this->getTable('newsletter/queue_store_link'),
123:             array('queue_id = ?' => $queue->getId())
124:         );
125: 
126:         $stores = $queue->getStores();
127:         if (!is_array($stores)) {
128:             $stores = array();
129:         }
130: 
131:         foreach ($stores as $storeId) {
132:             $data = array();
133:             $data['store_id'] = $storeId;
134:             $data['queue_id'] = $queue->getId();
135:             $adapter->insert($this->getTable('newsletter/queue_store_link'), $data);
136:         }
137:         $this->removeSubscribersFromQueue($queue);
138: 
139:         if (count($stores) == 0) {
140:             return $this;
141:         }
142: 
143:         $subscribers = Mage::getResourceSingleton('newsletter/subscriber_collection')
144:             ->addFieldToFilter('store_id', array('in'=>$stores))
145:             ->useOnlySubscribed()
146:             ->load();
147: 
148:         $subscriberIds = array();
149: 
150:         foreach ($subscribers as $subscriber) {
151:             $subscriberIds[] = $subscriber->getId();
152:         }
153: 
154:         if (count($subscriberIds) > 0) {
155:             $this->addSubscribersToQueue($queue, $subscriberIds);
156:         }
157: 
158:         return $this;
159:     }
160: 
161:     /**
162:      * Returns queue linked stores
163:      *
164:      * @param Mage_Newsletter_Model_Queue $queue
165:      * @return array
166:      */
167:     public function getStores(Mage_Newsletter_Model_Queue $queue)
168:     {
169:         $adapter = $this->_getReadAdapter();
170:         $select = $adapter->select()->from($this->getTable('newsletter/queue_store_link'), 'store_id')
171:             ->where('queue_id = :queue_id');
172: 
173:         if (!($result = $adapter->fetchCol($select, array('queue_id'=>$queue->getId())))) {
174:             $result = array();
175:         }
176: 
177:         return $result;
178:     }
179: 
180:     /**
181:      * Saving template after saving queue action
182:      *
183:      * @param Mage_Core_Model_Abstract $queue
184:      * @return Mage_Newsletter_Model_Resource_Queue
185:      */
186:     protected function _afterSave(Mage_Core_Model_Abstract $queue)
187:     {
188:         if ($queue->getSaveStoresFlag()) {
189:             $this->setStores($queue);
190:         }
191:         return $this;
192:     }
193: }
194: 
Magento 1.7.0.2 API documentation generated by ApiGen 2.8.0