X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=classes%2FConfig.php;h=e14730438eb306936c81652c6b8897df04398ea8;hb=d9f27fcb148681f31e55a22ac911b0ea3d6a7940;hp=5bec13fdc8d92a8d663745b895fedabc5292e366;hpb=8236037bf0bff51d4bc623646454f39eec4bc6ec;p=quix0rs-gnu-social.git diff --git a/classes/Config.php b/classes/Config.php old mode 100755 new mode 100644 index 5bec13fdc8..e14730438e --- a/classes/Config.php +++ b/classes/Config.php @@ -17,7 +17,9 @@ * along with this program. If not, see . */ -if (!defined('LACONICA')) { exit(1); } +if (!defined('STATUSNET')) { + exit(1); +} /** * Table Definition for config @@ -56,8 +58,8 @@ class Config extends Memcached_DataObject $c = self::memcache(); if (!empty($c)) { - $settings = $c->get(common_cache_key(self::settingsKey)); - if (!empty($settings)) { + $settings = $c->get(Cache::key(self::settingsKey)); + if ($settings !== false) { return $settings; } } @@ -75,7 +77,7 @@ class Config extends Memcached_DataObject $config->free(); if (!empty($c)) { - $c->set(common_cache_key(self::settingsKey), $settings); + $c->set(Cache::key(self::settingsKey), $settings); } return $settings; @@ -118,12 +120,41 @@ class Config extends Memcached_DataObject return $result; } + function pkeyGet($kv) + { + return Memcached_DataObject::pkeyGet('Config', $kv); + } + + static function save($section, $setting, $value) + { + $result = null; + + $config = Config::pkeyGet(array('section' => $section, + 'setting' => $setting)); + + if (!empty($config)) { + $orig = clone($config); + $config->value = $value; + $result = $config->update($orig); + } else { + $config = new Config(); + + $config->section = $section; + $config->setting = $setting; + $config->value = $value; + + $result = $config->insert(); + } + + return $result; + } + function _blowSettingsCache() { $c = self::memcache(); if (!empty($c)) { - $c->delete(common_cache_key(self::settingsKey)); + $c->delete(Cache::key(self::settingsKey)); } } }