77 lines
2.4 KiB
PHP
77 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace system\engine;
|
|
|
|
use \vendor\DB\DB;
|
|
|
|
abstract class HF_Model {
|
|
|
|
public $id = null;
|
|
public static function create($data) {
|
|
|
|
$obj = new static();
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
|
|
foreach(DB::getColumns($table) as $column) {
|
|
if (isset($data[$column])) {
|
|
$obj->$column = $data[$column];
|
|
}
|
|
}
|
|
return $obj;
|
|
}
|
|
|
|
public function save() {
|
|
$fieldMap = [];
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
foreach(DB::getColumns($table) as $column) {
|
|
$fieldMap[$column] = $this->$column;
|
|
}
|
|
if ($fieldMap["id"] == null) {
|
|
DB::insert($table, $fieldMap);
|
|
} else {
|
|
$updateFields = $fieldMap;
|
|
unset($updateFields["id"]);
|
|
DB::update($table, $updateFields, $fieldMap["id"]);
|
|
}
|
|
}
|
|
|
|
public function update($data) {
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
foreach(DB::getColumns($table) as $column) {
|
|
if ($column == "id" || strpos($column, "_id") !== false) {
|
|
continue; // Don't allow to override id
|
|
}
|
|
if (isset($data[$column])) {
|
|
$this->$column = $data[$column];
|
|
}
|
|
}
|
|
return $this;
|
|
}
|
|
|
|
public function delete() {
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
if ($this->id) {
|
|
DB::query("DELETE FROM $table WHERE id = " . $this->id);
|
|
}
|
|
}
|
|
|
|
public function deleteRelated($tables = []) {
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
foreach($tables as $relatedTable) {
|
|
DB::query("DELETE FROM $relatedTable WHERE $table" . "_id = " . $this->id);
|
|
}
|
|
}
|
|
|
|
public static function getByField($field, $value) {
|
|
$function = new \ReflectionClass(get_called_class());
|
|
$table = strtolower($function->getShortName());
|
|
$fields = implode(", ", DB::getColumns($table));
|
|
return DB::fetchObject("SELECT $fields FROM $table WHERE $field = ?", get_called_class(), [$value]);
|
|
}
|
|
|
|
} |