forked from vscarpenter/webSqlApp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSqlSyncHandler.php
86 lines (77 loc) · 2.81 KB
/
SqlSyncHandler.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<?php
/**
* SyqSyncHandler.php for WebSqlSync.js code
* Created by: sg4r3z 20/05/2013
* modified by abeauseigle 2013-10-08 to add the tableName in the JSON
* This class allow to manage the json flow sended by the client (with the WebSqlSync script by orbitaloop), and make a reply.
* ToDo: Do something with the JSON sent by the Client to update MySQL table data
*/
final class SqlSyncHandler{
private $clientData,$jsonData;
// well formatted Answer for WebSqlSync.js Script
private $serverAnswer = array("result" => '',"message" => '', "syncDate" => '',"data" => array());
/*
* __construct
* Capture the input stream and creates
* an array with the same structure
*/
public function __construct($dataFlow = NULL){
if($dataFlow == NULL)
{$this -> jsonData = file_get_contents('php://input');} // like jsonfile2string
else
{$this -> jsonData = file_get_contents($dataFlow);} // like jsonfile2string. On failure, file_get_contents() will return FALSE.
//$this -> clientData = json_decode($this -> jsonData);
$clientData = json_decode($this -> jsonData); // like string2array
// ToDo: Do something with the Client JSON data
}
/*
* reply (Server -> JSON -> Client)
* This method create a well-structred reply for Client in JSON
* This method accept status,message,data
* STATUS = boolean value (TRUE for OK, FALSE for ERROR)
* MESSAGE = string value for message
* DATA = array of data for client
*/
public function reply($status,$message,$data){ // $data come from the query getAllServerData() from sqlSyncHandlerTest.php
if($status)
{$this -> serverAnswer['result'] = 'OK';}
else
{$this -> serverAnswer['result'] = 'ERROR';}
$this -> serverAnswer['message'] = $message;
$this -> serverAnswer['syncDate'] = strtotime("now")*1000; // return sync_date: "1372365079000",
$this -> serverAnswer['data'] = $data;
echo json_encode($this -> serverAnswer);
// $myObject = '{"result":"OK","message":"this is a positive reply","syncDate":"1371753757","data":[{"UniteID":"0","UniteSymbol":"h"},{"UniteID":"1","UniteSymbol":"km"},{"UniteID":"2","UniteSymbol":"$"},{"UniteID":"3","UniteSymbol":"U$"},{"UniteID":"4","UniteSymbol":"\u20ac"},{"UniteID":"5","UniteSymbol":"$P"}]}';
// echo $myObject;
}
/*
* call
* This method allows class to call an
* external functon to make a custom job
*/
public function call($function,SqlSyncHandler $param = NULL){
call_user_func($function,$param);
}
/*
* getter clientData
* get a clientData property
*/
public function get_clientData(){
return $this -> clientData;
}
/*
* get serverAnswer
* get a serverAnswer property
*/
public function get_serverAnswer(){
return $this -> serverAnswer;
}
/*
* get jsonData
* get a jsonData property
*/
public function get_jsonData(){
return $this -> jsonData;
}
}
?>