diff options
author | Tobia De Koninck <LEDfan@users.noreply.github.com> | 2018-08-24 16:25:48 +0200 |
---|---|---|
committer | Tobia De Koninck <LEDfan@users.noreply.github.com> | 2018-08-27 12:11:31 +0200 |
commit | d2a5790053524437b907f616a7dea4016d79ac70 (patch) | |
tree | 63cc92e1d374b6b7da4b9fbc4e8f2437a0b07537 | |
parent | 8b47f45afa3b7837032d6ce1cfcda1c901ae840f (diff) | |
download | nextcloud-server-d2a5790053524437b907f616a7dea4016d79ac70.tar.gz nextcloud-server-d2a5790053524437b907f616a7dea4016d79ac70.zip |
Add an occ command to report updates
Signed-off-by: Tobia De Koninck <LEDfan@users.noreply.github.com>
4 files changed, 68 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..bca89adaa54 --- /dev/null +++ b/apps/updatenotification/lib/Command/Check.php @@ -0,0 +1,62 @@ +<?php + +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) { + // Server + $r = $this->updateChecker->getUpdateState(); + if ($r['updateAvailable']) { + $output->writeln($r['updateVersion'] . ' is available. Get more information on how to update at '. $r['updateLink'] . '.'); + } + + + // 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.'); + } + } + + return 0; + } +} |