Files
sysPass/lib/SP/Domain/Common/Adapters/DataModel.php
2022-11-27 16:01:51 +01:00

102 lines
2.6 KiB
PHP

<?php
/*
* sysPass
*
* @author nuxsmin
* @link https://syspass.org
* @copyright 2012-2022, Rubén Domínguez nuxsmin@$syspass.org
*
* This file is part of sysPass.
*
* sysPass is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* sysPass is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with sysPass. If not, see <http://www.gnu.org/licenses/>.
*/
namespace SP\Domain\Common\Adapters;
use JsonSerializable;
/**
* Class DataModelBase
*/
abstract class DataModel implements JsonSerializable
{
private array $properties;
public function __construct(?array $properties = [])
{
foreach ($properties as $property => $value) {
$this->{$property} = $value;
}
}
final public static function buildFromSimpleModel(SimpleModel $model): static
{
return new static($model->toArray());
}
final public function toArray(): array
{
if (count($this->properties) !== 0) {
return $this->properties;
}
return get_object_vars($this);
}
/**
* @param string $name
*
* @return mixed|null
*/
final public function __get(string $name)
{
if (property_exists($this, $name)) {
return $this->{$name};
}
return $this->properties[$name] ?? null;
}
final public function __set(string $name, mixed $value = null): void
{
if (is_numeric($value)) {
$value = (int)$value;
}
if (property_exists($this, $name)) {
$this->{$name} = $value;
} else {
$this->properties[$name] = $value;
}
}
final public function __isset(string $name): bool
{
return property_exists($this, $name) || isset($this->properties[$name]);
}
/**
* Specify data which should be serialized to JSON
*
* @link http://php.net/manual/en/jsonserializable.jsonserialize.php
* @return array data which can be serialized by <b>json_encode</b>,
* which is a value of any type other than a resource.
* @since 5.4.0
*/
public function jsonSerialize(): array
{
return $this->toArray();
}
}