Adding modifications from kritbit
This commit is contained in:
		
							
								
								
									
										77
									
								
								system/engine/hf_model.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								system/engine/hf_model.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,77 @@
 | 
			
		||||
<?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]);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user