Monkey Albino

Linux altar53.supremepanel53.com 4.18.0-553.8.1.lve.el8.x86_64 #1 SMP Thu Jul 4 16:24:39 UTC 2024 x86_64
/ home/ bdapparelinfo/ dhakazone.com/ admin/ model/ journal3/

/home/bdapparelinfo/dhakazone.com/admin/model/journal3/setting.php

<?php

use Journal3\Opencart\Model;

class ModelJournal3Setting extends Model {

	private static $INDEX_LIST = array(
		'product.model',
		'url_alias.query',
		'url_alias.keyword',
	);

	public function __construct($registry) {
		parent::__construct($registry);

		foreach (static::$INDEX_LIST as &$value) {
			$value = DB_PREFIX . $value;
		}
	}

	/**
	 * @throws Exception
	 */
	public function get($id, $setting_groups = array()) {
		$sql = "
			SELECT
				*
			FROM
				`{$this->dbPrefix('journal3_setting')}`
			WHERE
				`store_id` = '{$this->dbEscapeInt($id)}'
		";

		if ($setting_groups) {
			$sql .= "
				AND `setting_group` IN ({$this->dbEscape($setting_groups)})
			";
		}

		$query = $this->db->query($sql);

		$result = array();

		foreach ($query->rows as $value) {
			$result[$value['setting_group']][$value['setting_name']] = $this->decode($value['setting_value'], $value['serialized']);
		}

		if (!$result) {
			$result = new stdClass();
		}

		return $result;
	}

	public function edit($id, $settings) {
		foreach ($settings as $setting_group => $data) {
			foreach ($data as $key => $value) {
				$serialized = is_scalar($value) ? 0 : 1;

				$this->db->query("
					INSERT INTO `{$this->dbPrefix('journal3_setting')}` (
						`store_id`,
						`setting_group`,
						`setting_name`,
						`setting_value`,
						`serialized`
					) VALUES (
						'{$this->dbEscapeInt($id)}',
						'{$this->dbEscape($setting_group)}',
						'{$this->dbEscape($key)}',
						'{$this->dbEscape($this->encode($value, $serialized))}',
						'{$this->dbEscapeInt($serialized)}'
					) ON DUPLICATE KEY UPDATE 
						`setting_value` = '{$this->dbEscape($this->encode($value, $serialized))}',
						`serialized` = '{$this->dbEscapeInt($serialized)}'
				");
			}
		}
	}

	public function indexes($add_indexes = false) {
		$query = $this->db->query("
			SELECT * 
			FROM 
				INFORMATION_SCHEMA.TABLES 
			WHERE 
				TABLE_SCHEMA = '{$this->dbEscape(DB_DATABASE)}'
		");

		$tables_indexes = array();

		foreach ($query->rows as $table) {
			$indexes = $this->getTableIndexes($table['TABLE_NAME']);
			$columns = $this->getTableColumns($table['TABLE_NAME']);

			foreach ($columns as $column) {
				if ($this->canIndex($table['TABLE_NAME'] . '.' . $column) && !in_array($column, $indexes)) {
					if ($add_indexes) {
						$this->addIndex($table['TABLE_NAME'], $column);
					}

					$tables_indexes[] = $table['TABLE_NAME'] . '.' . $column;
				}
			}

		}

		return $tables_indexes;
	}

	private function getTableIndexes($table_name) {
		$query = $this->db->query("
			SELECT * 
			FROM INFORMATION_SCHEMA.STATISTICS 
			WHERE TABLE_SCHEMA = '{$this->dbEscape(DB_DATABASE)}'
			AND TABLE_NAME = '{$this->dbEscape($table_name)}'
		");

		$indexes = array();

		foreach ($query->rows as $index) {
			$indexes[] = $index['COLUMN_NAME'];
		}

		return $indexes;
	}

	private function getTableColumns($table_name) {
		$query = $this->db->query("
			SELECT * 
			FROM INFORMATION_SCHEMA.COLUMNS
			WHERE 
				TABLE_SCHEMA = '{$this->dbEscape(DB_DATABASE)}' 
				AND TABLE_NAME = '{$this->dbEscape($table_name)}'
				AND LCASE(DATA_TYPE) NOT IN ('blob', 'text', 'longtext')
		");

		$columns = array();

		foreach ($query->rows as $column) {
			$columns[] = $column['COLUMN_NAME'];
		}

		return $columns;
	}

	private function canIndex($column) {
		if (substr($column, -3) === '_id') {
			return true;
		}

		if (in_array($column, static::$INDEX_LIST)) {
			return true;
		}

		return false;
	}

	private function addIndex($table, $column) {
		ob_start();

		$this->db->query("ALTER TABLE `{$this->db->escape($table)}` ADD INDEX (`{$this->db->escape($column)}`)");

		$buf = ob_get_contents();

		ob_clean();

		if (strpos($buf, 'Error: ALTER') !== false) {
			throw new Exception('Your MySQL user may not have ALTER privilege.');
		}
	}

}