95 lines
3.3 KiB
PHP
Executable File
95 lines
3.3 KiB
PHP
Executable File
<?php
|
|
/* +**********************************************************************************
|
|
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
|
|
* ("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.
|
|
* ***********************************************************************************/
|
|
|
|
class Users_ExportData_Action extends Vtiger_ExportData_Action {
|
|
|
|
public function requiresPermission(\Vtiger_Request $request) {
|
|
return array();
|
|
}
|
|
|
|
public function checkPermission(Vtiger_Request $request){
|
|
$currentUserModel = Users_Record_Model::getCurrentUserModel();
|
|
if(!$currentUserModel->isAdminUser()) {
|
|
throw new AppException(vtranslate('LBL_PERMISSION_DENIED', 'Vtiger'));
|
|
}
|
|
}
|
|
|
|
var $exportableFields = array( 'user_name' => 'User Name',
|
|
'title' => 'Title',
|
|
'first_name' => 'First Name',
|
|
'last_name' => 'Last Name',
|
|
'email1' => 'Email',
|
|
'email2' => 'Other Email',
|
|
'secondaryemail'=> 'Secondary Email',
|
|
'phone_work' => 'Office Phone',
|
|
'phone_mobile' => 'Mobile',
|
|
'phone_fax' => 'Fax',
|
|
'address_street'=> 'Street',
|
|
'address_city' => 'City',
|
|
'address_state' => 'State',
|
|
'address_country' => 'Country',
|
|
// SalesPlatform.ru begin
|
|
//'address_postalcode'=> 'Postal Code');
|
|
'address_postalcode'=> 'Postal Code',
|
|
'roleid' => 'Role');
|
|
// SalesPlatform.ru end
|
|
/**
|
|
* Function exports the data based on the mode
|
|
* @param Vtiger_Request $request
|
|
*/
|
|
function ExportData(Vtiger_Request $request) {
|
|
$this->moduleCall = true;
|
|
$db = PearDatabase::getInstance();
|
|
$moduleName = $request->get('source_module');
|
|
if ($moduleName) {
|
|
$this->moduleInstance = Vtiger_Module_Model::getInstance($moduleName);
|
|
$this->moduleFieldInstances = $this->moduleInstance->getFields();
|
|
$this->focus = CRMEntity::getInstance($moduleName);
|
|
$query = $this->getExportQuery($request);
|
|
$result = $db->pquery($query, array());
|
|
$headers = $this->exportableFields;
|
|
foreach ($headers as $header) {
|
|
$translatedHeaders[] = vtranslate(html_entity_decode($header, ENT_QUOTES), $moduleName);
|
|
}
|
|
|
|
$entries = array();
|
|
for ($i=0; $i<$db->num_rows($result); $i++) {
|
|
$entries[] = $db->fetchByAssoc($result, $i);
|
|
}
|
|
|
|
return $this->output($request, $translatedHeaders, $entries);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Function that generates Export Query based on the mode
|
|
* @param Vtiger_Request $request
|
|
* @return <String> export query
|
|
*/
|
|
function getExportQuery(Vtiger_Request $request) {
|
|
$currentUser = Users_Record_Model::getCurrentUserModel();
|
|
$cvId = $request->get('viewname');
|
|
$moduleName = $request->get('source_module');
|
|
|
|
$queryGenerator = new QueryGenerator($moduleName, $currentUser);
|
|
if (!empty($cvId)) {
|
|
$queryGenerator->initForCustomViewById($cvId);
|
|
}
|
|
|
|
$acceptedFields = array_keys($this->exportableFields);
|
|
$queryGenerator->setFields($acceptedFields);
|
|
return $queryGenerator->getQuery();
|
|
}
|
|
|
|
public function validateRequest(Vtiger_Request $request) {
|
|
$request->validateReadAccess();
|
|
}
|
|
}
|