Blame view

sources/lib/public/iappconfig.php 2.14 KB
6d9380f96   Cédric Dupont   Update sources OC...
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
  <?php
  /**
   * Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
   * This file is licensed under the Affero General Public License version 3 or
   * later.
   * See the COPYING-README file.
   */
  namespace OCP;
  
  /**
   * This class provides an easy way for apps to store config values in the
   * database.
   */
  interface IAppConfig {
  	/**
  	 * check if a key is set in the appconfig
  	 * @param string $app
  	 * @param string $key
  	 * @return bool
  	 */
  	public function hasKey($app, $key);
  
  	/**
  	 * Gets the config value
  	 * @param string $app app
  	 * @param string $key key
  	 * @param string $default = null, default value if the key does not exist
  	 * @return string the value or $default
  	 *
  	 * This function gets a value from the appconfig table. If the key does
  	 * not exist the default value will be returned
  	 */
  	public function getValue($app, $key, $default = null);
  
  	/**
  	 * Deletes a key
  	 * @param string $app app
  	 * @param string $key key
  	 * @return bool
  	 *
  	 * Deletes a key.
  	 */
  	public function deleteKey($app, $key);
  
  	/**
  	 * Get the available keys for an app
  	 * @param string $app the app we are looking for
  	 * @return array an array of key names
  	 *
  	 * This function gets all keys of an app. Please note that the values are
  	 * not returned.
  	 */
  	public function getKeys($app);
  
  	/**
  	 * get multiply values, either the app or key can be used as wildcard by setting it to false
  	 *
  	 * @param string|false $key
  	 * @param string|false $app
  	 * @return array
  	 */
  	public function getValues($app, $key);
  
  	/**
  	 * sets a value in the appconfig
  	 * @param string $app app
  	 * @param string $key key
  	 * @param string $value value
  	 *
  	 * Sets a value. If the key did not exist before it will be created.
  	 * @return void
  	 */
  	public function setValue($app, $key, $value);
  
  	/**
  	 * Get all apps using the config
  	 * @return array an array of app ids
  	 *
  	 * This function returns a list of all apps that have at least one
  	 * entry in the appconfig table.
  	 */
  	public function getApps();
  
  	/**
  	 * Remove app from appconfig
  	 * @param string $app app
  	 * @return bool
  	 *
  	 * Removes all keys in appconfig belonging to the app.
  	 */
  	public function deleteApp($app);
  }