зеркало из https://github.com/nextcloud/server.git
Move getAppInfo and getAppVersion to IAppManager
Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
Родитель
1429146083
Коммит
19a0a9a4e7
|
@ -80,6 +80,12 @@ class AppManager implements IAppManager {
|
|||
/** @var string[] */
|
||||
private $alwaysEnabled;
|
||||
|
||||
/** @var array */
|
||||
private $appInfos = [];
|
||||
|
||||
/** @var array */
|
||||
private $appVersions = [];
|
||||
|
||||
/**
|
||||
* @param IUserSession $userSession
|
||||
* @param AppConfig $appConfig
|
||||
|
@ -341,17 +347,45 @@ class AppManager implements IAppManager {
|
|||
*
|
||||
* @param string $appId app id
|
||||
*
|
||||
* @param bool $path
|
||||
* @param null $lang
|
||||
* @return array app info
|
||||
*
|
||||
* @internal
|
||||
*/
|
||||
public function getAppInfo($appId) {
|
||||
$appInfo = \OC_App::getAppInfo($appId);
|
||||
if (!isset($appInfo['version'])) {
|
||||
// read version from separate file
|
||||
$appInfo['version'] = \OC_App::getAppVersion($appId);
|
||||
public function getAppInfo(string $appId, bool $path = false, $lang = null) {
|
||||
if ($path) {
|
||||
$file = $appId;
|
||||
} else {
|
||||
if ($lang === null && isset($this->appInfos[$appId])) {
|
||||
return $this->appInfos[$appId];
|
||||
}
|
||||
try {
|
||||
$appPath = $this->getAppPath($appId);
|
||||
} catch (AppPathNotFoundException $e) {
|
||||
return null;
|
||||
}
|
||||
$file = $appPath . '/appinfo/info.xml';
|
||||
}
|
||||
return $appInfo;
|
||||
|
||||
$parser = new InfoParser($this->memCacheFactory->createLocal('core.appinfo'));
|
||||
$data = $parser->parse($file);
|
||||
|
||||
if (is_array($data)) {
|
||||
$data = \OC_App::parseAppInfo($data, $lang);
|
||||
}
|
||||
|
||||
if ($lang === null) {
|
||||
$this->appInfos[$appId] = $data;
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
public function getAppVersion(string $appId, bool $useCache = true) {
|
||||
if(!$useCache || !isset($this->appVersions[$appId])) {
|
||||
$appInfo = \OC::$server->getAppManager()->getAppInfo($appId);
|
||||
$this->appVersions[$appId] = ($appInfo !== null) ? $appInfo['version'] : '0';
|
||||
}
|
||||
return $this->appVersions[$appId];
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -50,7 +50,6 @@
|
|||
*
|
||||
*/
|
||||
use OC\App\DependencyAnalyzer;
|
||||
use OC\App\InfoParser;
|
||||
use OC\App\Platform;
|
||||
use OC\DB\MigrationService;
|
||||
use OC\Installer;
|
||||
|
@ -63,10 +62,8 @@ use OCP\App\ManagerEvent;
|
|||
* upgrading and removing apps.
|
||||
*/
|
||||
class OC_App {
|
||||
static private $appVersion = [];
|
||||
static private $adminForms = array();
|
||||
static private $personalForms = array();
|
||||
static private $appInfo = array();
|
||||
static private $appTypes = array();
|
||||
static private $loadedApps = array();
|
||||
static private $altLogin = array();
|
||||
|
@ -590,15 +587,10 @@ class OC_App {
|
|||
* @param string $appId
|
||||
* @param bool $useCache
|
||||
* @return string
|
||||
* @deprecated 14.0.0 use \OC::$server->getAppManager()->getAppVersion()
|
||||
*/
|
||||
public static function getAppVersion($appId, $useCache = true) {
|
||||
if($useCache && isset(self::$appVersion[$appId])) {
|
||||
return self::$appVersion[$appId];
|
||||
}
|
||||
|
||||
$file = self::getAppPath($appId);
|
||||
self::$appVersion[$appId] = ($file !== false) ? self::getAppVersionByPath($file) : '0';
|
||||
return self::$appVersion[$appId];
|
||||
return \OC::$server->getAppManager()->getAppVersion($appId, $useCache);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -609,7 +601,7 @@ class OC_App {
|
|||
*/
|
||||
public static function getAppVersionByPath($path) {
|
||||
$infoFile = $path . '/appinfo/info.xml';
|
||||
$appData = self::getAppInfo($infoFile, true);
|
||||
$appData = \OC::$server->getAppManager()->getAppInfo($infoFile, true);
|
||||
return isset($appData['version']) ? $appData['version'] : '';
|
||||
}
|
||||
|
||||
|
@ -622,39 +614,10 @@ class OC_App {
|
|||
* @param string $lang
|
||||
* @return array|null
|
||||
* @note all data is read from info.xml, not just pre-defined fields
|
||||
* @deprecated 14.0.0 use \OC::$server->getAppManager()->getAppInfo()
|
||||
*/
|
||||
public static function getAppInfo($appId, $path = false, $lang = null) {
|
||||
if ($path) {
|
||||
$file = $appId;
|
||||
} else {
|
||||
if ($lang === null && isset(self::$appInfo[$appId])) {
|
||||
return self::$appInfo[$appId];
|
||||
}
|
||||
$appPath = self::getAppPath($appId);
|
||||
if($appPath === false) {
|
||||
return null;
|
||||
}
|
||||
$file = $appPath . '/appinfo/info.xml';
|
||||
}
|
||||
|
||||
$parser = new InfoParser(\OC::$server->getMemCacheFactory()->createLocal('core.appinfo'));
|
||||
$data = $parser->parse($file);
|
||||
|
||||
if (is_array($data)) {
|
||||
$data = OC_App::parseAppInfo($data, $lang);
|
||||
}
|
||||
if(isset($data['ocsid'])) {
|
||||
$storedId = \OC::$server->getConfig()->getAppValue($appId, 'ocsid');
|
||||
if($storedId !== '' && $storedId !== $data['ocsid']) {
|
||||
$data['ocsid'] = $storedId;
|
||||
}
|
||||
}
|
||||
|
||||
if ($lang === null) {
|
||||
self::$appInfo[$appId] = $data;
|
||||
}
|
||||
|
||||
return $data;
|
||||
return \OC::$server->getAppManager()->getAppInfo($appId, $path, $lang);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1068,7 +1031,8 @@ class OC_App {
|
|||
|
||||
self::executeRepairSteps($appId, $appData['repair-steps']['post-migration']);
|
||||
self::setupLiveMigrations($appId, $appData['repair-steps']['live-migration']);
|
||||
unset(self::$appVersion[$appId]);
|
||||
// update appversion in app manager
|
||||
\OC::$server->getAppManager()->getAppVersion($appId, false);
|
||||
|
||||
// run upgrade code
|
||||
if (file_exists($appPath . '/appinfo/update.php')) {
|
||||
|
|
|
@ -114,6 +114,7 @@ class App {
|
|||
* @param string $app id of the app or the path of the info.xml file
|
||||
* @param boolean $path (optional)
|
||||
* @return array|null
|
||||
* @deprecated 14.0.0 ise \OC::$server->getAppManager()->getAppInfo($appId)
|
||||
* @since 4.0.0
|
||||
*/
|
||||
public static function getAppInfo( $app, $path=false ) {
|
||||
|
@ -148,8 +149,9 @@ class App {
|
|||
* @param string $app
|
||||
* @return string
|
||||
* @since 4.0.0
|
||||
* @deprecated 14.0.0 use \OC::$server->getAppManager()->getAppVersion($appId)
|
||||
*/
|
||||
public static function getAppVersion( $app ) {
|
||||
return \OC_App::getAppVersion( $app );
|
||||
return \OC::$server->getAppManager()->getAppVersion($app);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -36,6 +36,26 @@ use OCP\IUser;
|
|||
* @since 8.0.0
|
||||
*/
|
||||
interface IAppManager {
|
||||
|
||||
/**
|
||||
* Returns the app information from "appinfo/info.xml".
|
||||
*
|
||||
* @param string $appId
|
||||
* @return mixed
|
||||
* @since 14.0.0
|
||||
*/
|
||||
public function getAppInfo(string $appId, bool $path = false, $lang = null);
|
||||
|
||||
/**
|
||||
* Returns the app information from "appinfo/info.xml".
|
||||
*
|
||||
* @param string $appId
|
||||
* @param bool $useCache
|
||||
* @return mixed
|
||||
* @since 14.0.0
|
||||
*/
|
||||
public function getAppVersion(string $appId, bool $useCache = true);
|
||||
|
||||
/**
|
||||
* Check if an app is enabled for user
|
||||
*
|
||||
|
|
Загрузка…
Ссылка в новой задаче