2013-03-10 12:40:11 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud - Collection class for PIM object
|
|
|
|
*
|
|
|
|
* @author Thomas Tanghus
|
2014-01-26 00:40:22 +01:00
|
|
|
* @copyright 2012-2014 Thomas Tanghus (thomas@tanghus.net)
|
2013-03-10 12:40:11 +01:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Contacts;
|
|
|
|
|
|
|
|
/**
|
2014-03-08 16:22:51 +01:00
|
|
|
* Subclass this for PIM collections.
|
2013-03-10 12:40:11 +01:00
|
|
|
*/
|
2013-04-25 01:03:05 +02:00
|
|
|
abstract class AbstractPIMCollection extends AbstractPIMObject implements \Iterator, \Countable, \ArrayAccess {
|
2013-03-10 12:40:11 +01:00
|
|
|
|
|
|
|
// Iterator properties
|
|
|
|
|
|
|
|
protected $objects = array();
|
|
|
|
|
|
|
|
protected $counter = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a specific child node, referenced by its id
|
2013-03-17 21:32:53 +01:00
|
|
|
* TODO: Maybe implement it here?
|
2013-03-10 12:40:11 +01:00
|
|
|
*
|
|
|
|
* @param string $id
|
|
|
|
* @return IPIMObject
|
|
|
|
*/
|
2013-05-30 20:52:12 +02:00
|
|
|
public abstract function getChild($id);
|
2013-03-10 12:40:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an array with all the child nodes
|
|
|
|
*
|
|
|
|
* @return IPIMObject[]
|
|
|
|
*/
|
2013-05-30 20:52:12 +02:00
|
|
|
public abstract function getChildren($limit = null, $offset = null);
|
2013-03-10 12:40:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if a child-node with the specified id exists
|
|
|
|
*
|
|
|
|
* @param string $id
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-05-30 20:52:12 +02:00
|
|
|
public abstract function childExists($id);
|
2013-03-10 12:40:11 +01:00
|
|
|
|
2013-03-20 11:22:53 +01:00
|
|
|
/**
|
|
|
|
* Add a child to the collection
|
|
|
|
*
|
|
|
|
* It's up to the implementations to "keep track" of the children.
|
|
|
|
*
|
|
|
|
* @param mixed $data
|
|
|
|
* @return string ID of the newly added child
|
|
|
|
*/
|
2013-05-30 20:52:12 +02:00
|
|
|
public abstract function addChild($data);
|
2013-03-20 11:22:53 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a child from the collection
|
|
|
|
*
|
|
|
|
* @param string $id
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-09-03 19:23:11 +02:00
|
|
|
public abstract function deleteChild($id, $options = array());
|
2013-03-20 11:22:53 +01:00
|
|
|
|
2013-03-10 12:40:11 +01:00
|
|
|
// Iterator methods
|
|
|
|
|
|
|
|
public function rewind() {
|
|
|
|
$this->counter = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function next() {
|
|
|
|
$this->counter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function valid() {
|
|
|
|
return array_key_exists($this->counter, $this->objects);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function current() {
|
|
|
|
return $this->objects[$this->counter];
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Implementations can choose to return the current objects ID/UUID
|
|
|
|
* to be able to iterate over the collection with ID => Object pairs:
|
|
|
|
* foreach($collection as $id => $object) {}
|
|
|
|
*/
|
|
|
|
public function key() {
|
|
|
|
return $this->counter;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Countable method.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* For implementations using a backend where fetching all object at once
|
|
|
|
* would give too much overhead, they can maintain an internal count value
|
|
|
|
* and fetch objects progressively. Simply watch the diffence between
|
|
|
|
* $this->counter, the value of count($this->objects) and the internal
|
|
|
|
* value, and fetch more objects when needed.
|
|
|
|
*/
|
|
|
|
public function count() {
|
|
|
|
return count($this->objects);
|
|
|
|
}
|
|
|
|
|
|
|
|
// ArrayAccess methods
|
|
|
|
|
|
|
|
public function offsetSet($offset, $value) {
|
|
|
|
if (is_null($offset)) {
|
|
|
|
$this->objects[] = $value;
|
|
|
|
} else {
|
|
|
|
$this->objects[$offset] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function offsetExists($offset) {
|
|
|
|
return isset($this->objects[$offset]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function offsetUnset($offset) {
|
|
|
|
unset($this->objects[$offset]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function offsetGet($offset) {
|
|
|
|
return isset($this->objects[$offset]) ? $this->objects[$offset] : null;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Magic property accessors
|
2013-03-17 21:32:53 +01:00
|
|
|
// NOTE: They should go in the implementations(?)
|
2013-03-22 15:00:47 +01:00
|
|
|
/*
|
2013-03-10 12:40:11 +01:00
|
|
|
public function __set($id, $value) {
|
2013-03-17 21:32:53 +01:00
|
|
|
$this->objects[$id] = $value;
|
2013-03-10 12:40:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function __get($id) {
|
2013-03-17 21:32:53 +01:00
|
|
|
return $this->objects[$id];
|
2013-03-10 12:40:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function __isset($id) {
|
2013-03-17 21:32:53 +01:00
|
|
|
return isset($this->objects[$id]);
|
2013-03-10 12:40:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function __unset($id) {
|
2013-03-17 21:32:53 +01:00
|
|
|
unset($this->objects[$id]);
|
2013-03-10 12:40:11 +01:00
|
|
|
}
|
2013-03-22 15:00:47 +01:00
|
|
|
*/
|
2013-03-10 12:40:11 +01:00
|
|
|
|
2013-03-17 21:32:53 +01:00
|
|
|
}
|