summaryrefslogtreecommitdiffstats
path: root/lib/preferences.php
diff options
context:
space:
mode:
authorJakob Sack <kde@jakobsack.de>2011-03-12 10:28:10 +0100
committerJakob Sack <kde@jakobsack.de>2011-03-12 10:28:10 +0100
commit1aa7fd98c2e9fc20ede32fb6716e35b0827b6a91 (patch)
tree40e14348efbec8cdecf2d5ea406c68a4061838e8 /lib/preferences.php
parent883c7a582de8e9f9455751927069755e74fbd1e3 (diff)
downloadnextcloud-server-1aa7fd98c2e9fc20ede32fb6716e35b0827b6a91.tar.gz
nextcloud-server-1aa7fd98c2e9fc20ede32fb6716e35b0827b6a91.zip
Refactoring OC_APPCONFIG and OC_PREFERENCES, minor changes to OC_APP. These libraries are skeletons only, the functions need to be written.
Diffstat (limited to 'lib/preferences.php')
-rw-r--r--lib/preferences.php160
1 files changed, 144 insertions, 16 deletions
diff --git a/lib/preferences.php b/lib/preferences.php
index bd4ff55cc5c..a7a2911cac7 100644
--- a/lib/preferences.php
+++ b/lib/preferences.php
@@ -1,34 +1,162 @@
<?php
+/**
+ * ownCloud
+ *
+ * @author Frank Karlitschek
+ * @author Jakob Sack
+ * @copyright 2010 Frank Karlitschek karlitschek@kde.org
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or any later version.
+ *
+ * This library 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 library. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+/*
+ *
+ * The following SQL statement is just a help for developers and will not be
+ * executed!
+ *
+ * CREATE TABLE `preferences` (
+ * `userid` VARCHAR( 255 ) NOT NULL ,
+ * `appid` VARCHAR( 255 ) NOT NULL ,
+ * `key` VARCHAR( 255 ) NOT NULL ,
+ * `value` VARCHAR( 255 ) NOT NULL
+ * )
+ *
+ */
+
+/**
+ * This class provides an easy way for storing user preferences.
+ */
class OC_PREFERENCES{
- static public $forms=array();
/**
- * Get the available keys for an application
- * @param string application
+ * @brief Get all users using the preferences
+ * @returns array with user ids
+ *
+ * This function returns a list of all users that have at least one entry
+ * in the preferences table.
*/
- public static function getKeys( $user, $application ){
- // OC_DB::query( $query);
+ public static function getUsers(){
+ // TODO: write function
return array();
}
/**
- * Get the config value
- * @param string application
- * @param string key
- * @param string default
+ * @brief Get all apps of a user
+ * @param $user user
+ * @returns array with app ids
+ *
+ * This function returns a list of all apps of the userthat have at least
+ * one entry in the preferences table.
*/
- public static function getValue( $user, $application, $key, $default ){
+ public static function getApps( $user ){
+ // TODO: write function
+ return array();
+ }
+
+ /**
+ * @brief Get the available keys for an app
+ * @param $user user
+ * @param $app the app we are looking for
+ * @returns array with key names
+ *
+ * This function gets all keys of an app of an user. Please note that the
+ * values are not returned.
+ */
+ public static function getKeys( $user, $app ){
+ // TODO: write function
+ return array();
+ }
+
+ /**
+ * @brief Gets the preference
+ * @param $user user
+ * @param $app app
+ * @param $key key
+ * @param $default = null, default value if the key does not exist
+ * @returns the value or $default
+ *
+ * This function gets a value from the prefernces table. If the key does
+ * not exist the default value will be returnes
+ */
+ public static function getValue( $user, $app, $key, $default = null ){
// OC_DB::query( $query);
return $default;
}
/**
- * Set the config value
- * @param string application
- * @param string key
- * @param string value
+ * @brief sets a value in the preferences
+ * @param $user user
+ * @param $app app
+ * @param $key key
+ * @param $value value
+ * @returns true/false
+ *
+ * Adds a value to the preferences. If the key did not exist before, it
+ * will be added automagically.
*/
- public static function setValue( $user, $application, $name, $url ){
- // OC_DB::query( $query);
+ public static function setValue( $user, $app, $key, $value ){
+ // TODO: write function
+ return true;
+ }
+
+ /**
+ * @brief Deletes a key
+ * @param $user user
+ * @param $app app
+ * @param $key key
+ * @returns true/false
+ *
+ * Deletes a key.
+ */
+ public static function deleteKey( $user, $app, $key ){
+ // TODO: write function
+ return true;
+ }
+
+ /**
+ * @brief Remove app of user from preferences
+ * @param $user user
+ * @param $app app
+ * @returns true/false
+ *
+ * Removes all keys in appconfig belonging to the app and the user.
+ */
+ public static function deleteApp( $user, $app ){
+ // TODO: write function
+ return true;
+ }
+
+ /**
+ * @brief Remove user from preferences
+ * @param $user user
+ * @returns true/false
+ *
+ * Removes all keys in appconfig belonging to the user.
+ */
+ public static function deleteUser( $user ){
+ // TODO: write function
+ return true;
+ }
+
+ /**
+ * @brief Remove app from all users
+ * @param $app app
+ * @returns true/false
+ *
+ * Removes all keys in preferences belonging to the app.
+ */
+ public static function deleteAppFromAllUsers( $app ){
+ // TODO: write function
return true;
}
}