From 6c223d16bd820d05eb5be4360cc34e59dc3a426b Mon Sep 17 00:00:00 2001 From: Shish Date: Tue, 27 Oct 2020 21:51:15 +0000 Subject: [PATCH] use inTransaction() instead of trying to maintain our own state --- core/database.php | 21 +++------------------ 1 file changed, 3 insertions(+), 18 deletions(-) diff --git a/core/database.php b/core/database.php index ccbe169a..e4ee55d1 100644 --- a/core/database.php +++ b/core/database.php @@ -33,14 +33,6 @@ class Database */ private $engine = null; - /** - * A boolean flag to track if we already have an active transaction. - * (ie: True if beginTransaction() already called) - * - * @var bool - */ - public $transaction = false; - /** * How many queries this DB object has run */ @@ -53,13 +45,9 @@ class Database private function connect_db(): void { - $this->db = new PDO($this->dsn, [ - PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, - ]); - + $this->db = new PDO($this->dsn); $this->connect_engine(); $this->engine->init($this->db); - $this->begin_transaction(); } @@ -87,21 +75,19 @@ class Database public function begin_transaction(): void { - if ($this->transaction === false) { + if ($this->is_transaction_open() === false) { $this->db->beginTransaction(); - $this->transaction = true; } } public function is_transaction_open(): bool { - return !is_null($this->db) && $this->transaction === true; + return !is_null($this->db) && $this->db->inTransaction(); } public function commit(): bool { if ($this->is_transaction_open()) { - $this->transaction = false; return $this->db->commit(); } else { throw new SCoreException("Unable to call commit() as there is no transaction currently open."); @@ -111,7 +97,6 @@ class Database public function rollback(): bool { if ($this->is_transaction_open()) { - $this->transaction = false; return $this->db->rollback(); } else { throw new SCoreException("Unable to call rollback() as there is no transaction currently open.");