<?php /** * StatusNet, the distributed open-source microblogging tool * * Data class for Profile preferences * * PHP version 5 * * LICENCE: This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * @category Data * @package GNUsocial * @author Mikael Nordfeldth <mmn@hethane.se> * @copyright 2013 Free Software Foundation, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://www.gnu.org/software/social/ */ class Profile_prefs extends Managed_DataObject { public $__table = 'profile_prefs'; // table name public $profile_id; // int(4) primary_key not_null public $namespace; // varchar(255) not_null public $topic; // varchar(255) not_null public $data; // text public $created; // datetime not_null default_0000-00-00%2000%3A00%3A00 public $modified; // timestamp not_null default_CURRENT_TIMESTAMP public static function schemaDef() { return array( 'fields' => array( 'profile_id' => array('type' => 'int', 'not null' => true, 'description' => 'user'), 'namespace' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'namespace, like pluginname or category'), 'topic' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'preference key, i.e. description, age...'), 'data' => array('type' => 'blob', 'description' => 'topic data, may be anything'), 'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'), 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'), ), 'primary key' => array('profile_id', 'namespace', 'topic'), 'foreign keys' => array( 'profile_prefs_profile_id_fkey' => array('profile', array('profile_id' => 'id')), ), 'indexes' => array( 'profile_prefs_profile_id_idx' => array('profile_id'), ), ); } static function getNamespacePrefs(Profile $profile, $namespace, array $topic=array()) { if (empty($topic)) { $prefs = new Profile_prefs(); $prefs->profile_id = $profile->id; $prefs->namespace = $namespace; $prefs->find(); } else { $prefs = self::pivotGet('profile_id', $profile->id, array('namespace'=>$namespace, 'topic'=>$topic)); } if (empty($prefs->N)) { throw new NoResultException($prefs); } return $prefs; } static function getNamespace(Profile $profile, $namespace, array $topic=array()) { $prefs = self::getNamespacePrefs($profile, $namespace, $topic); return $prefs->fetchAll(); } static function getAll(Profile $profile) { try { $prefs = self::listFind('profile_id', $profile->id); } catch (NoResultException $e) { return array(); } $list = array(); while ($entry = $prefs->fetch()) { if (!isset($list[$entry->namespace])) { $list[$entry->namespace] = array(); } $list[$entry->namespace][$entry->topic] = $entry->data; } return $list; } static function getTopic(Profile $profile, $namespace, $topic) { $pref = new Profile_prefs; $pref->profile_id = $profile->id; $pref->namespace = $namespace; $pref->topic = $topic; if (!$pref->find(true)) { throw new NoResultException($pref); } return $pref; } static function getData(Profile $profile, $namespace, $topic) { $pref = self::getTopic($profile, $namespace, $topic); return $pref->data; } static function getConfigData(Profile $profile, $namespace, $topic) { try { $data = self::getData($profile, $namespace, $topic); } catch (NoResultException $e) { $data = common_config($namespace, $topic); } return $data; } /* * Sets a profile preference based on Profile, namespace and topic * * @param Profile $profile Which profile this is for * @param string $namespace Under which namespace (pluginname etc.) * @param string $topic Preference name (think key in key-val store) * @param string $data Data to be put into preference storage, null means delete * * @return true if changes are made, false if no action taken * @throws ServerException if preference could not be saved */ static function setData(Profile $profile, $namespace, $topic, $data=null) { try { $pref = self::getTopic($profile, $namespace, $topic); if (is_null($data)) { $pref->delete(); } else { $orig = clone($pref); $pref->data = $data; $pref->update($orig); } return true; } catch (NoResultException $e) { if (is_null($data)) { return false; // No action taken } } $pref = new Profile_prefs(); $pref->profile_id = $profile->id; $pref->namespace = $namespace; $pref->topic = $topic; $pref->data = $data; if ($pref->insert() === false) { throw new ServerException('Could not save profile preference.'); } return true; } }