![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/laminas/laminas-db/src/Adapter/Driver/Sqlsrv/ |
<?php namespace Laminas\Db\Adapter\Driver\Sqlsrv; use Laminas\Db\Adapter\Driver\StatementInterface; use Laminas\Db\Adapter\Exception; use Laminas\Db\Adapter\ParameterContainer; use Laminas\Db\Adapter\Profiler; use function get_resource_type; use function is_array; use function sqlsrv_errors; use function sqlsrv_execute; use function sqlsrv_prepare; use function substr_count; use const SQLSRV_PARAM_IN; class Statement implements StatementInterface, Profiler\ProfilerAwareInterface { /** @var resource */ protected $sqlsrv; /** @var Sqlsrv */ protected $driver; /** @var Profiler\ProfilerInterface */ protected $profiler; /** @var string */ protected $sql; /** @var bool */ protected $isQuery; /** @var array */ protected $parameterReferences = []; /** @var ParameterContainer */ protected $parameterContainer; /** @var resource */ protected $resource; /** @var bool */ protected $isPrepared = false; /** @var array */ protected $prepareParams = []; /** @var array */ protected $prepareOptions = []; /** @var array */ protected $parameterReferenceValues = []; /** * Set driver * * @return $this Provides a fluent interface */ public function setDriver(Sqlsrv $driver) { $this->driver = $driver; return $this; } /** * @return $this Provides a fluent interface */ public function setProfiler(Profiler\ProfilerInterface $profiler) { $this->profiler = $profiler; return $this; } /** * @return null|Profiler\ProfilerInterface */ public function getProfiler() { return $this->profiler; } /** * One of two resource types will be provided here: * a) "SQL Server Connection" when a prepared statement needs to still be produced * b) "SQL Server Statement" when a prepared statement has been already produced * (there will need to already be a bound param set if it applies to this query) * * @param resource $resource * @return $this Provides a fluent interface * @throws Exception\InvalidArgumentException */ public function initialize($resource) { $resourceType = get_resource_type($resource); if ($resourceType === 'SQL Server Connection') { $this->sqlsrv = $resource; } elseif ($resourceType === 'SQL Server Statement') { $this->resource = $resource; $this->isPrepared = true; } else { throw new Exception\InvalidArgumentException('Invalid resource provided to ' . self::class); } return $this; } /** * Set parameter container * * @return $this Provides a fluent interface */ public function setParameterContainer(ParameterContainer $parameterContainer) { $this->parameterContainer = $parameterContainer; return $this; } /** * @return ParameterContainer */ public function getParameterContainer() { return $this->parameterContainer; } /** * @param resource $resource * @return $this Provides a fluent interface */ public function setResource($resource) { $this->resource = $resource; return $this; } /** * Get resource * * @return resource */ public function getResource() { return $this->resource; } /** * @param string $sql * @return $this Provides a fluent interface */ public function setSql($sql) { $this->sql = $sql; return $this; } /** * Get sql * * @return string */ public function getSql() { return $this->sql; } /** * @param string $sql * @param array $options * @return $this Provides a fluent interface * @throws Exception\RuntimeException */ public function prepare($sql = null, array $options = []) { if ($this->isPrepared) { throw new Exception\RuntimeException('Already prepared'); } $sql = $sql ?: $this->sql; $options = $options ?: $this->prepareOptions; $pRef = &$this->parameterReferences; for ($position = 0, $count = substr_count($sql, '?'); $position < $count; $position++) { if (! isset($this->prepareParams[$position])) { $pRef[$position] = [&$this->parameterReferenceValues[$position], SQLSRV_PARAM_IN, null, null]; } else { $pRef[$position] = &$this->prepareParams[$position]; } } $this->resource = sqlsrv_prepare($this->sqlsrv, $sql, $pRef, $options); $this->isPrepared = true; return $this; } /** * @return bool */ public function isPrepared() { return $this->isPrepared; } /** * Execute * * @param null|array|ParameterContainer $parameters * @throws Exception\RuntimeException * @return Result */ public function execute($parameters = null) { /** END Standard ParameterContainer Merging Block */ if (! $this->isPrepared) { $this->prepare(); } /** START Standard ParameterContainer Merging Block */ if (! $this->parameterContainer instanceof ParameterContainer) { if ($parameters instanceof ParameterContainer) { $this->parameterContainer = $parameters; $parameters = null; } else { $this->parameterContainer = new ParameterContainer(); } } if (is_array($parameters)) { $this->parameterContainer->setFromArray($parameters); } if ($this->parameterContainer->count() > 0) { $this->bindParametersFromContainer(); } if ($this->profiler) { $this->profiler->profilerStart($this); } $resultValue = sqlsrv_execute($this->resource); if ($this->profiler) { $this->profiler->profilerFinish(); } if ($resultValue === false) { $errors = sqlsrv_errors(); // ignore general warnings if ($errors[0]['SQLSTATE'] !== '01000') { throw new Exception\RuntimeException($errors[0]['message']); } } return $this->driver->createResult($this->resource); } /** * Bind parameters from container */ protected function bindParametersFromContainer() { $values = $this->parameterContainer->getPositionalArray(); $position = 0; foreach ($values as $value) { $this->parameterReferences[$position++][0] = $value; } } /** * @param array $prepareParams */ public function setPrepareParams(array $prepareParams) { $this->prepareParams = $prepareParams; } /** * @param array $prepareOptions */ public function setPrepareOptions(array $prepareOptions) { $this->prepareOptions = $prepareOptions; } }