-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathYqlDataProvider.php
118 lines (100 loc) · 2.46 KB
/
YqlDataProvider.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<?php
/**
* This file contains a class to provide a data provider for data returned by a call to the YQL Web service.
*
* @author Jefftulsa <[email protected]>
* @link http://www.yiihaw.com/
* @license MIT
*/
/**
* YqlDataProvider encapsulates a request to YQL.
*/
class YqlDataProvider extends CDataProvider
{
private $_request;
private $_response;
private $_yqlQuery;
/**
* Constructor.
* @param string the expected result item name. This is the name
* of the item returned in the query and is specific to the webservice being targeted
* @param array $config configuration (name=>value) to be applied as the initial property values of this class.
*/
public function __construct($itemName,$config=array())
{
$this->_request = new YqlRequest();
if(is_string($itemName))
$this->_request->itemName = $itemName;
$this->setId('YqlRequest-'.$this->_request->itemName);
foreach($config as $key=>$value)
$this->$key=$value;
}
/**
* Sets the yql query criteria.
* @param array the query criteria. An array
* representing the query criteria.
*/
public function setCriteria($value)
{
//if the full query was already set, ignore the criteria
if(isset($this->_request->query))
return;
foreach($value as $n=>$v)
{
$this->_request->$n = $v;
}
}
/**
* Sets the full yql query.
* @param array the query criteria. An array
* representing the query criteria.
*/
public function setQuery($value)
{
$this->_request->query = $value;
}
/**
* Fetches the data from the web service
* @return array list of data items
*/
protected function fetchData()
{
$this->_response = $this->_request->execute();
if($this->_response->hasErrors())
{
return array((array)$this->_response->error);
}
else
{
$items = $this->_response->results;
$arrayItems = array();
foreach($items as $itemObject)
{
$arrayItems[] = (array)$itemObject;
}
return $arrayItems;
}
}
/**
* Fetches the data item keys from the persistent data storage.
* @return array list of data item keys.
*/
protected function fetchKeys()
{
$keys=array();
foreach($this->getData() as $i=>$data)
{
$key = array_keys($data);
$keys[$i]=is_array($key) ? implode(',',$key) : $key;
}
return $keys;
}
/**
* Calculates the total number of data items.
* @return integer the total number of data items.
*/
protected function calculateTotalItemCount()
{
return $this->_response->count;
}
}