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
|
<?php
/**
* ElggMetadata
* This class describes metadata that can be attached to ElggEntities.
*
* @package Elgg.Core
* @subpackage Metadata
*/
class ElggMetadata extends ElggExtender {
protected function initializeAttributes() {
parent::initializeAttributes();
$this->attributes['type'] = "metadata";
}
/**
* Construct a new site object, optionally from a given id value or row.
*
* @param mixed $id ID of metadata from DB
*
* @return void
*/
function __construct($id = null) {
$this->initializeAttributes();
if (!empty($id)) {
// Create from db row
if ($id instanceof stdClass) {
$metadata = $id;
} else {
$metadata = elgg_get_metadata_from_id($id);
}
if ($metadata) {
$objarray = (array) $metadata;
foreach ($objarray as $key => $value) {
$this->attributes[$key] = $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(elgg_echo('IOException:UnableToSaveNew', array(get_class())));
}
return $this->id;
}
}
/**
* Delete a given metadata.
*
* @return bool
*/
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.
*
* @param int $id Metadata ID
*
* @return ElggMetadata
*/
public function getObjectFromID($id) {
return elgg_get_metadata_from_id($id);
}
}
|