summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2017-05-22 09:54:44 +0200
committerJoas Schilling <coding@schilljs.com>2017-05-22 09:54:44 +0200
commiteebd2811dc4427443f7be964be25c3596ef7e950 (patch)
tree5181c4cb24a605554baa45e6138bf0d442223ee4 /lib
parente102923a978d83268c04a3a5bf678054a845a58e (diff)
downloadnextcloud-server-eebd2811dc4427443f7be964be25c3596ef7e950.tar.gz
nextcloud-server-eebd2811dc4427443f7be964be25c3596ef7e950.zip
Version and dependency are now required
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/App/CodeChecker/InfoChecker.php38
1 files changed, 7 insertions, 31 deletions
diff --git a/lib/private/App/CodeChecker/InfoChecker.php b/lib/private/App/CodeChecker/InfoChecker.php
index 1e617e3aeec..e8791bd7037 100644
--- a/lib/private/App/CodeChecker/InfoChecker.php
+++ b/lib/private/App/CodeChecker/InfoChecker.php
@@ -34,15 +34,16 @@ class InfoChecker extends BasicEmitter {
private $mandatoryFields = [
'author',
'description',
+ 'dependencies',
'id',
'licence',
'name',
+ 'version',
];
private $optionalFields = [
'bugs',
'category',
'default_enable',
- 'dependencies', // TODO: Mandatory as of ownCloud 11
'documentation',
'namespace',
'ocsid',
@@ -50,7 +51,6 @@ class InfoChecker extends BasicEmitter {
'remote',
'repository',
'types',
- 'version',
'website',
];
private $deprecatedFields = [
@@ -80,29 +80,19 @@ class InfoChecker extends BasicEmitter {
$info = $this->infoParser->parse($appPath . '/appinfo/info.xml');
- if (isset($info['dependencies']['owncloud']['@attributes']['min-version']) && (isset($info['requiremin']) || isset($info['require']))) {
- $this->emit('InfoChecker', 'duplicateRequirement', ['min']);
+ if (!isset($info['dependencies']['nextcloud']['@attributes']['min-version'])) {
$errors[] = [
- 'type' => 'duplicateRequirement',
+ 'type' => 'missingRequirement',
'field' => 'min',
];
- } else if (
- !isset($info['dependencies']['owncloud']['@attributes']['min-version']) &&
- !isset($info['dependencies']['nextcloud']['@attributes']['min-version'])
- ) {
$this->emit('InfoChecker', 'missingRequirement', ['min']);
}
- if (isset($info['dependencies']['owncloud']['@attributes']['max-version']) && isset($info['requiremax'])) {
- $this->emit('InfoChecker', 'duplicateRequirement', ['max']);
+ if (!isset($info['dependencies']['nextcloud']['@attributes']['max-version'])) {
$errors[] = [
- 'type' => 'duplicateRequirement',
+ 'type' => 'missingRequirement',
'field' => 'max',
];
- } else if (
- !isset($info['dependencies']['owncloud']['@attributes']['max-version']) &&
- !isset($info['dependencies']['nextcloud']['@attributes']['max-version'])
- ) {
$this->emit('InfoChecker', 'missingRequirement', ['max']);
}
@@ -145,21 +135,7 @@ class InfoChecker extends BasicEmitter {
$versionFile = $appPath . '/appinfo/version';
if (is_file($versionFile)) {
$version = trim(file_get_contents($versionFile));
- if (isset($info['version'])) {
- if($info['version'] !== $version) {
- $this->emit('InfoChecker', 'differentVersions',
- [$version, $info['version']]);
- $errors[] = [
- 'type' => 'differentVersions',
- 'message' => 'appinfo/version: ' . $version .
- ' - appinfo/info.xml: ' . $info['version'],
- ];
- } else {
- $this->emit('InfoChecker', 'sameVersions', [$versionFile]);
- }
- } else {
- $this->emit('InfoChecker', 'migrateVersion', [$version]);
- }
+ $this->emit('InfoChecker', 'migrateVersion', [$version]);
}
return $errors;