blob: 3bbbc02fe748d6abc599b277b788e66c1f218b77 (
plain)
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
|
<?php
/**
* Stores site-side plugin settings as private data.
*
* This class is currently a stub, allowing a plugin to
* save settings in an object's private settings for each site.
*
* @package Elgg.Core
* @subpackage Plugins.Settings
*/
class ElggPlugin extends ElggObject {
protected function initialise_attributes() {
parent::initialise_attributes();
$this->attributes['subtype'] = "plugin";
}
public function __construct($guid = null) {
parent::__construct($guid);
}
/**
* Get a value from private settings.
*
* @param string $name
* @return mixed
*/
public function get($name) {
// See if its in our base attribute
if (isset($this->attributes[$name])) {
return $this->attributes[$name];
}
// No, so see if its in the private data store.
// get_private_setting() returns false if it doesn't exist
$meta = get_private_setting($this->guid, $name);
if ($meta === false) {
// Can't find it, so return null
return NULL;
}
return $meta;
}
/**
* Save a value to private settings.
*
* @param string $name
* @param mixed $value
*/
public function set($name, $value) {
if (array_key_exists($name, $this->attributes)) {
// Check that we're not trying to change the guid!
if ((array_key_exists('guid', $this->attributes)) && ($name=='guid')) {
return false;
}
$this->attributes[$name] = $value;
} else {
return set_private_setting($this->guid, $name, $value);
}
return true;
}
}
|