mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-24 03:50:33 +00:00
Make db throw specific exceptions
Needs testing and fleshing out; not all exception codes and messages have been defined
This commit is contained in:
parent
755c976aa4
commit
7c1df71acd
5 changed files with 65 additions and 11 deletions
|
@ -27,9 +27,10 @@ abstract class AbstractException extends \Exception {
|
||||||
"Db/Exception.updateFileUnreadable" => 10214,
|
"Db/Exception.updateFileUnreadable" => 10214,
|
||||||
"Db/Exception.updateManual" => 10215,
|
"Db/Exception.updateManual" => 10215,
|
||||||
"Db/Exception.updateManualOnly" => 10216,
|
"Db/Exception.updateManualOnly" => 10216,
|
||||||
"Db/Exception.paramTypeInvalid" => 10401,
|
"Db/Exception.paramTypeInvalid" => 10301,
|
||||||
"Db/Exception.paramTypeUnknown" => 10402,
|
"Db/Exception.paramTypeUnknown" => 10302,
|
||||||
"Db/Exception.paramTypeMissing" => 10403,
|
"Db/Exception.paramTypeMissing" => 10303,
|
||||||
|
"Db/Exception.engineErrorGeneral" => 10401, // this symbol can have engine-specific duplicates to accomodate engine-specific error string construction
|
||||||
"Conf/Exception.fileMissing" => 10302,
|
"Conf/Exception.fileMissing" => 10302,
|
||||||
"Conf/Exception.fileUnusable" => 10303,
|
"Conf/Exception.fileUnusable" => 10303,
|
||||||
"Conf/Exception.fileUnreadable" => 10304,
|
"Conf/Exception.fileUnreadable" => 10304,
|
||||||
|
|
|
@ -8,7 +8,8 @@ use JKingWeb\NewsSync\Db\ExceptionTimeout;
|
||||||
|
|
||||||
|
|
||||||
class Driver extends \JKingWeb\NewsSync\Db\AbstractDriver {
|
class Driver extends \JKingWeb\NewsSync\Db\AbstractDriver {
|
||||||
const SQLITE_ERROR = 1;
|
use ExceptionBuilder;
|
||||||
|
|
||||||
const SQLITE_BUSY = 5;
|
const SQLITE_BUSY = 5;
|
||||||
const SQLITE_CONSTRAINT = 19;
|
const SQLITE_CONSTRAINT = 19;
|
||||||
const SQLITE_MISMATCH = 20;
|
const SQLITE_MISMATCH = 20;
|
||||||
|
@ -78,7 +79,6 @@ class Driver extends \JKingWeb\NewsSync\Db\AbstractDriver {
|
||||||
// commit any successful updates if updating by more than one version
|
// commit any successful updates if updating by more than one version
|
||||||
$this->commit(true);
|
$this->commit(true);
|
||||||
// throw the error received
|
// throw the error received
|
||||||
// FIXME: This should create the relevant type of SQL exception
|
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
$this->commit();
|
$this->commit();
|
||||||
|
@ -89,14 +89,31 @@ class Driver extends \JKingWeb\NewsSync\Db\AbstractDriver {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function exec(string $query): bool {
|
public function exec(string $query): bool {
|
||||||
|
try {
|
||||||
return (bool) $this->db->exec($query);
|
return (bool) $this->db->exec($query);
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
list($excClass, $excMsg, $excData) = $this->exceptionBuild();
|
||||||
|
throw new $excClass($excMsg, $excData);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function query(string $query): \JKingWeb\NewsSync\Db\Result {
|
public function query(string $query): \JKingWeb\NewsSync\Db\Result {
|
||||||
return new Result($this->db->query($query), $this->db->changes());
|
Try {
|
||||||
|
$r = $this->db->query($query);
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
list($excClass, $excMsg, $excData) = $this->exceptionBuild();
|
||||||
|
throw new $excClass($excMsg, $excData);
|
||||||
|
}
|
||||||
|
return new Result($r, $this->db->changes());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function prepareArray(string $query, array $paramTypes): \JKingWeb\NewsSync\Db\Statement {
|
public function prepareArray(string $query, array $paramTypes): \JKingWeb\NewsSync\Db\Statement {
|
||||||
return new Statement($this->db, $this->db->prepare($query), $paramTypes);
|
try {
|
||||||
|
$s = $this->db->prepare($query);
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
list($excClass, $excMsg, $excData) = $this->exceptionBuild();
|
||||||
|
throw new $excClass($excMsg, $excData);
|
||||||
|
}
|
||||||
|
return new Statement($this->db, $s, $paramTypes);
|
||||||
}
|
}
|
||||||
}
|
}
|
23
lib/Db/SQLite3/ExceptionBuilder.php
Normal file
23
lib/Db/SQLite3/ExceptionBuilder.php
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
<?php
|
||||||
|
declare(strict_types=1);
|
||||||
|
namespace JKingWeb\NewsSync\Db\SQLite3;
|
||||||
|
use JKingWeb\NewsSync\Db\Exception;
|
||||||
|
use JKingWeb\NewsSync\Db\ExceptionInput;
|
||||||
|
use JKingWeb\NewsSync\Db\ExceptionTimeout;
|
||||||
|
|
||||||
|
|
||||||
|
trait ExceptionBuilder {
|
||||||
|
|
||||||
|
public function exceptionBuild() {
|
||||||
|
switch($this->db->lastErrorCode()) {
|
||||||
|
case self::SQLITE_BUSY:
|
||||||
|
return [ExceptionTimeout::class, 'sqliteBusy', $this->db->lastErrorMsg()];
|
||||||
|
case self::SQLITE_CONSTRAINT:
|
||||||
|
return [ExceptionInput::class, 'constraintViolation', $this->db->lastErrorMsg()];
|
||||||
|
case self::SQLITE_MISMATCH:
|
||||||
|
return [ExceptionInput::class, 'typeViolation', $this->db->lastErrorMsg()];
|
||||||
|
default:
|
||||||
|
return [Exception::class, 'engineErrorGeneral', $this->db->lastErrorMsg()];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,8 +2,15 @@
|
||||||
declare(strict_types=1);
|
declare(strict_types=1);
|
||||||
namespace JKingWeb\NewsSync\Db\SQLite3;
|
namespace JKingWeb\NewsSync\Db\SQLite3;
|
||||||
use JKingWeb\NewsSync\Db\Exception;
|
use JKingWeb\NewsSync\Db\Exception;
|
||||||
|
use JKingWeb\NewsSync\Db\ExceptionInput;
|
||||||
|
use JKingWeb\NewsSync\Db\ExceptionTimeout;
|
||||||
|
|
||||||
class Statement extends \JKingWeb\NewsSync\Db\AbstractStatement {
|
class Statement extends \JKingWeb\NewsSync\Db\AbstractStatement {
|
||||||
|
use ExceptionBuilder;
|
||||||
|
|
||||||
|
const SQLITE_BUSY = 5;
|
||||||
|
const SQLITE_CONSTRAINT = 19;
|
||||||
|
const SQLITE_MISMATCH = 20;
|
||||||
const BINDINGS = [
|
const BINDINGS = [
|
||||||
"null" => \SQLITE3_NULL,
|
"null" => \SQLITE3_NULL,
|
||||||
"integer" => \SQLITE3_INTEGER,
|
"integer" => \SQLITE3_INTEGER,
|
||||||
|
@ -59,6 +66,12 @@ class Statement extends \JKingWeb\NewsSync\Db\AbstractStatement {
|
||||||
// perform binding
|
// perform binding
|
||||||
$this->st->bindValue($a+1, $values[$a], $type);
|
$this->st->bindValue($a+1, $values[$a], $type);
|
||||||
}
|
}
|
||||||
return new Result($this->st->execute(), $this->db->changes(), $this);
|
try {
|
||||||
|
$r = $this->st->execute();
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
list($excClass, $excMsg, $excData) = $this->exceptionBuild();
|
||||||
|
throw new $excClass($excMsg, $excData);
|
||||||
|
}
|
||||||
|
return new Result($r, $this->db->changes(), $this);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -28,10 +28,10 @@ return [
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.fileUnusable' => 'Insufficient permissions to open database file "{0}" for reading or writing',
|
'Exception.JKingWeb/NewsSync/Db/Exception.fileUnusable' => 'Insufficient permissions to open database file "{0}" for reading or writing',
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.fileUncreatable' => 'Insufficient permissions to create new database file "{0}"',
|
'Exception.JKingWeb/NewsSync/Db/Exception.fileUncreatable' => 'Insufficient permissions to create new database file "{0}"',
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.fileCorrupt' => 'Database file "{0}" is corrupt or not a valid database',
|
'Exception.JKingWeb/NewsSync/Db/Exception.fileCorrupt' => 'Database file "{0}" is corrupt or not a valid database',
|
||||||
|
'Exception.JKingWeb/NewsSync/Db/Exception.engineErrorGeneral' => '{0}',
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeInvalid' => 'Prepared statement parameter type "{0}" is invalid',
|
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeInvalid' => 'Prepared statement parameter type "{0}" is invalid',
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeUnknown' => 'Prepared statement parameter type "{0}" is valid, but not implemented',
|
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeUnknown' => 'Prepared statement parameter type "{0}" is valid, but not implemented',
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeMissing' => 'Prepared statement parameter type for parameter #{0} was not specified',
|
'Exception.JKingWeb/NewsSync/Db/Exception.paramTypeMissing' => 'Prepared statement parameter type for parameter #{0} was not specified',
|
||||||
|
|
||||||
'Exception.JKingWeb/NewsSync/Db/Exception.updateManual' =>
|
'Exception.JKingWeb/NewsSync/Db/Exception.updateManual' =>
|
||||||
'{from_version, select,
|
'{from_version, select,
|
||||||
0 {{driver_name} database is configured for manual updates and is not initialized; please populate the database with the base schema}
|
0 {{driver_name} database is configured for manual updates and is not initialized; please populate the database with the base schema}
|
||||||
|
|
Loading…
Add table
Reference in a new issue