diff options
author | Robin Appelman <icewind@owncloud.com> | 2012-03-30 14:39:07 +0200 |
---|---|---|
committer | Robin Appelman <icewind@owncloud.com> | 2012-03-30 14:39:07 +0200 |
commit | 523fdda39915dd49190727ac74458a28f2d00f10 (patch) | |
tree | bbf71b0c460074042159b94f9b4771dfd65e8bbe /lib | |
parent | a07c6b1a2ea66f00b3e85d480703ca06a4b241be (diff) | |
download | nextcloud-server-523fdda39915dd49190727ac74458a28f2d00f10.tar.gz nextcloud-server-523fdda39915dd49190727ac74458a28f2d00f10.zip |
add the option to only load apps of a specific type
Diffstat (limited to 'lib')
-rwxr-xr-x | lib/app.php | 51 | ||||
-rw-r--r-- | lib/base.php | 7 |
2 files changed, 52 insertions, 6 deletions
diff --git a/lib/app.php b/lib/app.php index fa0a1d22d15..6c882963a02 100755 --- a/lib/app.php +++ b/lib/app.php @@ -34,16 +34,20 @@ class OC_App{ static private $settingsForms = array(); static private $adminForms = array(); static private $personalForms = array(); + static private $appInfo = array(); /** * @brief loads all apps + * @param array $types * @returns true/false * * This function walks through the owncloud directory and loads all apps * it can find. A directory contains an app if the file /appinfo/app.php * exists. + * + * if $types is set, only apps of those types will be loaded */ - public static function loadApps(){ + public static function loadApps($types=null){ // Did we allready load everything? if( self::$init ){ return true; @@ -51,14 +55,18 @@ class OC_App{ // Our very own core apps are hardcoded foreach( array('files', 'settings') as $app ){ - require( $app.'/appinfo/app.php' ); + if(is_null($types) or self::isType($app,$types)){ + require( $app.'/appinfo/app.php' ); + } } // The rest comes here $apps = self::getEnabledApps(); foreach( $apps as $app ){ - if(is_file(OC::$APPSROOT.'/apps/'.$app.'/appinfo/app.php')){ - require( $app.'/appinfo/app.php' ); + if(is_null($types) or self::isType($app,$types)){ + if(is_file(OC::$APPSROOT.'/apps/'.$app.'/appinfo/app.php')){ + require( $app.'/appinfo/app.php' ); + } } } @@ -69,6 +77,28 @@ class OC_App{ } /** + * check if an app is of a sepcific type + * @param string $app + * @param string/array $types + */ + public static function isType($app,$types){ + if(is_string($types)){ + $types=array($types); + } + $appData=self::getAppInfo($app); + if(!isset($appData['types'])){ + return false; + } + $appTypes=$appData['types']; + foreach($types as $type){ + if(array_search($type,$appTypes)!==false){ + return true; + } + } + return false; + } + + /** * get all enabled apps */ public static function getEnabledApps(){ @@ -283,6 +313,9 @@ class OC_App{ if($path){ $file=$appid; }else{ + if(isset(self::$appInfo[$appid])){ + return self::$appInfo[$appid]; + } $file=OC::$APPSROOT.'/apps/'.$appid.'/appinfo/info.xml'; } $data=array(); @@ -293,8 +326,16 @@ class OC_App{ $xml = new SimpleXMLElement($content); $data['info']=array(); foreach($xml->children() as $child){ - $data[$child->getName()]=(string)$child; + if($child->getName()=='types'){ + $data['types']=array(); + foreach($child->children() as $type){ + $data['types'][]=$type->getName(); + } + }else{ + $data[$child->getName()]=(string)$child; + } } + self::$appInfo[$appid]=$data; return $data; } diff --git a/lib/base.php b/lib/base.php index b07ac5af416..b031572f177 100644 --- a/lib/base.php +++ b/lib/base.php @@ -333,8 +333,13 @@ class OC{ // Load Apps // This includes plugins for users and filesystems as well global $RUNTIME_NOAPPS; + global $RUNTIME_APPTYPES; if(!$RUNTIME_NOAPPS ){ - OC_App::loadApps(); + if($RUNTIME_APPTYPES){ + OC_App::loadApps($RUNTIME_APPTYPES); + }else{ + OC_App::loadApps(); + } } //make sure temporary files are cleaned up |