![]() 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/mcoil.corals.io/vendor/doctrine/dbal/src/Driver/PgSQL/ |
<?php declare(strict_types=1); namespace Doctrine\DBAL\Driver\PgSQL; use Doctrine\DBAL\Driver\PgSQL\Exception\UnknownParameter; use Doctrine\DBAL\Driver\Statement as StatementInterface; use Doctrine\DBAL\ParameterType; use PgSql\Connection as PgSqlConnection; use function assert; use function is_resource; use function ksort; use function pg_escape_bytea; use function pg_escape_identifier; use function pg_get_result; use function pg_last_error; use function pg_query; use function pg_result_error; use function pg_send_execute; use function stream_get_contents; final class Statement implements StatementInterface { /** @var array<int, mixed> */ private array $parameters = []; /** @psalm-var array<int, ParameterType> */ private array $parameterTypes = []; /** @param array<array-key, int> $parameterMap */ public function __construct( private readonly PgSqlConnection $connection, private readonly string $name, private readonly array $parameterMap, ) { } public function __destruct() { if (! isset($this->connection)) { return; } @pg_query( $this->connection, 'DEALLOCATE ' . pg_escape_identifier($this->connection, $this->name), ); } /** {@inheritDoc} */ public function bindValue(int|string $param, mixed $value, ParameterType $type = ParameterType::STRING): void { if (! isset($this->parameterMap[$param])) { throw UnknownParameter::new((string) $param); } $this->parameters[$this->parameterMap[$param]] = $value; $this->parameterTypes[$this->parameterMap[$param]] = $type; } /** {@inheritDoc} */ public function execute(): Result { ksort($this->parameters); $escapedParameters = []; foreach ($this->parameters as $parameter => $value) { $escapedParameters[] = match ($this->parameterTypes[$parameter]) { ParameterType::BINARY, ParameterType::LARGE_OBJECT => $value === null ? null : pg_escape_bytea($this->connection, is_resource($value) ? stream_get_contents($value) : $value), default => $value, }; } if (@pg_send_execute($this->connection, $this->name, $escapedParameters) !== true) { throw new Exception(pg_last_error($this->connection)); } $result = @pg_get_result($this->connection); assert($result !== false); if ((bool) pg_result_error($result)) { throw Exception::fromResult($result); } return new Result($result); } }