晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/akaindir/public_html/crm/modules/Users/actions/ |
Upload File : |
<?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.
*************************************************************************************/
vimport('~~/include/Webservices/Custom/ChangePassword.php');
class Users_SaveAjax_Action extends Vtiger_SaveAjax_Action {
function __construct() {
parent::__construct();
$this->exposeMethod('userExists');
$this->exposeMethod('savePassword');
$this->exposeMethod('restoreUser');
$this->exposeMethod('transferOwner');
$this->exposeMethod('changeUsername');
$this->exposeMethod('changeAccessKey');
}
public function checkPermission(Vtiger_Request $request) {
$currentUserModel = Users_Record_Model::getCurrentUserModel();
$userId = $request->get('userid');
if(!$currentUserModel->isAdminUser()) {
$mode = $request->getMode();
if($mode == 'savePassword' && (isset($userId) && $currentUserModel->getId() != $userId)) {
throw new AppException(vtranslate('LBL_PERMISSION_DENIED', 'Vtiger'));
} else if(in_array($mode, array('userExists','restoreUser','transferOwner','changeUsername'))) {
throw new AppException(vtranslate('LBL_PERMISSION_DENIED', 'Vtiger'));
} else if($mode != 'savePassword' && ($currentUserModel->getId() != $request->get('record'))) {
throw new AppException(vtranslate('LBL_PERMISSION_DENIED', 'Vtiger'));
}
}
}
public function process(Vtiger_Request $request) {
$mode = $request->get('mode');
if (!empty($mode)) {
$this->invokeExposedMethod($mode, $request);
return;
}
$recordModel = $this->saveRecord($request);
$fieldModelList = $recordModel->getModule()->getFields();
$result = array();
foreach ($fieldModelList as $fieldName => $fieldModel) {
$fieldValue = $displayValue = Vtiger_Util_Helper::toSafeHTML($recordModel->get($fieldName));
if ($fieldModel->getFieldDataType() !== 'currency') {
$displayValue = $fieldModel->getDisplayValue($fieldValue, $recordModel->getId());
}
if($fieldName == 'language') {
$displayValue = Vtiger_Language_Handler::getLanguageLabel($fieldValue);
}
if(($fieldName == 'currency_decimal_separator' || $fieldName == 'currency_grouping_separator') && ($displayValue == ' ')) {
$displayValue = vtranslate('Space', 'Users');
}
$result[$fieldName] = array('value' => $fieldValue, 'display_value' => $displayValue);
}
$result['_recordLabel'] = $recordModel->getName();
$result['_recordId'] = $recordModel->getId();
$response = new Vtiger_Response();
$response->setEmitType(Vtiger_Response::$EMIT_JSON);
$response->setResult($result);
$response->emit();
}
/**
* Function to get the record model based on the request parameters
* @param Vtiger_Request $request
* @return Vtiger_Record_Model or Module specific Record Model instance
*/
public function getRecordModelFromRequest(Vtiger_Request $request) {
$recordModel = parent::getRecordModelFromRequest($request);
$fieldName = $request->get('field');
$currentUserModel = Users_Record_Model::getCurrentUserModel();
if ($fieldName === 'is_admin' && (!$currentUserModel->isAdminUser() || !$request->get('value'))) {
$recordModel->set($fieldName, 'off');
}
if($fieldName == "is_owner") {
$recordId = $request->get('record');
$moduleName = $request->getModule();
if(!empty($recordId)) {
$existingRecordModel = Vtiger_Record_Model::getInstanceById($recordId, $moduleName);
$recordModel->set($fieldName,$existingRecordModel->get($fieldName));
}
}
return $recordModel;
}
public function userExists(Vtiger_Request $request){
$module = $request->getModule();
$userName = $request->get('user_name');
$status = Users_Record_Model::isUserExists($userName);
$response = new Vtiger_Response();
$response->setResult($status);
$response->emit();
}
public function savePassword(Vtiger_Request $request) {
$module = $request->getModule();
$userModel = vglobal('current_user');
$newPassword = $request->get('new_password');
$oldPassword = $request->get('old_password');
$wsUserId = vtws_getWebserviceEntityId($module, $request->get('userid'));
$wsStatus = vtws_changePassword($wsUserId, $oldPassword, $newPassword, $newPassword, $userModel);
$response = new Vtiger_Response();
if ($wsStatus['message']) {
$response->setResult($wsStatus);
} else {
$response->setError('JS_PASSWORD_INCORRECT_OLD', 'JS_PASSWORD_INCORRECT_OLD');
}
$response->emit();
}
/*
* To restore a user
* @param Vtiger_Request Object
*/
public function restoreUser(Vtiger_Request $request) {
$moduleName = $request->getModule();
$record = $request->get('userid');
$recordModel = Users_Record_Model::getInstanceById($record, $moduleName);
$recordModel->set('status', 'Active');
$recordModel->set('id', $record);
$recordModel->set('mode', 'edit');
$recordModel->save();
$db = PearDatabase::getInstance();
$db->pquery("UPDATE vtiger_users SET deleted=? WHERE id=?", array(0,$record));
$userModuleModel = Users_Module_Model::getInstance($moduleName);
$listViewUrl = $userModuleModel->getListViewUrl();
$response = new Vtiger_Response();
$response->setResult(array('message'=>vtranslate('LBL_USER_RESTORED_SUCCESSFULLY', $moduleName), 'listViewUrl' => $listViewUrl));
$response->emit();
}
/*
* Function to transfer CRM owner without deleting User
*/
public function transferOwner(Vtiger_Request $request) {
$moduleName = $request->getModule(false);
$record = $request->get('record');
$usersInstance = CRMEntity::getInstance($moduleName);
$status = $usersInstance->transferOwnership($record);
$response = new Vtiger_Response();
if($status) {
$response->setResult(array('message' => vtranslate('LBL_OWNERSHIP_TRANSFERRED_SUCCESSFULLY', $moduleName)));
} else {
$response->setError(vtranslate('LBL_OWNERSHIP_TRANSFERRED_FAILED', $moduleName));
}
$response->emit();
}
/**
* Function to change username
*/
public function changeUsername(Vtiger_Request $request) {
$response = new Vtiger_Response();
$userId = $request->get('userid');
$status = Users_Record_Model::changeUsername($request->get('newUsername'), $request->get('newPassword'), $request->get('oldPassword'), $userId);
if($status['success']) {
$response->setResult($status['message']);
}else{
$response->setError($status['message']);
}
$response->emit();
}
public function changeAccessKey(Vtiger_Request $request) {
$recordId = $request->get('record');
$moduleName = $request->getModule();
$response = new Vtiger_Response();
try {
$recordModel = Users_Record_Model::getInstanceById($recordId, $moduleName);
$oldAccessKey = $recordModel->get('accesskey');
$entity = $recordModel->getEntity();
$entity->createAccessKey();
require_once('modules/Users/CreateUserPrivilegeFile.php');
createUserPrivilegesfile($recordId);
Vtiger_AccessControl::clearUserPrivileges($recordId);
$recordModel = Users_Record_Model::getInstanceFromPreferenceFile($recordId);
$newAccessKey = $recordModel->get('accesskey');
if ($newAccessKey != $oldAccessKey) {
$response->setResult(array('success' => true, 'message' => vtranslate('LBL_ACCESS_KEY_UPDATED_SUCCESSFULLY', $moduleName), 'accessKey' => $newAccessKey));
} else {
$response->setError(vtranslate('LBL_FAILED_TO_UPDATE_ACCESS_KEY', $moduleName));
}
} catch (Exception $ex) {
$response->setError($ex->getMessage());
}
$response->emit();
}
}