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 subscribers collection
 30:  *
 31:  * @category    Mage
 32:  * @package     Mage_Newsletter
 33:  * @author      Magento Core Team <core@magentocommerce.com>
 34:  */
 35: class Mage_Newsletter_Model_Resource_Subscriber_Collection extends Mage_Core_Model_Resource_Db_Collection_Abstract
 36: {
 37: 
 38:     /**
 39:      * Queue link table name
 40:      *
 41:      * @var string
 42:      */
 43:     protected $_queueLinkTable;
 44: 
 45:     /**
 46:      * Store table name
 47:      *
 48:      * @var string
 49:      */
 50:     protected $_storeTable;
 51: 
 52:     /**
 53:      * Queue joined flag
 54:      *
 55:      * @var boolean
 56:      */
 57:     protected $_queueJoinedFlag    = false;
 58: 
 59:     /**
 60:      * Flag that indicates apply of customers info on load
 61:      *
 62:      * @var boolean
 63:      */
 64:     protected $_showCustomersInfo  = false;
 65: 
 66:     /**
 67:      * Filter for count
 68:      *
 69:      * @var array
 70:      */
 71:     protected $_countFilterPart    = array();
 72: 
 73:     /**
 74:      * Constructor
 75:      * Configures collection
 76:      *
 77:      */
 78:     protected function _construct()
 79:     {
 80:         parent::_construct();
 81:         $this->_init('newsletter/subscriber');
 82:         $this->_queueLinkTable = $this->getTable('newsletter/queue_link');
 83:         $this->_storeTable = $this->getTable('core/store');
 84: 
 85: 
 86:         // defining mapping for fields represented in several tables
 87:         $this->_map['fields']['customer_lastname'] = 'customer_lastname_table.value';
 88:         $this->_map['fields']['customer_firstname'] = 'customer_firstname_table.value';
 89:         $this->_map['fields']['type'] = $this->getResource()->getReadConnection()
 90:             ->getCheckSql('main_table.customer_id = 0', 1, 2);
 91:         $this->_map['fields']['website_id'] = 'store.website_id';
 92:         $this->_map['fields']['group_id'] = 'store.group_id';
 93:         $this->_map['fields']['store_id'] = 'main_table.store_id';
 94:     }
 95: 
 96:     /**
 97:      * Set loading mode subscribers by queue
 98:      *
 99:      * @param Mage_Newsletter_Model_Queue $queue
100:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
101:      */
102:     public function useQueue(Mage_Newsletter_Model_Queue $queue)
103:     {
104:         $this->getSelect()
105:             ->join(array('link'=>$this->_queueLinkTable), "link.subscriber_id = main_table.subscriber_id", array())
106:             ->where("link.queue_id = ? ", $queue->getId());
107:         $this->_queueJoinedFlag = true;
108:         return $this;
109:     }
110: 
111:     /**
112:      * Set using of links to only unsendet letter subscribers.
113:      *
114:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
115:      */
116:     public function useOnlyUnsent()
117:     {
118:         if ($this->_queueJoinedFlag) {
119:             $this->addFieldToFilter('link.letter_sent_at', array('null' => 1));
120:         }
121: 
122:         return $this;
123:     }
124: 
125:     /**
126:      * Adds customer info to select
127:      *
128:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
129:      */
130:     public function showCustomerInfo()
131:     {
132:         $adapter = $this->getConnection();
133:         $customer = Mage::getModel('customer/customer');
134:         $firstname  = $customer->getAttribute('firstname');
135:         $lastname   = $customer->getAttribute('lastname');
136: 
137:         $this->getSelect()
138:             ->joinLeft(
139:                 array('customer_lastname_table'=>$lastname->getBackend()->getTable()),
140:                 $adapter->quoteInto('customer_lastname_table.entity_id=main_table.customer_id
141:                  AND customer_lastname_table.attribute_id = ?', (int)$lastname->getAttributeId()),
142:                 array('customer_lastname'=>'value')
143:             )
144:             ->joinLeft(
145:                 array('customer_firstname_table'=>$firstname->getBackend()->getTable()),
146:                 $adapter->quoteInto('customer_firstname_table.entity_id=main_table.customer_id
147:                  AND customer_firstname_table.attribute_id = ?', (int)$firstname->getAttributeId()),
148:                 array('customer_firstname'=>'value')
149:             );
150: 
151:         return $this;
152:     }
153: 
154:     /**
155:      * Add type field expression to select
156:      *
157:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
158:      */
159:     public function addSubscriberTypeField()
160:     {
161:         $this->getSelect()
162:             ->columns(array('type'=>new Zend_Db_Expr($this->_getMappedField('type'))));
163:         return $this;
164:     }
165: 
166:     /**
167:      * Sets flag for customer info loading on load
168:      *
169:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
170:      */
171:     public function showStoreInfo()
172:     {
173:         $this->getSelect()->join(
174:             array('store' => $this->_storeTable),
175:             'store.store_id = main_table.store_id',
176:             array('group_id', 'website_id')
177:         );
178: 
179:         return $this;
180:     }
181: 
182:     /**
183:      * Returns field table alias
184:      *
185:      * @deprecated after 1.4.0.0-rc1
186:      *
187:      * @param string $field
188:      * @return string
189:      */
190:     public function _getFieldTableAlias($field)
191:     {
192:         if (strpos($field, 'customer') === 0) {
193:            return $field .'_table.value';
194:         }
195: 
196:         if ($field == 'type') {
197:             return $this->getConnection()->getCheckSql('main_table.customer_id = 0', 1, 2);
198:         }
199: 
200:         if (in_array($field, array('website_id', 'group_id'))) {
201:             return 'store.' . $field;
202:         }
203: 
204:         return 'main_table.' . $field;
205:     }
206: 
207:     /**
208:      * Returns select count sql
209:      *
210:      * @return string
211:      */
212:     public function getSelectCountSql()
213:     {
214: 
215:         $select = parent::getSelectCountSql();
216:         $countSelect = clone $this->getSelect();
217: 
218:         $countSelect->reset(Zend_Db_Select::HAVING);
219: 
220:         return $select;
221:     }
222: 
223:     /**
224:      * Load only subscribed customers
225:      *
226:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
227:      */
228:     public function useOnlyCustomers()
229:     {
230:         $this->addFieldToFilter('main_table.customer_id', array('gt' => 0));
231: 
232:         return $this;
233:     }
234: 
235:     /**
236:      * Show only with subscribed status
237:      *
238:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
239:      */
240:     public function useOnlySubscribed()
241:     {
242:         $this->addFieldToFilter('main_table.subscriber_status', Mage_Newsletter_Model_Subscriber::STATUS_SUBSCRIBED);
243: 
244:         return $this;
245:     }
246: 
247:     /**
248:      * Filter collection by specified store ids
249:      *
250:      * @param array|int $storeIds
251:      * @return Mage_Newsletter_Model_Resource_Subscriber_Collection
252:      */
253:     public function addStoreFilter($storeIds)
254:     {
255:         $this->addFieldToFilter('main_table.store_id', array('in'=>$storeIds));
256:         return $this;
257:     }
258: }
259: 
Magento 1.7.0.2 API documentation generated by ApiGen 2.8.0