vtigerossez/include/Webservices/ChangePassword.php

71 lines
2.5 KiB
PHP

<?php
/*+*******************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
*
*********************************************************************************/
/**
* @author Musavir Ahmed Khan<musavir at vtiger.com>
*/
/**
* @param WebserviceId $id
* @param String $oldPassword
* @param String $newPassword
* @param String $confirmPassword
* @param Users $user
*
*/
function vtws_changePassword($id, $oldPassword, $newPassword, $confirmPassword, $user) {
vtws_preserveGlobal('current_user',$user);
$idComponents = vtws_getIdComponents($id);
if($idComponents[1] == $user->id || is_admin($user)) {
$newUser = new Users();
$newUser->retrieveCurrentUserInfoFromFile($idComponents[1]);
if(!is_admin($user)) {
if(empty($oldPassword)) {
throw new WebServiceException(WebServiceErrorCode::$INVALIDOLDPASSWORD,
vtws_getWebserviceTranslatedString('LBL_'.
WebServiceErrorCode::$INVALIDOLDPASSWORD));
}
if(!$user->verifyPassword($oldPassword)) {
throw new WebServiceException(WebServiceErrorCode::$INVALIDOLDPASSWORD,
vtws_getWebserviceTranslatedString('LBL_'.
WebServiceErrorCode::$INVALIDOLDPASSWORD));
}
}
if(strcmp($newPassword, $confirmPassword) === 0) {
$db = PearDatabase::getInstance();
$db->dieOnError = true;
$db->startTransaction();
$success = $newUser->change_password($oldPassword, $newPassword, false);
$error = $db->hasFailedTransaction();
$db->completeTransaction();
if($error) {
throw new WebServiceException(WebServiceErrorCode::$DATABASEQUERYERROR,
vtws_getWebserviceTranslatedString('LBL_'.
WebServiceErrorCode::$DATABASEQUERYERROR));
}
if(!$success) {
throw new WebServiceException(WebServiceErrorCode::$CHANGEPASSWORDFAILURE,
vtws_getWebserviceTranslatedString('LBL_'.
WebServiceErrorCode::$CHANGEPASSWORDFAILURE));
}
} else {
throw new WebServiceException(WebServiceErrorCode::$CHANGEPASSWORDFAILURE,
vtws_getWebserviceTranslatedString('LBL_'.
WebServiceErrorCode::$CHANGEPASSWORDFAILURE));
}
VTWS_PreserveGlobal::flush();
return array('message' => 'Changed password successfully');
}
}
?>