Commit 35a43d03 authored by Alexander Butenko's avatar Alexander Butenko

First real api

parent 79a83d07
<?php <?php
abstract class dbObject { abstract class dbObject {
public $db; private $db;
public $data;
public $isNew = true;
public $returnType = 'Object';
public function __construct () {
public function __construct ($data = null) {
$this->db = MysqliDb::getInstance(); $this->db = MysqliDb::getInstance();
if ($data)
$this->data = $data;
} }
private function cleanup ($data) { public function __set ($name, $value) {
if (method_exists ($this, "preLoad")) $this->data[$name] = $value;
$this->preLoad ($data); }
if (count ($data) == 0) public function __get ($name) {
return Array(); if (isset ($this->data[$name]))
return $this->data[$name];
foreach ($this->dbFields as $key => $prop) { if (property_exists ($this->db, $name))
$value = $data[$key]; return $this->db->$name;
if (!is_array($value)) {
$sqlData[$key] = $value;
continue;
} }
if ($prop['json']) public function __isset ($name) {
$sqlData[$key] = json_encode($value); if ($this->data[$name])
else if ($prop['array']) return isset ($this->data[$name]);
$sqlData[$key] = implode ("|", $value);
else if (property_exists ($this->db, $name))
$sqlData[$key] = $value; return isset ($this->db->$name);
} }
return $sqlData; public function __unset ($name) {
unset ($this->data[$name]);
} }
public function insert (&$data) { public static function ObjectBuilder () {
if (empty ($this->dbFields)) $obj = self::objectCopy ();
return false; $obj->returnType = 'Object';
return $obj;
}
$data = $this->cleanup ($data); public static function ArrayBuilder () {
$id = $this->db->insert ($this->dbTable, $data); $obj = self::objectCopy ();
$data[$this->$primaryKey] = $id; $obj->returnType = 'Array';
return $id; return $obj;
} }
public function remove ($data) { public function insert () {
$this->db->where ($this->primaryKey, $data['id']); $sqlData = $this->prepareData ();
return $this->db->delete ($this->dbTable); $id = $this->db->insert ($this->dbTable, $sqlData);
if (!empty ($this->primaryKey))
$this->data[$this->primaryKey] = $id;
$this->isNew = false;
return $id;
} }
public function update ($data) { public function update ($data = null) {
if (empty ($this->dbFields)) if (empty ($this->dbFields))
return false; return false;
$data = $this->cleanup ($data); if (empty ($this->data[$this->primaryKey]))
$this->db->where ($this->primaryKey, $data[$this->primaryKey]); return false;
return $this->db->update ($this->dbTable, $data);
if ($data) {
foreach ($data as $k => $v)
$this->$k = $v;
}
$sqlData = $this->prepareData ();
$this->db->where ($this->primaryKey, $this->data[$this->primaryKey]);
return $this->db->update ($this->dbTable, $sqlData);
} }
public function getOne($id, $fields = null) { public function save () {
if ($this->isNew)
return $this->insert();
return $this->update();
}
public function remove () {
$this->db->where ($this->primaryKey, $this->data[$this->primaryKey]);
return $this->db->delete ($this->dbTable);
}
public function byId ($id, $fields = null) {
$this->db->where($this->primaryKey, $id); $this->db->where($this->primaryKey, $id);
return $this->getOne ($fields);
}
public function getOne ($fields = null) {
$results = $this->db->getOne ($this->dbTable, $fields); $results = $this->db->getOne ($this->dbTable, $fields);
if (isset($this->jsonFields) && is_array($this->jsonFields)) { if (isset($this->jsonFields) && is_array($this->jsonFields)) {
foreach ($this->jsonFields as $key) foreach ($this->jsonFields as $key)
...@@ -66,12 +102,18 @@ abstract class dbObject { ...@@ -66,12 +102,18 @@ abstract class dbObject {
foreach ($this->arrayFields as $key) foreach ($this->arrayFields as $key)
$results[$key] = explode ("|", $results[$key]); $results[$key] = explode ("|", $results[$key]);
} }
if ($this->returnType == 'Array')
return $results; return $results;
$item = $this->objectCopy ($results);
$item->isNew = false;
return $item;
} }
public function get ($limit = null, $fields = null) { public function get ($limit = null, $fields = null) {
$db = MysqliDb::getInstance(); $objects = Array ();
$results = $db->get($this->dbTable); $results = $this->db->get($this->dbTable);
foreach ($results as &$r) { foreach ($results as &$r) {
if (isset ($this->jsonFields) && is_array($this->jsonFields)) { if (isset ($this->jsonFields) && is_array($this->jsonFields)) {
foreach ($this->jsonFields as $key) foreach ($this->jsonFields as $key)
...@@ -81,28 +123,68 @@ abstract class dbObject { ...@@ -81,28 +123,68 @@ abstract class dbObject {
foreach ($this->arrayFields as $key) foreach ($this->arrayFields as $key)
$r[$key] = explode ("|", $r[$key]); $r[$key] = explode ("|", $r[$key]);
} }
if ($this->returnType == 'Object') {
$item = $this->objectCopy ($r);
$item->isNew = false;
$objects[] = $item;
}
} }
if ($this->returnType == 'Object')
return $objects;
return $results; return $results;
} }
public function where ($whereProp, $whereValue = null, $operator = null) { public function count () {
$this->db->where ($whereProp, $whereValue, $operator); $res = $this->db->getValue ($this->dbTable, "count(*)");
return $this; return $res['cnt'];
} }
public function orWhere ($whereProp, $whereValue = null, $operator = null) {
$this->db->orWhere ($whereProp, $whereValue, $operator); public function __call ($method, $arg) {
call_user_func_array (array ($this->db, $method), $arg);
return $this; return $this;
} }
public function orderBy($orderByField, $orderbyDirection = "DESC", $customFields = null) { public function toJson () {
$this->db->orderBy ($orderByField, $orderbyDirection, $customFields); return json_encode ($this->data);
return $this;
} }
public function count () { public function __toString () {
$res = $this->db->getValue($this->dbTable, "count(*)"); return $this->toJson ();
return $res['cnt']; }
private function prepareData () {
$sqlData = Array();
if (method_exists ($this, "preLoad"))
$this->preLoad ($data);
if (count ($this->data) == 0)
return Array();
foreach ($this->data as $key => $value) {
if (!in_array ($key, array_keys ($this->dbFields)))
continue;
if (!is_array($value)) {
$sqlData[$key] = $value;
continue;
} }
if (in_array ($key, $this->jsonFields))
$sqlData[$key] = json_encode($value);
else
$sqlData[$key] = implode ("|", $value);
}
return $sqlData;
}
private static function objectCopy ($data = null) {
$className = get_called_class ();
return new $className ($data);
}
} }
?> ?>
...@@ -5,8 +5,13 @@ class accData extends dbObject { ...@@ -5,8 +5,13 @@ class accData extends dbObject {
protected $dbTable = "acc_data"; protected $dbTable = "acc_data";
protected $primaryKey = "id"; protected $primaryKey = "id";
public $calldate;
public $callid;
public $clientid;
public $queueid;
public function last () { public function last () {
$this->db->where ("id" , 1300, '>'); $this->where ("id" , 1300, '>');
return $this; return $this;
} }
} }
......
<?php
require_once "../dbObject.php";
/**
* To make IDEs autocomplete happy
*
* @property string id
* @property string userid
* @property string name
* @property string authcode
* @property string iscallerid
*/
class department extends dbObject {
protected $dbTable = "departments";
protected $primaryKey = "id";
protected $dbFields = Array (
'userid' => 'int:required',
'name' => 'int:required',
'authcode' => 'int',
'iscallerid' => 'int',
'testvar' => 'int'
);
protected $jsonFields = Array ('authcode');
public function last () {
$this->setTrace (true);
$this->where ("id" , 130, '>');
return $this;
}
}
?>
<? <?
require_once ("../MysqliDb.php"); require_once ("../MysqliDb.php");
require_once ("models/accData.php"); require_once ("models/department.php");
$db = new Mysqlidb('localhost', 'root', '', 'akorbi'); $db = new Mysqlidb('localhost', 'root', '', 'akorbi');
$accData = new accData(); $dept = new department();
$d = $accData->getOne(1288); $dept->userid = 10;
print_r ($d); $dept->name = 'avb test';
$dept->authcode = Array('1234','123456');
$dept->iscallerid = 1;
$dept->insert();
print_r ($accData->last()->get()); $dept2 = new department([
'userid' => '11',
'name' => 'avb2 test',
'authcode' => '5678',
'iscallerid' => 0,
]);
$dept2->save();
$dept2->iscallerid=1;
print_r ($dept2->data);
$dept2->save();
//$a = new accData; //echo $db->getLastQuery();
echo "List\n";
$depts = department::ObjectBuilder()->last()->get ();
foreach ($depts as $d) {
// print_r ($d->data);
echo $d . "\n";
}
echo "getOne\n";
$dept3 = department::ObjectBuilder()->byId ("181");
$dept3->authcode=333;
$dept3->save();
print_r ($dept3->data) . "\n";
echo $dept3->count;
print_r ($dept3->trace);
echo $dept3->qqq;
?> ?>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment