summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorBjoern Schiessle <bjoern@schiessle.org>2016-11-23 21:19:06 +0100
committerBjoern Schiessle <bjoern@schiessle.org>2016-11-25 10:26:47 +0100
commit3fc75073b80a3ffedbcd127e9e75edf567f245a5 (patch)
treeee318005b5c38f1b8ae2e1562371d505a760ffb5 /lib
parent546989959c11bc773461cdd8ff0233e3f54255e0 (diff)
downloadnextcloud-server-3fc75073b80a3ffedbcd127e9e75edf567f245a5.tar.gz
nextcloud-server-3fc75073b80a3ffedbcd127e9e75edf567f245a5.zip
update accounts table if email address or display name changes from outside
Signed-off-by: Bjoern Schiessle <bjoern@schiessle.org>
Diffstat (limited to 'lib')
-rw-r--r--lib/base.php6
-rw-r--r--lib/private/Accounts/AccountManager.php20
-rw-r--r--lib/private/Accounts/Hooks.php78
3 files changed, 99 insertions, 5 deletions
diff --git a/lib/base.php b/lib/base.php
index d6c6e17eff9..cad9121da1a 100644
--- a/lib/base.php
+++ b/lib/base.php
@@ -758,6 +758,7 @@ class OC {
self::registerLogRotate();
self::registerEncryptionWrapper();
self::registerEncryptionHooks();
+ self::registerAccountHooks();
self::registerSettingsHooks();
//make sure temporary files are cleaned up
@@ -868,6 +869,11 @@ class OC {
}
}
+ private static function registerAccountHooks() {
+ $hookHandler = new \OC\Accounts\Hooks();
+ \OCP\Util::connectHook('OC_User', 'changeUser', $hookHandler, 'changeUserHook');
+ }
+
/**
* register hooks for the cache
*/
diff --git a/lib/private/Accounts/AccountManager.php b/lib/private/Accounts/AccountManager.php
index 6496a521326..8c7cd010de1 100644
--- a/lib/private/Accounts/AccountManager.php
+++ b/lib/private/Accounts/AccountManager.php
@@ -23,6 +23,7 @@
namespace OC\Accounts;
+use OCP\IConfig;
use OCP\IDBConnection;
use OCP\IUser;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
@@ -62,6 +63,9 @@ class AccountManager {
/** @var EventDispatcherInterface */
private $eventDispatcher;
+ /** @var IConfig */
+ private $config;
+
/**
* AccountManager constructor.
*
@@ -81,16 +85,22 @@ class AccountManager {
*/
public function updateUser(IUser $user, $data) {
$userData = $this->getUser($user);
+ $updated = true;
if (empty($userData)) {
$this->insertNewUser($user, $data);
- } else {
+ } elseif ($userData !== $data) {
$this->updateExistingUser($user, $data);
+ } else {
+ // nothing needs to be done if new and old data set are the same
+ $updated = false;
}
- $this->eventDispatcher->dispatch(
- 'OC\AccountManager::userUpdated',
- new GenericEvent($user)
- );
+ if ($updated) {
+ $this->eventDispatcher->dispatch(
+ 'OC\AccountManager::userUpdated',
+ new GenericEvent($user)
+ );
+ }
}
/**
diff --git a/lib/private/Accounts/Hooks.php b/lib/private/Accounts/Hooks.php
new file mode 100644
index 00000000000..187024e5472
--- /dev/null
+++ b/lib/private/Accounts/Hooks.php
@@ -0,0 +1,78 @@
+<?php
+/**
+ * @copyright Copyright (c) 2016 Bjoern Schiessle <bjoern@schiessle.org>
+ *
+ * @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 OC\Accounts;
+
+use OCP\IUser;
+
+class Hooks {
+
+ /** @var AccountManager */
+ private $accountManager = null;
+
+ /**
+ * update accounts table if email address or display name was changed from outside
+ *
+ * @param array $params
+ */
+ public function changeUserHook($params) {
+
+ $this->instantiateAccountManager();
+
+ /** @var IUser $user */
+ $user = $params['user'];
+ $feature = $params['feature'];
+ $newValue = $params['value'];
+ $accountData = $this->accountManager->getUser($user);
+
+ switch ($feature) {
+ case 'eMailAddress':
+ if ($accountData[AccountManager::PROPERTY_EMAIL]['value'] !== $newValue) {
+ $accountData[AccountManager::PROPERTY_EMAIL]['value'] = $newValue;
+ $this->accountManager->updateUser($user, $accountData);
+ }
+ break;
+ case 'displayName':
+ if ($accountData[AccountManager::PROPERTY_DISPLAYNAME]['value'] !== $newValue) {
+ $accountData[AccountManager::PROPERTY_DISPLAYNAME]['value'] = $newValue;
+ $this->accountManager->updateUser($user, $accountData);
+ }
+ break;
+ }
+
+ }
+
+ /**
+ * return instance of accountManager
+ *
+ * @return AccountManager
+ */
+ protected function instantiateAccountManager() {
+ if (is_null($this->accountManager)) {
+ $this->accountManager = new AccountManager(
+ \OC::$server->getDatabaseConnection(),
+ \OC::$server->getEventDispatcher()
+ );
+ }
+ }
+
+}