* @copyright 2020 MyAAC
 * @link      https://my-aac.org
 */
class Settings implements ArrayAccess
{
	static private $instance;
	private $settingsArray = [];
	private $settingsDatabase = [];
	private $cache = [];
	private $valuesAsked = [];
	/**
	 * @return Settings
	 */
	public static function getInstance(): Settings
	{
		if (!self::$instance) {
			self::$instance = new self();
		}
		return self::$instance;
	}
	public function load()
	{
		$cache = Cache::getInstance();
		if ($cache->enabled()) {
			$tmp = '';
			if ($cache->fetch('settings', $tmp)) {
				$this->settingsDatabase = unserialize($tmp);
				return;
			}
		}
		global $db;
		$settings = $db->query('SELECT * FROM `' . TABLE_PREFIX . 'settings`');
		if($settings->rowCount() > 0) {
			foreach ($settings->fetchAll(PDO::FETCH_ASSOC) as $setting) {
				$this->settingsDatabase[$setting['name']][$setting['key']] = $setting['value'];
			}
		}
		if ($cache->enabled()) {
			$cache->set('settings', serialize($this->settingsDatabase), 600);
		}
	}
	public function save($pluginName, $settings) {
		global $db;
		$db->query('DELETE FROM `' . TABLE_PREFIX . 'settings` WHERE `name` = ' . $db->quote($pluginName) . ';');
		foreach ($settings as $key => $value) {
			try {
				$db->insert(TABLE_PREFIX . 'settings', ['name' => $pluginName, 'key' => $key, 'value' => $value]);
			} catch (PDOException $error) {
				warning('Error while saving setting (' . $pluginName . ' - ' . $key . '): ' . $error->getMessage());
			}
		}
		$cache = Cache::getInstance();
		if ($cache->enabled()) {
			$cache->delete('settings');
		}
	}
	public function updateInDatabase($pluginName, $key, $value)
	{
		global $db;
		$db->update(TABLE_PREFIX . 'settings', ['value' => $value], ['name' => $pluginName, 'key' => $key]);
	}
	public function deleteFromDatabase($pluginName, $key = null)
	{
		global $db;
		if (!isset($key)) {
			$db->delete(TABLE_PREFIX . 'settings', ['name' => $pluginName], -1);
		}
		else {
			$db->delete(TABLE_PREFIX . 'settings', ['name' => $pluginName, 'key' => $key]);
		}
	}
	public static function display($plugin, $settings): array
	{
		global $db;
		$query = 'SELECT `key`, `value` FROM `' . TABLE_PREFIX . 'settings` WHERE `name` = ' . $db->quote($plugin) . ';';
		$query = $db->query($query);
		$settingsDb = [];
		if($query->rowCount() > 0) {
			foreach($query->fetchAll(PDO::FETCH_ASSOC) as $value) {
				$settingsDb[$value['key']] = $value['value'];
			}
		}
		$javascript = '';
		ob_start();
		?>
		
		
			' . ($type ? 'Yes' : 'No') . ' ';
			};
			$i = 0;
			$j = 0;
			foreach($settings as $key => $setting) {
				if ($setting['type'] === 'category') {
					if ($j++ !== 0) { // close previous category
						echo '
';
					}
				?>
				
					';
					}
					?>
					
= $setting['title']; ?>
					
						
							
								| Name | Value | Description | 
						
						
						
					
						|  | ';
				}
				else if($setting['type'] === 'textarea') {
					echo '';
				}
				else if ($setting['type'] === 'options') {
					if ($setting['options'] === '$templates') {
						$templates = [];
						foreach (get_templates() as $value) {
							$templates[$value] = $value;
						}
						$setting['options'] = $templates;
					}
					else if($setting['options'] === '$clients') {
						$clients = [];
						foreach((array)config('clients') as $client) {
							$client_version = (string)($client / 100);
							if(strpos($client_version, '.') === false)
								$client_version .= '.0';
							$clients[$client] = $client_version;
						}
						$setting['options'] = $clients;
					}
					else if ($setting['options'] == '$timezones') {
						$timezones = [];
						foreach (DateTimeZone::listIdentifiers() as $value) {
							$timezones[$value] = $value;
						}
						$setting['options'] = $timezones;
					}
					else {
						if (is_string($setting['options'])) {
							$setting['options'] = explode(',', $setting['options']);
							foreach ($setting['options'] as &$option) {
								$option = trim($option);
							}
						}
					}
					echo '';
				}
				if (!isset($setting['hidden']) || !$setting['hidden']) {
				?> | 
								';
								echo 'Default: ';
								if ($setting['type'] === 'boolean') {
									echo ($setting['default'] ? 'Yes' : 'No');
								}
								else if (in_array($setting['type'], ['text', 'number', 'email', 'password', 'textarea'])) {
									echo $setting['default'];
								}
								else if ($setting['type'] === 'options') {
									echo $setting['options'][$setting['default']];
								}
								?>
							 |