. * */ /** * Public interface of ownCloud for apps to use. * App Class. * */ // use OCP namespace for all classes that are considered public. // This means that they should be used by apps instead of the internal ownCloud classes namespace OCP; /** * This class provides functions to manage apps in ownCloud */ class App { /** * @brief makes owncloud aware of this app * @param $data array with all information * @returns true/false * * This function registers the application. $data is an associative array. * The following keys are required: * - id: id of the application, has to be unique ('addressbook') * - name: Human readable name ('Addressbook') * - version: array with Version (major, minor, bugfix) ( array(1, 0, 2)) * * The following keys are optional: * - order: integer, that influences the position of your application in * a list of applications. Lower values come first. * */ public static function register( $data ){ } /** * @brief adds an entry to the navigation * @param $data array containing the data * @returns true/false * * This function adds a new entry to the navigation visible to users. $data * is an associative array. * The following keys are required: * - id: unique id for this entry ('addressbook_index') * - href: link to the page * - name: Human readable name ('Addressbook') * * The following keys are optional: * - icon: path to the icon of the app * - order: integer, that influences the position of your application in * the navigation. Lower values come first. */ public static function addNavigationEntry( $data ){ return \OC_App::addNavigationEntry( $data ); } /** * @brief marks a navigation entry as active * @param $id id of the entry * @returns true/false * * This function sets a navigation entry as active and removes the 'active' * property from all other entries. The templates can use this for * highlighting the current position of the user. */ public static function setActiveNavigationEntry( $id ){ return \OC_App::setActiveNavigationEntry( $id ); } /** * @brief Register a Configuration Screen that should appear in the personal settings section. * @param $app string appid * @param $page string page to be included */ public static function registerPersonal( $app, $page ){ return \OC_App::registerPersonal( $app, $page ); } /** * @brief Register a Configuration Screen that should appear in the Admin section. * @param $app string appid * @param $page string page to be included */ public static function registerAdmin( $app, $page ){ return \OC_App::registerAdmin( $app, $page ); } /** * @brief Read app metadata from the info.xml file * @param string $app id of the app or the path of the info.xml file * @param boolean path (optional) * @returns array */ public static function getAppInfo( $app, $path=false ){ return \OC_App::getAppInfo( $app, $path); } /** * @brief checks whether or not an app is enabled * @param $app app * @returns true/false * * This function checks whether or not an app is enabled. */ public static function isEnabled( $app ){ return \OC_App::isEnabled( $app ); } /** * @brief Check if the app is enabled, redirects to home if not * @param $app app * @returns true/false */ public static function checkAppEnabled( $app ){ return \OC_Util::checkAppEnabled( $app ); } /** * @brief Get the last version of the app, either from appinfo/version or from appinfo/info.xml * @param $app app * @returns true/false */ public static function getAppVersion( $app ){ return \OC_App::getAppVersion( $app ); } } ?>