]> git.mxchange.org Git - friendica.git/blob - src/Core/Config/PreloadPConfigAdapter.php
002094a51692f00b85dd2ff5f7fa5bfaed5f2355
[friendica.git] / src / Core / Config / PreloadPConfigAdapter.php
1 <?php\r
2 \r
3 namespace Friendica\Core\Config;\r
4 \r
5 use dba;\r
6 use Exception;\r
7 use Friendica\BaseObject;\r
8 \r
9 require_once 'include/dba.php';\r
10 \r
11 /**\r
12  * Preload PConfigAdapter\r
13  *\r
14  * Minimize the number of database queries to retrieve configuration values at the cost of memory.\r
15  *\r
16  * @author Hypolite Petovan <mrpetovan@gmail.com>\r
17  */\r
18 class PreloadPConfigAdapter extends BaseObject implements IPConfigAdapter\r
19 {\r
20         private $config_loaded = false;\r
21 \r
22         public function __construct($uid)\r
23         {\r
24                 $this->load($uid, 'config');\r
25         }\r
26 \r
27         public function load($uid, $family)\r
28         {\r
29                 if ($this->config_loaded) {\r
30                         return;\r
31                 }\r
32 \r
33                 $a = self::getApp();\r
34 \r
35                 $pconfigs = dba::select('pconfig', ['cat', 'v', 'k'], ['uid' => $uid]);\r
36                 while ($pconfig = dba::fetch($pconfigs)) {\r
37                         $cat   = $pconfig['cat'];\r
38                         $k     = $pconfig['k'];\r
39                         $value = (preg_match("|^a:[0-9]+:{.*}$|s", $pconfig['v']) ? unserialize($pconfig['v']) : $pconfig['v']);\r
40 \r
41                         $a->config[$uid][$cat][$k] = $value;\r
42                 }\r
43                 dba::close($pconfigs);\r
44 \r
45                 $this->config_loaded = true;\r
46         }\r
47 \r
48         public function get($uid, $cat, $k, $default_value = null, $refresh = false)\r
49         {\r
50                 $a = self::getApp();\r
51 \r
52                 $return = $default_value;\r
53 \r
54                 if (isset($a->config[$uid][$cat][$k])) {\r
55                         $return = $a->config[$uid][$cat][$k];\r
56                 }\r
57 \r
58                 return $return;\r
59         }\r
60 \r
61         public function set($uid, $cat, $k, $value)\r
62         {\r
63                 $a = self::getApp();\r
64 \r
65                 // We store our setting values as strings.\r
66                 // So we have to do the conversion here so that the compare below works.\r
67                 // The exception are array values.\r
68                 $compare_value = !is_array($value) ? (string)$value : $value;\r
69 \r
70                 if ($this->get($uid, $cat, $k) === $compare_value) {\r
71                         return true;\r
72                 }\r
73 \r
74                 $a->config[$uid][$cat][$k] = $value;\r
75 \r
76                 // manage array value\r
77                 $dbvalue = is_array($value) ? serialize($value) : $value;\r
78 \r
79                 $result = dba::update('pconfig', ['v' => $dbvalue], ['uid' => $uid, 'cat' => $cat, 'k' => $k], true);\r
80 \r
81                 if (!$result) {\r
82                         throw new Exception('Unable to store config value in [' . $uid . '][' . $cat . '][' . $k . ']');\r
83                 }\r
84 \r
85                 return true;\r
86         }\r
87 \r
88         public function delete($uid, $cat, $k)\r
89         {\r
90                 $a = self::getApp();\r
91 \r
92                 if (!isset($a->config[$uid][$cat][$k])) {\r
93                         return true;\r
94                 }\r
95 \r
96                 unset($a->config[$uid][$cat][$k]);\r
97 \r
98                 $result = dba::delete('pconfig', ['uid' => $uid, 'cat' => $cat, 'k' => $k]);\r
99 \r
100                 return $result;\r
101         }\r
102 }\r