HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/backip-old-files/administrator/components/com_virtuemart/helpers/vmtabledata.php
<?php
/**
 * Xref table abstract class to create tables specialised doing xref
 *
 *
 * @package	VirtueMart
 * @subpackage Helpers
 * @author Max Milbers
 * @copyright Copyright (c) 2011 VirtueMart Team. All rights reserved.
 * @license http://www.gnu.org/copyleft/gpl.html GNU/GPL, see LICENSE.php
 * VirtueMart is free software. This version may have been modified pursuant
 * to the GNU General Public License, and as distributed it includes or
 * is derivative of works licensed under the GNU General Public License or
 * other free or open source software licenses.
 * See /administrator/components/com_virtuemart/COPYRIGHT.php for copyright notices and details.
 *
 * http://virtuemart.net
 */

defined('_JEXEC') or die();

class VmTableData extends VmTable {


	/**
	 * Records in this table do not need to exist, so we might need to create a record even
	 * if the primary key is set. Therefore we need to overload the store() function.
	 *
	 * @author Max Milbers
	 * @see libraries/joomla/database/JTable#store($updateNulls)
	 */
	public function store($updateNulls = false) {

		$this->setLoggableFieldsForStore();

		if($this->_cryptedFields){
			foreach($this->_cryptedFields as $field){
				if(isset($this->{$field})){
					$this->{$field} = vmCrypt::encrypt($this->{$field});
				}
			}
		}

		$this->storeParams();

		$tblKey = $this->_tbl_key;
		$pKey = $this->_pkey;

		$res = false;
		if($tblKey == $pKey){
			//vmdebug('VmTableData '.get_class($this). ' need not to be a vmtabledata $tblKey == $pKey');

			if(!empty($this->{$tblKey})){
				$_qry = 'SELECT `'.$this->_tbl_key.'` '
				. 'FROM `'.$this->_tbl.'` '
				. 'WHERE `'.$this->_tbl_key.'` = "' . $this->{$tblKey}.'" ';
				$this->_db->setQuery($_qry);
				$res = $this->_db->loadResult();
			}

		} else {
			if(!empty($this->{$pKey})){
				$_qry = 'SELECT `'.$this->_tbl_key.'` '
				. 'FROM `'.$this->_tbl.'` '
				. 'WHERE `'.$this->_pkey.'` = "' . $this->{$pKey}.'" ';
				$this->_db->setQuery($_qry);
				//Yes, overwriting $this->{$tblKey} is correct !
				$this->{$tblKey} = $this->_db->loadResult();
			}
			if ( !empty($this->{$tblKey}) ) {
				$res = true;
			}
		}

		if(!empty($this->_hashName)){
			$this->hashEntry();
		}

		if($res){
			$returnCode = $this->_db->updateObject($this->_tbl, $this, $this->_tbl_key, $updateNulls);
		} else {
			$p = $this->{$tblKey};
			$returnCode = $this->_db->insertObject($this->_tbl, $this, $this->_tbl_key);
			if($returnCode and !empty($this->_hashName)){
				$oldH= $this->{$this->_hashName};
				if($p!=$this->{$tblKey} and !in_array($tblKey,$this->_omittedHashFields)){
					$this->hashEntry();
					$ok = $this->_db->updateObject($this->_tbl, $this, $this->_tbl_key, $updateNulls);
					vmdebug('VmTableData Updated entry with correct hash ',$this->_tbl_key,$p,$this->{$tblKey},$oldH,$this->{$this->_hashName});
				}
			}
		}

		//reset Params
		if(isset($this->_tmpParams) and is_array($this->_tmpParams)){
			foreach($this->_tmpParams as $k => $v){
				$this->{$k} = $v;
			}
		}
		$this->_tmpParams = false;

		if (!$returnCode) {
			vmError(get_class($this) . '::store failed - ' . $this->_db->getErrorMsg());
			return false;
		}
		else {

			return true;
		}

	}


}