summaryrefslogtreecommitdiffstats
path: root/apps/updatenotification
diff options
context:
space:
mode:
authorblizzz <blizzz@arthur-schiwon.de>2018-09-05 18:03:04 +0200
committerGitHub <noreply@github.com>2018-09-05 18:03:04 +0200
commitd2803aeb5c43ad077bba7e496fa9a4c6d4a4d7a0 (patch)
treeb4d103642d4678053137efa532754336f3f680b0 /apps/updatenotification
parent59aad5dac648365199b221b01db8558d3ca0f9c1 (diff)
parentd492b2c3998ddf0395acaac2572097447eb01586 (diff)
downloadnextcloud-server-d2803aeb5c43ad077bba7e496fa9a4c6d4a4d7a0.tar.gz
nextcloud-server-d2803aeb5c43ad077bba7e496fa9a4c6d4a4d7a0.zip
Merge pull request #10836 from nextcloud/fix_8281
Add an occ command to report updates
Diffstat (limited to 'apps/updatenotification')
-rw-r--r--apps/updatenotification/appinfo/info.xml4
-rw-r--r--apps/updatenotification/composer/composer/autoload_classmap.php1
-rw-r--r--apps/updatenotification/composer/composer/autoload_static.php1
-rw-r--r--apps/updatenotification/lib/Command/Check.php96
4 files changed, 102 insertions, 0 deletions
diff --git a/apps/updatenotification/appinfo/info.xml b/apps/updatenotification/appinfo/info.xml
index a227ccd6557..4436e820b51 100644
--- a/apps/updatenotification/appinfo/info.xml
+++ b/apps/updatenotification/appinfo/info.xml
@@ -23,4 +23,8 @@
<settings>
<admin>OCA\UpdateNotification\Settings\Admin</admin>
</settings>
+
+ <commands>
+ <command>OCA\UpdateNotification\Command\Check</command>
+ </commands>
</info>
diff --git a/apps/updatenotification/composer/composer/autoload_classmap.php b/apps/updatenotification/composer/composer/autoload_classmap.php
index bc9474d5458..c6243dd76bc 100644
--- a/apps/updatenotification/composer/composer/autoload_classmap.php
+++ b/apps/updatenotification/composer/composer/autoload_classmap.php
@@ -7,6 +7,7 @@ $baseDir = $vendorDir;
return array(
'OCA\\UpdateNotification\\AppInfo\\Application' => $baseDir . '/../lib/AppInfo/Application.php',
+ 'OCA\\UpdateNotification\\Command\\Check' => $baseDir . '/../lib/Command/Check.php',
'OCA\\UpdateNotification\\Controller\\APIController' => $baseDir . '/../lib/Controller/APIController.php',
'OCA\\UpdateNotification\\Controller\\AdminController' => $baseDir . '/../lib/Controller/AdminController.php',
'OCA\\UpdateNotification\\Notification\\BackgroundJob' => $baseDir . '/../lib/Notification/BackgroundJob.php',
diff --git a/apps/updatenotification/composer/composer/autoload_static.php b/apps/updatenotification/composer/composer/autoload_static.php
index 1908e433941..b3f900c3f99 100644
--- a/apps/updatenotification/composer/composer/autoload_static.php
+++ b/apps/updatenotification/composer/composer/autoload_static.php
@@ -22,6 +22,7 @@ class ComposerStaticInitUpdateNotification
public static $classMap = array (
'OCA\\UpdateNotification\\AppInfo\\Application' => __DIR__ . '/..' . '/../lib/AppInfo/Application.php',
+ 'OCA\\UpdateNotification\\Command\\Check' => __DIR__ . '/..' . '/../lib/Command/Check.php',
'OCA\\UpdateNotification\\Controller\\APIController' => __DIR__ . '/..' . '/../lib/Controller/APIController.php',
'OCA\\UpdateNotification\\Controller\\AdminController' => __DIR__ . '/..' . '/../lib/Controller/AdminController.php',
'OCA\\UpdateNotification\\Notification\\BackgroundJob' => __DIR__ . '/..' . '/../lib/Notification/BackgroundJob.php',
diff --git a/apps/updatenotification/lib/Command/Check.php b/apps/updatenotification/lib/Command/Check.php
new file mode 100644
index 00000000000..f363832873b
--- /dev/null
+++ b/apps/updatenotification/lib/Command/Check.php
@@ -0,0 +1,96 @@
+<?php
+
+/**
+ *
+ * @copyright Copyright (c) 2018, Tobia De Koninck (tobia@ledfan.be)
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCA\UpdateNotification\Command;
+
+use OC\App\AppManager;
+use OC\Installer;
+use OCA\UpdateNotification\UpdateChecker;
+use Symfony\Component\Console\Command\Command;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+
+class Check extends Command {
+
+ /**
+ * @var Installer $installer
+ */
+ private $installer;
+
+ /**
+ * @var AppManager $appManager
+ */
+ private $appManager;
+
+ /**
+ * @var UpdateChecker $updateChecker
+ */
+ private $updateChecker;
+
+ public function __construct(AppManager $appManager, UpdateChecker $updateChecker, Installer $installer) {
+ parent::__construct();
+ $this->installer = $installer;
+ $this->appManager = $appManager;
+ $this->updateChecker = $updateChecker;
+ }
+
+ protected function configure() {
+ $this
+ ->setName('update:check')
+ ->setDescription('Check for server and app updates')
+ ;
+ }
+
+ protected function execute(InputInterface $input, OutputInterface $output) {
+ $updatesAvailableCount = 0;
+
+ // Server
+ $r = $this->updateChecker->getUpdateState();
+ if (isset($r['updateAvailable']) && $r['updateAvailable']) {
+ $output->writeln($r['updateVersion'] . ' is available. Get more information on how to update at '. $r['updateLink'] . '.');
+ $updatesAvailableCount += 1;
+ }
+
+
+ // Apps
+ $apps = $this->appManager->getInstalledApps();
+ foreach ($apps as $app) {
+ $update = $this->installer->isUpdateAvailable($app);
+ if ($update !== false) {
+ $output->writeln('Update for ' . $app . ' to version ' . $update . ' is available.');
+ $updatesAvailableCount += 1;
+ }
+ }
+
+ // Report summary
+ if ($updatesAvailableCount === 0) {
+ $output->writeln('<info>Everything up to date</info>');
+ } else if ($updatesAvailableCount === 1) {
+ $output->writeln('<comment>1 update available</comment>');
+ } else {
+ $output->writeln('<comment>' . $updatesAvailableCount . ' updates available</comment>');
+ }
+
+ return 0;
+ }
+}