diff --git a/lib/user.php b/lib/user.php index 38259bceea..f953d22154 100644 --- a/lib/user.php +++ b/lib/user.php @@ -419,6 +419,24 @@ class OC_User { } } + /** + * @brief Check whether user can change his password + * @param $uid The username + * @returns true/false + * + * Check whether a specified user can change his password + */ + public static function canUserChangePassword($uid) { + foreach(self::$_usedBackends as $backend) { + if($backend->implementsActions(OC_USER_BACKEND_SET_PASSWORD)) { + if($backend->userExists($uid)) { + return true; + } + } + } + return false; + } + /** * @brief Check if the password is correct * @param $uid The username diff --git a/settings/personal.php b/settings/personal.php index 4624bda839..a2e510a6d3 100644 --- a/settings/personal.php +++ b/settings/personal.php @@ -47,6 +47,7 @@ $tmpl->assign('total_space', OC_Helper::humanFileSize($storageInfo['total'])); $tmpl->assign('usage_relative', $storageInfo['relative']); $tmpl->assign('email', $email); $tmpl->assign('languages', $languages); +$tmpl->assign('passwordChangeSupported', OC_User::canUserChangePassword(OC_User::getUser())); $forms=OC_App::getForms('personal'); $tmpl->assign('forms', array()); diff --git a/settings/templates/personal.php b/settings/templates/personal.php index 0e1677bdea..b1cc671392 100644 --- a/settings/templates/personal.php +++ b/settings/templates/personal.php @@ -15,7 +15,9 @@ t('Download iOS Client');?> - +
t('Password');?> @@ -27,6 +29,9 @@
+