%PDF- %PDF-
Server IP : 37.220.80.31 / Your IP : 3.16.218.216 Web Server : Apache/2.4.52 (Ubuntu) System : Linux 3051455-guretool.twc1.net 5.15.0-107-generic #117-Ubuntu SMP Fri Apr 26 12:26:49 UTC 2024 x86_64 User : www-root ( 1010) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /var/www/www-root/data/www/dev.artlot24.ru/bitrix/modules/sale/lib/internals/ |
Upload File : |
<?php namespace Bitrix\Sale\Internals; use Bitrix\Main; use Bitrix\Main\Application; use Bitrix\Main\Localization\Loc; Loc::loadMessages(__FILE__); /** * Class DiscountEntitiesTable * * Fields: * <ul> * <li> ID int mandatory * <li> DISCOUNT_ID int mandatory * <li> MODULE_ID string(50) mandatory * <li> ENTITY string(255) mandatory * <li> FIELD_ENTITY string(255) mandatory * <li> FIELD_TABLE string(255) mandatory * </ul> * * @package Bitrix\Sale\Internals * * DO NOT WRITE ANYTHING BELOW THIS * * <<< ORMENTITYANNOTATION * @method static EO_DiscountEntities_Query query() * @method static EO_DiscountEntities_Result getByPrimary($primary, array $parameters = array()) * @method static EO_DiscountEntities_Result getById($id) * @method static EO_DiscountEntities_Result getList(array $parameters = array()) * @method static EO_DiscountEntities_Entity getEntity() * @method static \Bitrix\Sale\Internals\EO_DiscountEntities createObject($setDefaultValues = true) * @method static \Bitrix\Sale\Internals\EO_DiscountEntities_Collection createCollection() * @method static \Bitrix\Sale\Internals\EO_DiscountEntities wakeUpObject($row) * @method static \Bitrix\Sale\Internals\EO_DiscountEntities_Collection wakeUpCollection($rows) */ class DiscountEntitiesTable extends Main\Entity\DataManager { /** * Returns DB table name for entity. * * @return string */ public static function getTableName() { return 'b_sale_discount_entities'; } /** * Returns entity map definition. * * @return array */ public static function getMap() { return array( 'ID' => new Main\Entity\IntegerField('ID', array( 'primary' => true, 'autocomplete' => true, 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_ID_FIELD') )), 'DISCOUNT_ID' => new Main\Entity\IntegerField('DISCOUNT_ID', array( 'required' => true, 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_DISCOUNT_ID_FIELD') )), 'MODULE_ID' => new Main\Entity\StringField('MODULE_ID', array( 'required' => true, 'validation' => array(__CLASS__, 'validateModuleId'), 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_MODULE_ID_FIELD') )), 'ENTITY' => new Main\Entity\StringField('ENTITY', array( 'required' => true, 'validation' => array(__CLASS__, 'validateEntity'), 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_ENTITY_FIELD') )), 'FIELD_ENTITY' => new Main\Entity\StringField('FIELD_ENTITY', array( 'required' => true, 'validation' => array(__CLASS__, 'validateFieldEntity'), 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_FIELD_ENTITY_FIELD') )), 'FIELD_TABLE' => new Main\Entity\StringField('FIELD_TABLE', array( 'required' => true, 'validation' => array(__CLASS__, 'validateFieldTable'), 'title' => Loc::getMessage('DISCOUNT_ENTITIES_ENTITY_FIELD_TABLE_FIELD'), )), 'DISCOUNT' => new Main\Entity\ReferenceField( 'DISCOUNT', 'Bitrix\Sale\Internals\Discount', array('=this.DISCOUNT_ID' => 'ref.ID'), array('join_type' => 'LEFT') ) ); } /** * Returns validators for MODULE_ID field. * * @return array */ public static function validateModuleId() { return array( new Main\Entity\Validator\Length(null, 50), ); } /** * Returns validators for ENTITY field. * * @return array */ public static function validateEntity() { return array( new Main\Entity\Validator\Length(null, 255), ); } /** * Returns validators for FIELD_ENTITY field. * * @return array */ public static function validateFieldEntity() { return array( new Main\Entity\Validator\Length(null, 255), ); } /** * Returns validators for FIELD_TABLE field. * * @return array */ public static function validateFieldTable() { return array( new Main\Entity\Validator\Length(null, 255), ); } /** * Delete entity list by discount. * * @param int $discount Discount id. * @return void */ public static function deleteByDiscount($discount) { $discount = (int)$discount; if ($discount <= 0) return; $conn = Application::getConnection(); $helper = $conn->getSqlHelper(); $conn->queryExecute( 'delete from '.$helper->quote(self::getTableName()).' where '.$helper->quote('DISCOUNT_ID').' = '.$discount ); } /** * Update entity list by discount. * * @param int $discount Discount id. * @param array $entityList Discount entity list. * @param bool $clear Clear old values. * @return bool */ public static function updateByDiscount($discount, $entityList, $clear) { $discount = (int)$discount; if ($discount <= 0) return false; $clear = ($clear === true); if ($clear) { self::deleteByDiscount($discount); } if (!empty($entityList) && is_array($entityList)) { foreach ($entityList as &$entity) { $fields = array( 'DISCOUNT_ID' => $discount, 'MODULE_ID' => $entity['MODULE'], 'ENTITY' => $entity['ENTITY'], 'FIELD_ENTITY' => $entity['FIELD_ENTITY'], ); if (is_array($fields['FIELD_ENTITY'])) $fields['FIELD_ENTITY'] = implode('-', $fields['FIELD_ENTITY']); if (isset($entity['FIELD_TABLE']) && is_array($entity['FIELD_TABLE'])) { foreach ($entity['FIELD_TABLE'] as $oneField) { if (empty($oneField)) continue; $fields['FIELD_TABLE'] = $oneField; $result = self::add($fields); } unset($oneField); } else { $fields['FIELD_TABLE'] = (isset($entity['FIELD_TABLE']) ? $entity['FIELD_TABLE'] : $entity['FIELD_ENTITY']); $result = self::add($fields); } } unset($entity); } return true; } /** * Return entity by discount list. * * @param array $discountList Discount id list. * @param array $filter Additional filter. * @param bool $groupModule Group by modules. * @return array */ public static function getByDiscount($discountList, $filter = array(), $groupModule = true) { $groupModule = ($groupModule === true); $result = array(); if (!empty($discountList) && is_array($discountList)) { Main\Type\Collection::normalizeArrayValuesByInt($discountList); if (!empty($discountList)) { if (!is_array($filter)) $filter = array(); $discountRows = array_chunk($discountList, 500); foreach ($discountRows as &$row) { $filter['@DISCOUNT_ID'] = $row; $entityIterator = self::getList(array( 'select' => array('DISCOUNT_ID', 'MODULE_ID', 'ENTITY', 'FIELD_ENTITY', 'FIELD_TABLE'), 'filter' => $filter )); if ($groupModule) { while ($entity = $entityIterator->fetch()) { unset($entity['DISCOUNT_ID']); if (!isset($result[$entity['MODULE_ID']])) $result[$entity['MODULE_ID']] = array(); if (!isset($result[$entity['MODULE_ID']][$entity['ENTITY']])) $result[$entity['MODULE_ID']][$entity['ENTITY']] = array(); $result[$entity['MODULE_ID']][$entity['ENTITY']][$entity['FIELD_ENTITY']] = $entity; } } else { while ($entity = $entityIterator->fetch()) { $entity['DISCOUNT_ID'] = (int)$entity['DISCOUNT_ID']; if (!isset($result[$entity['DISCOUNT_ID']])) $result[$entity['DISCOUNT_ID']] = array(); $result[$entity['DISCOUNT_ID']][] = $entity; } } unset($entity, $entityIterator); } unset($row, $discountRows); } } return $result; } }