晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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/Settings/MailConverter/models/ |
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.
*************************************************************************************/
class Settings_MailConverter_BodyRule_Model extends Settings_MailConverter_RuleRecord_Model {
var $_bodyruleTable = 'vtiger_mailscanner_bodyrule';
var $_bodyruleMappingTable = 'vtiger_mailscanner_mapping';
public static function getCleanInstance($qualifiedModuleName='Settings:MailConverter'){
$modelClassName = Vtiger_Loader::getComponentClassName('Model', 'BodyRule', $qualifiedModuleName);
return new $modelClassName();
}
public function getBodyRuleDelimiter() {
$delimiter = array(
'colon' => array('symbol' => ':', 'label' => 'LBL_COLON'),
'semicolon' => array('symbol' => ';', 'label' => 'LBL_SEMICOLON'),
'dash' => array('symbol' => '-', 'label' => 'LBL_DASH'),
'equal' => array('symbol' => '=', 'label' => 'LBL_EQUAL'),
'lessthan' => array('symbol' => '>', 'label' => 'LBL_GREATER_THAN'),
'colondash' => array('symbol' => ':-', 'label' => 'LBL_COLON_DASH'),
'colonequal' => array('symbol' => ':=', 'label' => 'LBL_COLON_EQUAL'),
'semicolondash' => array('symbol' => ';-', 'label' => 'LBL_SEMICOLON_DASH'),
'semicolonequal' => array('symbol' => ';=', 'label' => 'LBL_SEMICOLON_EQUAL'),
'equallessthan' => array('symbol' => '=>', 'label' => 'LBL_EQUAL_GREATER_THAN'),
);
return $delimiter;
}
public function getModuleFields($action) {
$module = Settings_MailConverter_BodyRule_Model::getModuleNameByAction($action);
if(!$module)
return array();
$fields = array();
$moduleInstance = Vtiger_Module_Model::getInstance($module);
$fieldInstances = Vtiger_Field_Model::getAllForModule($moduleInstance);
foreach($fieldInstances as $blockInstance) {
foreach($blockInstance as $fieldInstance) {
if($fieldInstance->isEditable()) {
$fieldName = $fieldInstance->getName();
$uiType = $fieldInstance->get('uitype');
$displayType = $fieldInstance->getDisplayType();
$dataType = $fieldInstance->getFieldDataType();
$blockedUiType = array(4, 52, 53, 69, 105);
$blockedDisplayType = array(2, 3);
if(!in_array($uiType, $blockedUiType) && !in_array($displayType, $blockedDisplayType) &&
$dataType != 'boolean' && $dataType != 'reference' && $fieldName != 'comments') {
$fields[$fieldName] = vtranslate($fieldInstance->get('label'), $module);
}
}
}
}
return $fields;
}
public function parseBody($bodyText, $delimeter) {
$bodyFields = array('Subject', 'From Email', 'From Name', 'Email Content');
$rows = explode("\n", $bodyText);
foreach($rows as $row) {
if(strrpos($row, $delimeter)) {
$columns = explode($delimeter, $row);
$bodyFields[] = decode_html(trim($columns[0]));
}
}
return array_unique($bodyFields);
}
public function getModuleNameByAction($action) {
if($action == 'CREATE_HelpDesk_FROM' || $action == 'CREATE_HelpDeskNoContact_FROM') {
$module = 'HelpDesk';
} else if($action == 'CREATE_Leads_SUBJECT') {
$module = 'Leads';
} else if($action == 'CREATE_Contacts_SUBJECT') {
$module = 'Contacts';
} else if($action == 'CREATE_Accounts_SUBJECT') {
$module = 'Accounts';
} else if($action == 'CREATE_Potentials_SUBJECT' || $action == 'CREATE_PotentialsNoContact_SUBJECT') {
$module = 'Potentials';
} else {
$module = false;
}
return $module;
}
function saveBodyRule() {
$scannerId = $this->get('scannerId');
$ruleId = $this->get('ruleId');
$delimiter = $this->get('delimiter');
$mappingData = $this->get('filedsMapping');
$action = $this->get('action');
$body = $this->get('body');
$moduleName = $this->getModuleNameByAction($action);
$db = PearDatabase::getInstance();
$db->pquery("DELETE FROM $this->_bodyruleTable WHERE ruleid = ? AND scannerid = ?", array($ruleId, $scannerId));
$db->pquery("DELETE FROM $this->_bodyruleMappingTable WHERE ruleid = ? AND scannerid = ?", array($ruleId, $scannerId));
$db->pquery("INSERT INTO $this->_bodyruleTable VALUES (?, ?, ?, ?, ?)", array($ruleId, $scannerId, $delimiter, $moduleName, $body));
foreach($mappingData as $bodyField => $crmField) {
$db->pquery("INSERT INTO $this->_bodyruleMappingTable VALUES (?, ?, ?, ?)", array($ruleId, $scannerId, $crmField, $bodyField));
}
}
function getDelimiter() {
$db = PearDatabase::getInstance();
$params = array($this->get('ruleid'), $this->get('scannerid'));
$result = $db->pquery("SELECT delimiter FROM $this->_bodyruleTable WHERE ruleid = ? AND scannerid = ?", $params);
if($db->num_rows($result) > 0) {
return decode_html(decode_html($db->query_result($result, 0, 'delimiter')));
}
}
function getBody() {
$db = PearDatabase::getInstance();
$params = array($this->get('ruleid'), $this->get('scannerid'));
$result = $db->pquery("SELECT body FROM $this->_bodyruleTable WHERE ruleid = ? AND scannerid = ?", $params);
if($db->num_rows($result) > 0) {
return decode_html($db->query_result($result, 0, 'body'));
}
}
function getMapping() {
$db = PearDatabase::getInstance();
$params = array($this->get('ruleid'), $this->get('scannerid'));
$result = $db->pquery("SELECT crm_field, body_field FROM $this->_bodyruleMappingTable WHERE ruleid = ? AND scannerid = ?", $params);
$count = $db->num_rows($result);
for($i = 0; $i < $count; $i++) {
$crmField = decode_html($db->query_result($result, $i, 'crm_field'));
$bodyField = decode_html($db->query_result($result, $i, 'body_field'));
$data[$bodyField] = $crmField;
}
return $data;
}
public function deleteBodyRule($scannerId, $ruleId) {
$db = PearDatabase::getInstance();
$db->pquery("DELETE FROM $this->_bodyruleTable WHERE ruleid = ? AND scannerid = ?", array($ruleId, $scannerId));
$db->pquery("DELETE FROM $this->_bodyruleMappingTable WHERE ruleid = ? AND scannerid = ?", array($ruleId, $scannerId));
}
}