123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\SalesRule\Model\ResourceModel\Coupon;
- /**
- * SalesRule Model Resource Coupon_Usage
- *
- * @author Magento Core Team <core@magentocommerce.com>
- */
- class Usage extends \Magento\Framework\Model\ResourceModel\Db\AbstractDb
- {
- /**
- * Constructor
- *
- * @return void
- */
- protected function _construct()
- {
- $this->_init('salesrule_coupon_usage', 'coupon_id');
- }
- /**
- * Increment times_used counter
- *
- * @param int $customerId
- * @param mixed $couponId
- * @return void
- */
- public function updateCustomerCouponTimesUsed($customerId, $couponId)
- {
- $connection = $this->getConnection();
- $select = $connection->select();
- $select->from(
- $this->getMainTable(),
- ['times_used']
- )->where(
- 'coupon_id = :coupon_id'
- )->where(
- 'customer_id = :customer_id'
- );
- $timesUsed = $connection->fetchOne($select, [':coupon_id' => $couponId, ':customer_id' => $customerId]);
- if ($timesUsed > 0) {
- $this->getConnection()->update(
- $this->getMainTable(),
- ['times_used' => $timesUsed + 1],
- ['coupon_id = ?' => $couponId, 'customer_id = ?' => $customerId]
- );
- } else {
- $this->getConnection()->insert(
- $this->getMainTable(),
- ['coupon_id' => $couponId, 'customer_id' => $customerId, 'times_used' => 1]
- );
- }
- }
- /**
- * Load an object by customer_id & coupon_id
- *
- * @param \Magento\Framework\DataObject $object
- * @param int $customerId
- * @param mixed $couponId
- * @return $this
- */
- public function loadByCustomerCoupon(\Magento\Framework\DataObject $object, $customerId, $couponId)
- {
- $connection = $this->getConnection();
- if ($connection && $couponId && $customerId) {
- $select = $connection->select()->from(
- $this->getMainTable()
- )->where(
- 'customer_id =:customer_id'
- )->where(
- 'coupon_id = :coupon_id'
- );
- $data = $connection->fetchRow($select, [':coupon_id' => $couponId, ':customer_id' => $customerId]);
- if ($data) {
- $object->setData($data);
- }
- }
- if ($object instanceof \Magento\Framework\Model\AbstractModel) {
- $this->_afterLoad($object);
- }
- return $this;
- }
- }
|