Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bitrix/ext_www/cvetdv.ru/bitrix/modules/sale/lib/controller/ |
Upload File : |
<?php namespace Bitrix\Sale\Controller; use Bitrix\Main\Engine\Response\DataType\Page; use Bitrix\Main\Error; use Bitrix\Main\UI\PageNavigation; use Bitrix\Sale\Internals\OrderPropsRelationTable; use Bitrix\Sale\Result; class PropertyRelation extends ControllerBase { //region Actions public function getFieldsAction() { $view = $this->getViewManager() ->getView($this); return ['PROPERTY_RELATION'=>$view->prepareFieldInfos( $view->getFields() )]; } public function addAction(array $fields) { $r = new Result(); $res = $this->existsByFilter([ 'PROPERTY_ID'=>$fields['PROPERTY_ID'], 'ENTITY_ID'=>$fields['ENTITY_ID'], 'ENTITY_TYPE'=>$fields['ENTITY_TYPE'] ]); if($res->isSuccess() == false) { $r = $this->existsProperty($fields['PROPERTY_ID']); if($r->isSuccess()) { $r = $this->getEntityTable() ->add($fields); } } else { $r->addError(new Error('Duplicate entry for key [propertyId, entityId, entityType]', 201650000001)); } if(!$r->isSuccess()) { $this->addErrors($r->getErrors()); return null; } else { return [ 'PROPERTY_RELATION'=> $this->getEntityTable()::getList([ 'filter'=>[ 'PROPERTY_ID'=>$fields['PROPERTY_ID'], 'ENTITY_ID'=>$fields['ENTITY_ID'], 'ENTITY_TYPE'=>$fields['ENTITY_TYPE'] ] ])->fetchAll()[0] ]; } } public function deleteByFilterAction($fields) { $r = $this->checkFields($fields); if($r->isSuccess()) { $r = $this->existsByFilter($fields); if($r->isSuccess()) { $r = $this->getEntityTable() ->delete($fields); } } if($r->isSuccess()) { return true; } else { $this->addErrors($r->getErrors()); return null; } } public function listAction(PageNavigation $pageNavigation, array $select = [], array $filter = [], array $order = []): Page { $select = empty($select) ? ['*']:$select; $order = empty($order) ? ['PROPERTY_ID'=>'ASC']:$order; $items = $this->getEntityTable()::getList( [ 'select' => $select, 'filter' => $filter, 'order' => $order, 'offset' => $pageNavigation->getOffset(), 'limit' => $pageNavigation->getLimit(), ] )->fetchAll(); return new Page('PROPERTY_RELATIONS', $items, function() use ($filter) { return $this->getEntityTable()::getCount([$filter]); }); } //endregion protected function getEntityTable(): OrderPropsRelationTable { return new OrderPropsRelationTable(); } protected function existsByFilter($filter) { $r = new Result(); $row = $this->getEntityTable()::getList(['filter'=>['PROPERTY_ID'=>$filter['PROPERTY_ID'], 'ENTITY_ID'=>$filter['ENTITY_ID'], 'ENTITY_TYPE'=>$filter['ENTITY_TYPE']]])->fetchAll(); if(isset($row[0]['PROPERTY_ID']) == false) $r->addError(new Error('property relation is not exists', 201640400004)); return $r; } protected function checkFields($fields) { $r = new Result(); if(isset($fields['PROPERTY_ID']) == false && $fields['PROPERTY_ID'] <> '') $r->addError(new Error('propertyId - parametrs is empty', 201640400001)); if(isset($fields['ENTITY_ID']) == false && $fields['ENTITY_ID'] <> '') $r->addError(new Error('propertyId - parametrs is empty', 201640400002)); if(isset($fields['ENTITY_TYPE']) == false && $fields['ENTITY_TYPE'] <> '') $r->addError(new Error('propertyId - parametrs is empty', 201640400003)); return $r; } protected function checkPermissionEntity($name, $arguments=[]) { if($name == 'deletebyfilter') { $r = $this->checkReadPermissionEntity(); } else { $r = parent::checkPermissionEntity($name); } return $r; } protected function existsProperty($id) { $r = new Result(); $property = \Bitrix\Sale\Internals\OrderPropsTable::getRow([ 'filter' => [ '=ID' => $id ] ]); if(is_null($property)) $r->addError(new Error('property id is not exists', 201650000002)); return $r; } protected function checkModifyPermissionEntity(): Result { $r = new Result(); $saleModulePermissions = self::getApplication()->GetGroupRight("sale"); if ($saleModulePermissions < "W") { $r->addError(new Error('Access Denied', 200040300020)); } return $r; } protected function checkReadPermissionEntity(): Result { $r = new Result(); $saleModulePermissions = self::getApplication()->GetGroupRight("sale"); if ($saleModulePermissions == "D") { $r->addError(new Error('Access Denied', 200040300010)); } return $r; } }