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;
+ }
+}