summaryrefslogtreecommitdiffstats
path: root/codebase/DataStorage/PHPYii2DBDataWrapper.php
diff options
context:
space:
mode:
Diffstat (limited to 'codebase/DataStorage/PHPYii2DBDataWrapper.php')
-rw-r--r--codebase/DataStorage/PHPYii2DBDataWrapper.php91
1 files changed, 91 insertions, 0 deletions
diff --git a/codebase/DataStorage/PHPYii2DBDataWrapper.php b/codebase/DataStorage/PHPYii2DBDataWrapper.php
new file mode 100644
index 0000000..95af1b7
--- /dev/null
+++ b/codebase/DataStorage/PHPYii2DBDataWrapper.php
@@ -0,0 +1,91 @@
+<?php
+namespace DHTMLX\Connector\DataStorage;
+
+class PHPYii2DBDataWrapper extends ArrayDBDataWrapper {
+
+ public function select($sql){
+ if (is_array($this->connection)) //result of findAll
+ $res = $this->connection;
+ else
+ $res = $this->connection->find()->all();
+
+ $temp = array();
+ if (sizeof($res)){
+ foreach ($res as $obj)
+ $temp[]=$obj->getAttributes();
+ }
+ //die(var_dump($temp));
+ return new ArrayQueryWrapper($temp);
+ }
+
+ protected function getErrorMessage(){
+ $errors = $this->connection->getErrors();
+ $text = array();
+ foreach ($errors as $key => $value){
+ $text[] = $key." - ".$value[0];
+ }
+ return implode("\n", $text);
+ }
+ public function insert($data,$source){
+ $name = get_class($this->connection);
+ $obj = new $name();
+ //die(var_dump($data));
+ $this->fill_model_and_save($obj, $data);
+ }
+ public function delete($data,$source){
+ $obj = $this->connection->findOne($data->get_id());
+ if ($obj->delete()){
+ $data->success();
+ $data->set_new_id($obj->getPrimaryKey());
+ } else {
+ $data->set_response_attribute("details", $this->errors_to_string($obj->getErrors()));
+ $data->invalid();
+ }
+ }
+ public function update($data,$source){
+ //$obj = get_class($this->connection);
+ //$obj->setAttribute($obj->getPrimaryKey);
+
+ $obj = $this->connection->findOne($data->get_id());
+;
+ $this->fill_model_and_save($obj, $data);
+ }
+
+ protected function fill_model_and_save($obj, $data){
+
+ //map data to model object
+ for ($i=0; $i < sizeof($this->config->text); $i++){
+ $step=$this->config->text[$i];
+ $obj->setAttribute($step["name"], $data->get_value("c".$i)); //TODO make array with corresponding names
+ }
+
+ if ($relation = $this->config->relation_id["db_name"])
+ $obj->setAttribute($relation, $data->get_value($relation));
+
+ //save model
+ if ($obj->save()){
+ $data->success();
+ $data->set_new_id($obj->getPrimaryKey());
+ } else {
+ $data->set_response_attribute("details", $this->errors_to_string($obj->getErrors()));
+ $data->invalid();
+ }
+ }
+
+ protected function errors_to_string($errors){
+ $text = array();
+ foreach($errors as $value)
+ $text[]=implode("\n", $value);
+ return implode("\n",$text);
+ }
+ public function escape($str){
+ throw new Exception("Not implemented");
+ }
+ public function query($str){
+ throw new Exception("Not implemented");
+ }
+ public function get_new_id(){
+ throw new Exception("Not implemented");
+ }
+
+} \ No newline at end of file