summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap
diff options
context:
space:
mode:
authorMarc Hefter <marchefter@march42.net>2022-05-17 12:49:38 +0200
committerMarc Hefter <marchefter@gmail.com>2023-04-06 08:20:21 +0200
commit2315c177261a03a2047f9ba3d11dd96da4fef840 (patch)
treef53852d74d9232945fc38cb9d191a6f9db0f2171 /apps/user_ldap
parent7fa3c674de904b140575112f471c5753aa03a89c (diff)
downloadnextcloud-server-2315c177261a03a2047f9ba3d11dd96da4fef840.tar.gz
nextcloud-server-2315c177261a03a2047f9ba3d11dd96da4fef840.zip
feature addition: [user_ldap] update user profile from LDAP
Signed-off-by: Marc Hefter <marchefter@march42.net> Signed-off-by: Marc Hefter <marchefter@gmail.com>
Diffstat (limited to 'apps/user_ldap')
-rw-r--r--apps/user_ldap/lib/User/User.php42
1 files changed, 22 insertions, 20 deletions
diff --git a/apps/user_ldap/lib/User/User.php b/apps/user_ldap/lib/User/User.php
index e9437d61ab3..043f3b2d273 100644
--- a/apps/user_ldap/lib/User/User.php
+++ b/apps/user_ldap/lib/User/User.php
@@ -36,9 +36,12 @@ use OCA\User_LDAP\Access;
use OCA\User_LDAP\Connection;
use OCA\User_LDAP\Exceptions\AttributeNotSet;
use OCA\User_LDAP\FilesystemHelper;
+use OC\Accounts\AccountManager;
use OCP\Accounts\IAccountManager;
+use OCP\Accounts\PropertyDoesNotExistException;
use OCP\IAvatarManager;
use OCP\IConfig;
+use OCP\IDBConnection;
use OCP\ILogger;
use OCP\Image;
use OCP\IUser;
@@ -575,28 +578,12 @@ class User {
return $quotaValue === 'none' || $quotaValue === 'default' || \OC_Helper::computerFileSize($quotaValue) !== false;
}
-/* user profile settings and LDAP attributes
- * ***
- * interface IAccountManager
- * public const PROPERTY_PHONE = 'phone';
- * public const PROPERTY_EMAIL = 'email';
- * public const PROPERTY_WEBSITE = 'website';
- * public const PROPERTY_ADDRESS = 'address';
- * public const PROPERTY_TWITTER = 'twitter';
- * public const PROPERTY_ORGANISATION = 'organisation';
- * public const PROPERTY_ROLE = 'role';
- * public const PROPERTY_HEADLINE = 'headline';
- * public const PROPERTY_BIOGRAPHY = 'biography';
- * public const PROPERTY_PROFILE_ENABLED = 'profile_enabled';
- * public function getAccount(IUser $user): IAccount;
- * public function updateAccount(IAccount $account): void;
- */
/**
* fetches values from LDAP and stores it as Nextcloud user value
* @param string $valueFromLDAP if known, to save an LDAP read request
* @return null
*/
- public function updateProfile(string $property, $valueFromLDAP = null) {
+ private function updateProfile(string $property, $valueFromLDAP) {
// check for valid property and set corresponding profile property
$profileProperty = 'INVALID';
if (self::USER_PREFKEY_PHONE == $property) {
@@ -616,10 +603,9 @@ class User {
} elseif (self::USER_PREFKEY_BIOGRAPHY == $property) {
$profileProperty = \OCP\Accounts\IAccountManager::PROPERTY_BIOGRAPHY;
} else {
- // TODO: throw exception for invalid property specified
+ // FIXME: throw exception for invalid property specified
return;
}
- $this->logger->info('user profile data from LDAP '.$this->dn.' ('.$profileProperty.')', ['app' => 'user_ldap']);
// check if this property was refreshed before
if ($this->wasRefreshed($property)) {
return;
@@ -628,12 +614,28 @@ class User {
//$propertyValue = (string)$valueFromLDAP;
$propertyValue = [$valueFromLDAP];
}
+ $this->logger->debug('user profile data ('.$profileProperty.') from LDAP '.$this->dn.' ='.((string)$valueFromLDAP), ['app' => 'user_ldap']);
if ($propertyValue && isset($propertyValue[0])) {
$value = $propertyValue[0];
+ try {
+ $user = $this->userManager->get($this->uid);
+ if (!is_null($user)) {
+ $currentValue = (string)$user->getProfilePropertyValue($profileProperty);
+ if ($currentValue !== $value) {
+ $user->setProfilePropertyValue($profileProperty,$value);
+ }
+ // setScope(IAccountManager::SCOPE_FEDERATED);
+ // setVerified(IAccountManager::VERIFIED);
+ }
+ } catch (PropertyDoesNotExistException $e) {
+ $this->logger->error('property does not exist: '.$profileProperty.' for user '.$userName.'', ['app' => 'user_ldap']);
+ return;
+ }
+ $this->logger->debug('property updated: '.$profileProperty.'='.$propertyValue.' for user '.$userName.'', ['app' => 'user_ldap']);
$this->config->setUserValue($this->getUsername(), 'user_ldap', $property, $value);
- // TODO: update user profile data; call \OCP\Accounts\IAccount::setProperty
return $value;
} else {
+ // FIXME: I decided, to leave profile untouched, if attribute gets removed from LDAP
$this->config->deleteUserValue($this->getUsername(), 'user_ldap', $property);
return '';
}