晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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/readers/ |
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_FileReader_Reader {
var $status='success';
var $numberOfRecordsRead = 0;
var $errorMessage='';
var $user;
var $request;
var $moduleModel;
public function __construct($request, $user) {
$this->request = $request;
$this->user = $user;
$this->moduleModel = Vtiger_Module_Model::getInstance($this->request->get('module'));
}
public function getStatus() {
return $this->status;
}
public function getErrorMessage() {
return $this->errorMessage;
}
public function getNumberOfRecordsRead() {
return $this->numberOfRecordsRead;
}
/**
* To set number of records read from CSV to DB
* @param type $table
* @param type $db
*/
public function setNumberOfRecordsRead($table,$db){
$query = "SELECT count(*) AS count FROM $table";
$result = $db->pquery($query,array());
$count = $db->query_result($result,0,'count');
$this->numberOfRecordsRead = $count;
}
public function hasHeader() {
if($this->request->get('has_header') == 'on'
|| $this->request->get('has_header') == 1
|| $this->request->get('has_header') == true) {
return true;
}
return false;
}
public function getFirstRowData($hasHeader=true) {
return null;
}
public function getFilePath() {
return Import_Utils_Helper::getImportFilePath($this->user);
}
public function getFileHandler() {
$filePath = $this->getFilePath();
if(!file_exists($filePath)) {
$this->status = 'failed';
$this->errorMessage = "ERR_FILE_DOESNT_EXIST";
return false;
}
$fileHandler = fopen($filePath, 'r');
if(!$fileHandler) {
$this->status = 'failed';
$this->errorMessage = "ERR_CANT_OPEN_FILE";
return false;
}
return $fileHandler;
}
public function convertCharacterEncoding($value, $fromCharset, $toCharset) {
if (function_exists("mb_convert_encoding")) {
$value = mb_convert_encoding($value, $toCharset, $fromCharset);
} else {
$value = iconv($fromCharset, $toCharset, $value);
}
return $value;
}
public function read() {
// Sub-class need to implement this
}
public function deleteFile() {
$filePath = $this->getFilePath();
@unlink($filePath);
}
public function createTable() {
$db = PearDatabase::getInstance();
$tableName = Import_Utils_Helper::getDbTableName($this->user);
$fieldMapping = $this->request->get('field_mapping');
$moduleFields = $this->moduleModel->getFields();
$moduleImportableFields = $this->moduleModel->getAdditionalImportFields();
$moduleFields = array_merge($moduleFields, $moduleImportableFields);
$columnsListQuery = 'id INT PRIMARY KEY AUTO_INCREMENT, status INT DEFAULT 0, recordid INT';
$fieldTypes = $this->getModuleFieldDBColumnType();
foreach($fieldMapping as $fieldName => $index) {
$fieldObject = $moduleFields[$fieldName];
$columnsListQuery .= $this->getDBColumnType($fieldObject, $fieldTypes);
}
$createTableQuery = 'CREATE TABLE '. $tableName . ' ('.$columnsListQuery.') ENGINE=MyISAM ';
$db->query($createTableQuery);
return true;
}
public function addRecordToDB($columnNames, $fieldValues) {
$db = PearDatabase::getInstance();
foreach($fieldValues as $key => $fieldVal){
$newField[$key] = htmlspecialchars_decode($fieldVal, ENT_QUOTES);
}
$fieldValues = $newField;
$tableName = Import_Utils_Helper::getDbTableName($this->user);
$db->pquery('INSERT INTO '.$tableName.' ('. implode(',', $columnNames).') VALUES ('. generateQuestionMarks($fieldValues) .')', $fieldValues);
$this->numberOfRecordsRead++;
}
/** Function returns the database column type of the field
* @param $fieldObject <Vtiger_Field_Model>
* @param $fieldTypes <Array> - fieldnames with column type
* @return <String> - column name with type for sql creation of table
*/
public function getDBColumnType($fieldObject,$fieldTypes){
$columnsListQuery = '';
$fieldName = $fieldObject->getName();
$dataType = $fieldObject->getFieldDataType();
$skipDataType = array('reference','owner', 'currencyList', 'date', 'datetime', 'productTax', 'ownergroup');
if(in_array($dataType, $skipDataType)){
$columnsListQuery .= ','.$fieldName.' varchar(250)';
} else {
$columnsListQuery .= ','.$fieldName.' '.$fieldTypes[$fieldObject->get('column')];
}
return $columnsListQuery;
}
/** Function returns array of columnnames and their column datatype
* @return <Array>
*/
public function getModuleFieldDBColumnType() {
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT tablename FROM vtiger_field WHERE tabid=? GROUP BY tablename', array($this->moduleModel->getId()));
$tables = array();
if ($result && $db->num_rows($result) > 0) {
while ($row = $db->fetch_array($result)) {
$tables[] = $row['tablename'];
}
}
$fieldTypes = array();
foreach ($tables as $table) {
$result = $db->pquery("DESC $table", array());
if ($result && $db->num_rows($result) > 0) {
while ($row = $db->fetch_array($result)) {
$fieldTypes[$row['field']] = $row['type'];
}
}
}
return $fieldTypes;
}
}
?>