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
|
<?php
/**
* ElggMetadata
* This class describes metadata that can be attached to ElggEntities.
*
* @package Elgg
* @subpackage Core
*/
class ElggMetadata extends ElggExtender {
/**
* Construct a new site object, optionally from a given id value or row.
*
* @param mixed $id
*/
function __construct($id = null) {
$this->attributes = array();
if (!empty($id)) {
// Create from db row
if ($id instanceof stdClass) {
$metadata = $id;
} else {
$metadata = get_metadata($id);
}
if ($metadata) {
$objarray = (array) $metadata;
foreach($objarray as $key => $value) {
$this->attributes[$key] = $value;
}
$this->attributes['type'] = "metadata";
}
}
}
/**
* Class member get overloading
*
* @param string $name
* @return mixed
*/
function __get($name) {
return $this->get($name);
}
/**
* Class member set overloading
*
* @param string $name
* @param mixed $value
* @return mixed
*/
function __set($name, $value) {
return $this->set($name, $value);
}
/**
* Determines whether or not the user can edit this piece of metadata
*
* @return true|false Depending on permissions
*/
function canEdit() {
if ($entity = get_entity($this->get('entity_guid'))) {
return $entity->canEditMetadata($this);
}
return false;
}
/**
* Save matadata object
*
* @return int the metadata object id
*/
function save() {
if ($this->id > 0) {
return update_metadata($this->id, $this->name, $this->value, $this->value_type, $this->owner_guid, $this->access_id);
} else {
$this->id = create_metadata($this->entity_guid, $this->name, $this->value, $this->value_type, $this->owner_guid, $this->access_id);
if (!$this->id) {
throw new IOException(sprintf(elgg_echo('IOException:UnableToSaveNew'), get_class()));
}
return $this->id;
}
}
/**
* Delete a given metadata.
*/
function delete() {
return delete_metadata($this->id);
}
/**
* Get a url for this item of metadata.
*
* @return string
*/
public function getURL() {
return get_metadata_url($this->id);
}
// SYSTEM LOG INTERFACE ////////////////////////////////////////////////////////////
/**
* For a given ID, return the object associated with it.
* This is used by the river functionality primarily.
* This is useful for checking access permissions etc on objects.
*/
public function getObjectFromID($id) {
return get_metadata($id);
}
}
|