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/rospirotorg.ru/bitrix/modules/main/lib/data/ |
Upload File : |
<?php /** * Bitrix Framework * @package bitrix * @subpackage main * @copyright 2001-2013 Bitrix */ namespace Bitrix\Main\Data; /** * Class description * @package bitrix * @subpackage main */ class HsphpReadConnection extends NosqlConnection implements \Bitrix\Main\ORM\Query\INosqlPrimarySelector { protected $host = 'localhost'; protected $port = '9998'; public function __construct(array $configuration) { parent::__construct($configuration); // host validation if (array_key_exists('host', $configuration)) { if (!is_string($configuration['host']) || $configuration['host'] == "") { throw new \Bitrix\Main\Config\ConfigurationException("Invalid host parameter"); } $this->host = $configuration['host']; } // port validation if (array_key_exists('port', $configuration)) { if (!is_string($configuration['port']) || $configuration['port'] == "") { throw new \Bitrix\Main\Config\ConfigurationException("Invalid port parameter"); } $this->port = $configuration['port']; } } protected function connectInternal() { if ($this->isConnected) { return; } $this->resource = new \HSPHP\ReadSocket(); $this->resource->connect($this->host, $this->port); $this->isConnected = true; } protected function disconnectInternal() { } public function get($key) { return null; } public function set($key, $value) { return null; } public function getEntityByPrimary(\Bitrix\Main\ORM\Entity $entity, $primary, $select) { $this->connectInternal(); $table = $entity->getDBTableName(); $sqlConfiguration = $entity->getConnection()->getConfiguration(); $primary = (array) $primary; if (count($primary) > 1) { throw new \Exception('HSPHP Read Socket doesn\'t support multiple select'); } $indexId = $this->resource->getIndexId($sqlConfiguration['database'], $table, '', join(',', (array) $select)); $this->resource->select($indexId, '=', $primary); $response = $this->resource->readResponse(); //foreach $result = array(); if (is_array($response)) { foreach ($response as $row) { $newRow = array(); foreach ($row as $k => $v) { $newRow[$select[$k]] = $v; } $result[] = $newRow; } } return $result; } }