mirror of
https://github.com/standardebooks/web.git
synced 2025-07-06 14:50:39 -04:00
67 lines
1.3 KiB
PHP
67 lines
1.3 KiB
PHP
<?
|
|
class LocSubject{
|
|
public int $LocSubjectId;
|
|
public string $Name;
|
|
|
|
// *******
|
|
// METHODS
|
|
// *******
|
|
|
|
/**
|
|
* @throws Exceptions\InvalidLocSubjectException
|
|
*/
|
|
public function Validate(): void{
|
|
$error = new Exceptions\InvalidLocSubjectException();
|
|
|
|
if(isset($this->Name)){
|
|
$this->Name = trim($this->Name);
|
|
|
|
if($this->Name == ''){
|
|
$error->Add(new Exceptions\LocSubjectNameRequiredException());
|
|
}
|
|
|
|
if(strlen($this->Name) > EBOOKS_MAX_STRING_LENGTH){
|
|
$error->Add(new Exceptions\StringTooLongException('LoC subject: '. $this->Name));
|
|
}
|
|
}
|
|
else{
|
|
$error->Add(new Exceptions\LocSubjectNameRequiredException());
|
|
}
|
|
|
|
if($error->HasExceptions){
|
|
throw $error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @throws Exceptions\InvalidLocSubjectException
|
|
*/
|
|
public function Create(): void{
|
|
$this->Validate();
|
|
|
|
Db::Query('
|
|
INSERT into LocSubjects (Name)
|
|
values (?)
|
|
', [$this->Name]);
|
|
$this->LocSubjectId = Db::GetLastInsertedId();
|
|
}
|
|
|
|
/**
|
|
* @throws Exceptions\InvalidLocSubjectException
|
|
*/
|
|
public function GetByNameOrCreate(string $name): LocSubject{
|
|
$result = Db::Query('
|
|
SELECT *
|
|
from LocSubjects
|
|
where Name = ?
|
|
', [$name], LocSubject::class);
|
|
|
|
if(isset($result[0])){
|
|
return $result[0];
|
|
}
|
|
else{
|
|
$this->Create();
|
|
return $this;
|
|
}
|
|
}
|
|
}
|