![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/module-reports/Model/ResourceModel/Event/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ /** * Report event collection * * @author Magento Core Team <[email protected]> */ namespace Magento\Reports\Model\ResourceModel\Event; /** * @api * @since 100.0.2 */ class Collection extends \Magento\Framework\Model\ResourceModel\Db\Collection\AbstractCollection { /** * Store Ids * * @var array */ protected $_storeIds; /** * Resource initializations * * @return void */ protected function _construct() { $this->_init(\Magento\Reports\Model\Event::class, \Magento\Reports\Model\ResourceModel\Event::class); } /** * Add store ids filter * @codeCoverageIgnore * * @param array $storeIds * @return $this */ public function addStoreFilter(array $storeIds) { $this->_storeIds = $storeIds; return $this; } /** * Add recently filter * * @param int $typeId * @param int $subjectId * @param int $subtype * @param null|int|array $ignore * @param int $limit * @return $this */ public function addRecentlyFiler($typeId, $subjectId, $subtype = 0, $ignore = null, $limit = 15) { $stores = $this->getResource()->getCurrentStoreIds($this->_storeIds); $select = $this->getSelect(); $select->where( 'event_type_id = ?', $typeId )->where( 'subject_id = ?', $subjectId )->where( 'subtype = ?', $subtype )->where( 'store_id IN(?)', $stores ); if ($ignore) { if (is_array($ignore)) { $select->where('object_id NOT IN(?)', $ignore); } else { $select->where('object_id <> ?', $ignore); } } $select->group('object_id')->limit($limit); return $this; } }