diff --git a/apps/updatenotification/appinfo/info.xml b/apps/updatenotification/appinfo/info.xml index a227ccd655..4436e820b5 100644 --- a/apps/updatenotification/appinfo/info.xml +++ b/apps/updatenotification/appinfo/info.xml @@ -23,4 +23,8 @@ OCA\UpdateNotification\Settings\Admin + + + OCA\UpdateNotification\Command\Check + diff --git a/apps/updatenotification/composer/composer/autoload_classmap.php b/apps/updatenotification/composer/composer/autoload_classmap.php index bc9474d545..c6243dd76b 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 1908e43394..b3f900c3f9 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 0000000000..f363832873 --- /dev/null +++ b/apps/updatenotification/lib/Command/Check.php @@ -0,0 +1,96 @@ +. + * + */ + +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('Everything up to date'); + } else if ($updatesAvailableCount === 1) { + $output->writeln('1 update available'); + } else { + $output->writeln('' . $updatesAvailableCount . ' updates available'); + } + + return 0; + } +}