File "TableGenerator.php"

Full Path: /home/warrior1/public_html/plugins/mailpoet/vendor-prefixed/doctrine/dbal/lib/Doctrine/DBAL/Id/TableGenerator.php
File size: 2.57 KB
MIME-type: text/x-php
Charset: utf-8

<?php
namespace MailPoetVendor\Doctrine\DBAL\Id;
if (!defined('ABSPATH')) exit;
use MailPoetVendor\Doctrine\DBAL\Connection;
use MailPoetVendor\Doctrine\DBAL\Driver;
use MailPoetVendor\Doctrine\DBAL\DriverManager;
use MailPoetVendor\Doctrine\DBAL\Exception;
use MailPoetVendor\Doctrine\DBAL\LockMode;
use Throwable;
use function array_change_key_case;
use function assert;
use function is_int;
use const CASE_LOWER;
class TableGenerator
{
 private $conn;
 private $generatorTableName;
 private $sequences = [];
 public function __construct(Connection $conn, $generatorTableName = 'sequences')
 {
 if ($conn->getDriver() instanceof Driver\PDOSqlite\Driver) {
 throw new Exception('Cannot use TableGenerator with SQLite.');
 }
 $this->conn = DriverManager::getConnection($conn->getParams(), $conn->getConfiguration(), $conn->getEventManager());
 $this->generatorTableName = $generatorTableName;
 }
 public function nextValue($sequence)
 {
 if (isset($this->sequences[$sequence])) {
 $value = $this->sequences[$sequence]['value'];
 $this->sequences[$sequence]['value']++;
 if ($this->sequences[$sequence]['value'] >= $this->sequences[$sequence]['max']) {
 unset($this->sequences[$sequence]);
 }
 return $value;
 }
 $this->conn->beginTransaction();
 try {
 $platform = $this->conn->getDatabasePlatform();
 $sql = 'SELECT sequence_value, sequence_increment_by' . ' FROM ' . $platform->appendLockHint($this->generatorTableName, LockMode::PESSIMISTIC_WRITE) . ' WHERE sequence_name = ? ' . $platform->getWriteLockSQL();
 $row = $this->conn->fetchAssociative($sql, [$sequence]);
 if ($row !== \false) {
 $row = array_change_key_case($row, CASE_LOWER);
 $value = $row['sequence_value'];
 $value++;
 assert(is_int($value));
 if ($row['sequence_increment_by'] > 1) {
 $this->sequences[$sequence] = ['value' => $value, 'max' => $row['sequence_value'] + $row['sequence_increment_by']];
 }
 $sql = 'UPDATE ' . $this->generatorTableName . ' ' . 'SET sequence_value = sequence_value + sequence_increment_by ' . 'WHERE sequence_name = ? AND sequence_value = ?';
 $rows = $this->conn->executeStatement($sql, [$sequence, $row['sequence_value']]);
 if ($rows !== 1) {
 throw new Exception('Race-condition detected while updating sequence. Aborting generation');
 }
 } else {
 $this->conn->insert($this->generatorTableName, ['sequence_name' => $sequence, 'sequence_value' => 1, 'sequence_increment_by' => 1]);
 $value = 1;
 }
 $this->conn->commit();
 } catch (Throwable $e) {
 $this->conn->rollBack();
 throw new Exception('Error occurred while generating ID with TableGenerator, aborted generation: ' . $e->getMessage(), 0, $e);
 }
 return $value;
 }
}