晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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/www/crm/modules/Import/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 Import_Map_Model extends Vtiger_Base_Model {
static $tableName = 'vtiger_import_maps';
var $map;
var $user;
public function __construct($map, $user) {
$this->map = $map;
$this->user = $user;
}
public static function getInstanceFromDb($row, $user) {
$map = array();
foreach($row as $key=>$value) {
if($key == 'content') {
$content = array();
$pairs = explode("&", decode_html($value));
foreach($pairs as $pair) {
list($mappedName, $sequence) = explode("=", $pair);
$mappedName = str_replace('/eq/', '=', $mappedName);
$mappedName = str_replace('/amp/', '&', $mappedName);
$content["$mappedName"] = $sequence;
}
$map[$key] = $content;
} else {
$map[$key] = $value;
}
}
return new Import_Map_Model($map, $user);
}
public static function markAsDeleted($mapId) {
$db = PearDatabase::getInstance();
$db->pquery('UPDATE vtiger_import_maps SET deleted=1 WHERE id=?', array($mapId));
}
public function getId() {
$map = $this->map;
return $map['id'];
}
public function getAllValues() {
return $this->map;
}
public function getValue($key) {
$map = $this->map;
return $map[$key];
}
public function getStringifiedContent() {
if(empty($this->map['content'])) return;
$content = $this->map['content'];
$keyValueStrings = array();
foreach($content as $key => $value) {
$key = str_replace('=', '/eq/', $key);
$key = str_replace('&', '/amp/', $key);
$keyValueStrings[] = $key.'='.$value;
}
$stringifiedContent = implode('&', $keyValueStrings);
return $stringifiedContent;
}
public function save() {
$db = PearDatabase::getInstance();
$map = $this->getAllValues();
$map['content'] = "".$db->getEmptyBlob()."";
$columnNames = array_keys($map);
$columnValues = array_values($map);
if(count($map) > 0) {
$db->pquery('INSERT INTO '.self::$tableName.' ('. implode(',',$columnNames).') VALUES ('. generateQuestionMarks($columnValues).')', array($columnValues));
$db->updateBlob(self::$tableName,"content","name='". $db->sql_escape_string($this->getValue('name')).
"' AND module='".$db->sql_escape_string($this->getValue('module'))."'",$this->getStringifiedContent());
}
}
public static function getAllByModule($moduleName) {
global $current_user;
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT * FROM '.self::$tableName.' WHERE deleted=0 AND module=?', array($moduleName));
$noOfMaps = $db->num_rows($result);
$savedMaps = array();
for($i=0; $i<$noOfMaps; ++$i) {
$importMap = Import_Map_Model::getInstanceFromDb($db->query_result_rowdata($result, $i), $current_user);
$savedMaps[$importMap->getId()] = $importMap;
}
return $savedMaps;
}
}