summaryrefslogtreecommitdiffstats
path: root/apps/updatenotification/lib
diff options
context:
space:
mode:
Diffstat (limited to 'apps/updatenotification/lib')
-rw-r--r--apps/updatenotification/lib/Notification/BackgroundJob.php20
1 files changed, 15 insertions, 5 deletions
diff --git a/apps/updatenotification/lib/Notification/BackgroundJob.php b/apps/updatenotification/lib/Notification/BackgroundJob.php
index 3a89f3813e6..e455a1642f4 100644
--- a/apps/updatenotification/lib/Notification/BackgroundJob.php
+++ b/apps/updatenotification/lib/Notification/BackgroundJob.php
@@ -30,6 +30,7 @@ use OCP\Http\Client\IClientService;
use OCP\IConfig;
use OCP\IGroup;
use OCP\IGroupManager;
+use OCP\IURLGenerator;
use OCP\IUser;
use OCP\Notification\IManager;
@@ -50,6 +51,9 @@ class BackgroundJob extends TimedJob {
/** @var IClientService */
protected $client;
+ /** @var IURLGenerator */
+ protected $urlGenerator;
+
/** @var IUser[] */
protected $users;
@@ -61,8 +65,9 @@ class BackgroundJob extends TimedJob {
* @param IGroupManager $groupManager
* @param IAppManager $appManager
* @param IClientService $client
+ * @param IURLGenerator $urlGenerator
*/
- public function __construct(IConfig $config, IManager $notificationManager, IGroupManager $groupManager, IAppManager $appManager, IClientService $client) {
+ public function __construct(IConfig $config, IManager $notificationManager, IGroupManager $groupManager, IAppManager $appManager, IClientService $client, IURLGenerator $urlGenerator) {
// Run once a day
$this->setInterval(60 * 60 * 24);
@@ -71,6 +76,7 @@ class BackgroundJob extends TimedJob {
$this->groupManager = $groupManager;
$this->appManager = $appManager;
$this->client = $client;
+ $this->urlGenerator = $urlGenerator;
}
protected function run($argument) {
@@ -91,7 +97,8 @@ class BackgroundJob extends TimedJob {
$status = $updater->check();
if (isset($status['version'])) {
- $this->createNotifications('core', $status['version']);
+ $url = $this->urlGenerator->linkToRouteAbsolute('settings_admin') . '#updater';
+ $this->createNotifications('core', $status['version'], $url);
}
}
@@ -103,7 +110,8 @@ class BackgroundJob extends TimedJob {
foreach ($apps as $app) {
$update = $this->isUpdateAvailable($app);
if ($update !== false) {
- $this->createNotifications($app, $update);
+ $url = $this->urlGenerator->linkToRouteAbsolute('settings.AppSettings.viewApps') . '#app-' . $app;
+ $this->createNotifications($app, $update, $url);
}
}
}
@@ -113,8 +121,9 @@ class BackgroundJob extends TimedJob {
*
* @param string $app
* @param string $version
+ * @param string $url
*/
- protected function createNotifications($app, $version) {
+ protected function createNotifications($app, $version, $url) {
$lastNotification = $this->config->getAppValue('updatenotification', $app, false);
if ($lastNotification === $version) {
// We already notified about this update
@@ -129,7 +138,8 @@ class BackgroundJob extends TimedJob {
$notification->setApp('updatenotification')
->setDateTime(new \DateTime())
->setObject($app, $version)
- ->setSubject('update_available');
+ ->setSubject('update_available')
+ ->setLink($url);
foreach ($this->getUsersToNotify() as $uid) {
$notification->setUser($uid);