1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2024-12-23 17:12:41 +00:00
Arsse/lib/Db/Transaction.php
J. King b3f631e335 Use more reliable database locking strategy; reorganize tests
PostgreSQL and MySQL both have better locking mechanisms than what was previously implemented, as well
2017-07-07 21:06:38 -04:00

45 lines
No EOL
999 B
PHP

<?php
declare(strict_types=1);
namespace JKingWeb\Arsse\Db;
class Transaction {
protected $index;
protected $pending = false;
protected $drv;
function __construct(Driver $drv, bool $lock = false) {
$this->index = $drv->savepointCreate($lock);
$this->drv = $drv;
$this->pending = true;
}
function __destruct() {
if($this->pending) {
try {
$this->drv->savepointUndo($this->index);
} catch(\Throwable $e) {
// do nothing
}
}
}
function commit(): bool {
$out = $this->drv->savepointRelease($this->index);
$this->pending = false;
return $out;
}
function rollback(): bool {
$out = $this->drv->savepointUndo($this->index);
$this->pending = false;
return $out;
}
function getIndex(): int {
return $this->index;
}
function isPending(): bool {
return $this->pending;
}
}