forked from alchemy-fr/Phlickr
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Response.php
149 lines (139 loc) · 3.56 KB
/
Response.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
<?php
/**
* @version $Id$
* @author Andrew Morton <[email protected]>
* @license http://opensource.org/licenses/lgpl-license.php
* GNU Lesser General Public License, Version 2.1
* @package Phlickr
*/
/**
* Phlickr_Api includes the core classes.
*/
require_once dirname(__FILE__) . '/Api.php';
/**
* Phlickr_Response handles the XML returned by a Phlickr_Request.
*
* Sample usage:
* <code>
* <?php
* include_once '/Api.php';
*
* // store a sample response into a variable
* $xmlResponse = <<<XML
* <?xml version="1.0" encoding="utf-8" ?>
* <rsp stat="ok">
* <user id="39059360@N00">
* <username>just testing</username>
* </user>
* </rsp>
* XML;
*
* // instantiate the object
* $response = new Phlickr_Response($xmlResponse);
*
* // was the request successful?
* print $response->isOk();
*
* // view the response (using its __toString() function)
* print $response;
* ?>
* </code>
*
* This class is responsible for:
* - Converting the XML string returned by a Phlickr_Request object into a
* SimpleXML object.
* - Determining the success or failure of the request.
*
* @package Phlickr
* @author Andrew Morton <[email protected]>
* @since 0.1.0
*/
class Phlickr_Response {
/**
* The Request was sent and the server responded with a valid Response.
* This constant is defined by Flickr's API.
*
* @var string
*/
const STAT_OK = 'ok';
/**
* The Request was sent but the server found a problem with the Request.
* This constant is defined by Flickr's API.
*
* @var string
*/
const STAT_FAIL = 'fail';
/**
* XML payload of the Response.
*
* @var object SimpleXMLElement
*/
var $xml = null;
/**
* Status of the Reponse.
*
* @var string
* @see STAT_OK, STAT_FAIL
*/
var $stat = null;
/**
* Error code.
* This variable is only assigned when !$this->isOk()
*
* @var integer
*/
var $err_code = null;
/**
* Error message.
* This variable is only assigned when !$this->isOk()
*
* @var string
* @access public
*/
var $err_msg = null;
/**
* Constructor takes output from the http request
*
* @param string $restResult XML string from a Flickr_Request object.
* @param boolean $throwOnFailed Should an exception be thrown when the
* response indicates failure?
* @throws Phlickr_XmlParseException, Phlickr_Exception
*/
function __construct($restResult, $throwOnFailed = false) {
$xml = simplexml_load_string($restResult);
if (false === $xml) {
throw new Phlickr_XmlParseException('Could not parse XML.', $restResult);
}
$this->stat = (string) $xml['stat'];
if ($this->isOk()) {
$this->xml = $xml;
} else {
$this->err_code = (integer) $xml->err['code'];
$this->err_msg = (string) $xml->err['msg'];
if ($throwOnFailed) {
throw new Phlickr_MethodFailureException($this->err_msg, $this->err_code);
}
}
}
public function __toString() {
return $this->xml->asXML();
}
/**
* Check if the Response is successful
*
* @return boolean
*/
public function isOk() {
return ($this->stat == self::STAT_OK);
}
/**
* Get the XML Object.
*
* @return object SimpleXML
* @see SimpleXML::asXML()
* @since 0.2.3
*/
public function getXml() {
return $this->xml;
}
}