forked from alchemy-fr/Phlickr
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Collection.php
165 lines (148 loc) · 4.78 KB
/
Collection.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
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
<?php
/**
* @version $Id$
* @author William O'Beirne <[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';
/**
* This class extends Phlickr_ObjectBase.
*/
require_once dirname(__FILE__) . '/Framework/ObjectBase.php';
/**
* Phlickr_Collection allows the manipuation of a Flickr collection. Uses
* unofficial flickr.collections.* methods. May be unstable.
*
* @package Phlickr
* @author William O'Beirne <[email protected]>
*/
class Phlickr_Collection extends Phlickr_Framework_ObjectBase {
/**
* The name of the XML element in the response that defines the object.
*
* @var string
*/
const XML_RESPONSE_ELEMENT = 'collection';
/**
* The name of the Flickr API method that provides the info on this object.
*
* @var string
*/
const XML_METHOD_NAME = 'flickr.collections.getInfo';
/**
* Constructor.
*
* You can construct a collection from an Id or XML. In its current state,
* the flickr api only allows collections to be handled by their owners.
*
* @param object Phlickr_API $api
* @param mixed $source string Id, object SimpleXMLElement
* @throws Phlickr_Exception, Phlickr_ConnectionException, Phlickr_XmlParseException
*/
function __construct(Phlickr_Api $api, $source) {
assert($api->isAuthValid());
parent::__construct($api, $source, self::XML_RESPONSE_ELEMENT);
}
public function __toString() {
return $this->getTitle() . ' (' . $this->getId() . ')';
}
static function getRequestMethodName() {
return self::XML_METHOD_NAME;
}
static function getRequestMethodParams($id) {
return array('collection_id' => (string) $id);
}
public function getId() {
return (string) $this->_cachedXml['id'];
}
public function buildUrl() {
return "http://flickr.com/photos/{$this->getUserId()}/collections/{$this->getPublicId()}/";
}
/**
* Return the Collection's title.
*
* @return string
*/
public function getTitle() {
if (!isset($this->_cachedXml->title)) {
$this->load();
}
return (string) $this->_cachedXml->title;
}
/**
* Return the user id of the collection owner. In its current state,
* collections get info does not return owner ID. Since collection's get
* info can only be run by the owner, we just get the authd ID.
*
* @return string
*/
public function getUserId() {
return $this->getApi()->getUserId();
}
/**
* Returns the id of the collection, minus the part behind the dash.
* This is the ID publically displayed, used in URLs etc.
*
* @return string
*/
public function getPublicId() {
$ids = explode('-', $this->getId());
return $ids[1];
}
/**
* Return the Collection's description.
*
* @return string
* @see Phlickr_AuthedPhotoset::setMeta()
*/
public function getDescription() {
if (!isset($this->_cachedXml->description)) {
$this->load();
}
return (string) $this->_cachedXml->description;
}
/**
* Return the children of this collection. Can either be collections,
* or sets.
*
* @return array
*/
public function getTree() {
$resp = $this->getApi()->executeMethod(
'flickr.collections.getTree',
array(
'collection_id' => $this->getId(),
)
);
return $this->buildCollectionsTreeArray($resp->xml->collections->collection);
}
/**
* Helper function, recursively assigns collection tree to an array.
*/
private function buildCollectionsTreeArray($collection) {
$children = array();
if (isset($collection->collection)) {
foreach ($collection->collection as $subcollection) {
$id = (string) $subcollection['id'];
$children['collections'][$id]['id'] = $id;
$children['collections'][$id]['title'] = $subcollection['title'];
if (isset($subcollection->collection)) {
$children['collections'][$id]['collections'] = $this->buildCollectionsTreeArray($subcollection);
}
}
}
elseif (isset($collection->set)) {
foreach ($collection->set as $set) {
$id = (string) $set['id'];
$children['sets'][$id]['id'] = $id;
$children['sets'][$id]['title'] = (string)$set['title'];
}
}
return $children;
}
}