<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
*
* @property int id
*/
-abstract class BaseModel extends BaseEntity
+abstract class BaseModel extends BaseDataTransferObject
{
/** @var Database */
protected $dba;
$this->originalData = $data;
}
- public function getOriginalData()
+ public function getOriginalData(): array
{
return $this->originalData;
}
* @param array $data
* @return BaseModel
*/
- public static function createFromPrototype(BaseModel $prototype, array $data)
+ public static function createFromPrototype(BaseModel $prototype, array $data): BaseModel
{
$model = clone $prototype;
$model->data = $data;
* @param $name
* @return bool
*/
- public function __isset($name)
+ public function __isset($name): bool
{
return in_array($name, array_merge(array_keys($this->data), array_keys(get_object_vars($this))));
}
* - $model->field (outside of class)
* - $this->field (inside of class)
*
- * @param $name
+ * @param string $name Name of data to fetch
* @return mixed
* @throws HTTPException\InternalServerErrorException
*/
- public function __get($name)
+ public function __get(string $name)
{
$this->checkValid();
}
/**
+ * * Magic setter. This allows to set model fields with the following syntax:
+ * - $model->field = $value (outside of class)
+ * - $this->field = $value (inside of class)
+ *
* @param string $name
- * @param mixed $value
+ * @param mixed $value
*/
- public function __set($name, $value)
+ public function __set(string $name, $value)
{
$this->data[$name] = $value;
}
- public function toArray()
+ public function toArray(): array
{
return $this->data;
}
protected function checkValid()
{
- if (empty($this->data['id'])) {
+ if (!isset($this->data['id']) || is_null($this->data['id'])) {
throw new HTTPException\InternalServerErrorException(static::class . ' record uninitialized');
}
}