2024-06-20 14:10:42 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Class: Config
|
|
|
|
* Holds all of the configuration settings for the entire site.
|
|
|
|
*/
|
|
|
|
class Config {
|
|
|
|
# Array: $data
|
|
|
|
# Holds the configuration data as a $key => $val array.
|
|
|
|
private $data = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: __construct
|
|
|
|
* Loads the configuration file from disk.
|
|
|
|
*/
|
|
|
|
private function __construct() {
|
|
|
|
if (!$this->read() and !INSTALLING)
|
|
|
|
trigger_error(
|
|
|
|
__("Could not read the configuration file."),
|
|
|
|
E_USER_ERROR
|
|
|
|
);
|
|
|
|
|
|
|
|
fallback($this->data["sql"], array());
|
|
|
|
fallback($this->data["enabled_modules"], array());
|
|
|
|
fallback($this->data["enabled_feathers"], array());
|
|
|
|
fallback($this->data["routes"], array());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: __get
|
|
|
|
* Handles access to the configuration data.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* @mixed@
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function __get(
|
|
|
|
$name
|
|
|
|
): mixed {
|
2024-06-20 14:10:42 +00:00
|
|
|
if (isset($this->data[$name]))
|
|
|
|
return $this->data[$name];
|
|
|
|
|
|
|
|
trigger_error(
|
|
|
|
__("Requested configuration setting not found."),
|
|
|
|
E_USER_NOTICE
|
|
|
|
);
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: __isset
|
|
|
|
* Handles access to the configuration data.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function __isset(
|
|
|
|
$name
|
|
|
|
): bool {
|
2024-06-20 14:10:42 +00:00
|
|
|
return isset($this->data[$name]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: read
|
|
|
|
* Reads the configuration file and decodes the settings.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
private function read(
|
|
|
|
): array|false {
|
2024-06-20 14:10:42 +00:00
|
|
|
$security = "<?php header(\"Status: 403\"); exit(\"Access denied.\"); ?>\n";
|
2025-01-13 09:56:01 +00:00
|
|
|
|
|
|
|
$contents = @file_get_contents(
|
|
|
|
INCLUDES_DIR.DIR."config.json.php"
|
|
|
|
);
|
2024-06-20 14:10:42 +00:00
|
|
|
|
|
|
|
if ($contents === false)
|
|
|
|
return false;
|
|
|
|
|
2025-01-13 09:56:01 +00:00
|
|
|
$json = json_get(
|
|
|
|
str_replace($security, "", $contents),
|
|
|
|
true
|
|
|
|
);
|
2024-06-20 14:10:42 +00:00
|
|
|
|
|
|
|
if (!is_array($json))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
return $this->data = $json;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: write
|
|
|
|
* Encodes the settings and writes the configuration file.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
private function write(
|
|
|
|
): int|false {
|
2024-06-20 14:10:42 +00:00
|
|
|
$contents = "<?php header(\"Status: 403\"); exit(\"Access denied.\"); ?>\n";
|
2025-01-13 09:56:01 +00:00
|
|
|
|
2024-06-20 14:10:42 +00:00
|
|
|
$contents.= json_set(
|
|
|
|
$this->data,
|
|
|
|
JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES
|
|
|
|
);
|
|
|
|
|
2025-01-13 09:56:01 +00:00
|
|
|
return @file_put_contents(
|
|
|
|
INCLUDES_DIR.DIR."config.json.php",
|
|
|
|
$contents
|
|
|
|
);
|
2024-06-20 14:10:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: set
|
|
|
|
* Adds or replaces a configuration setting with the given value.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* $setting - The setting name.
|
|
|
|
* $value - The value to set.
|
|
|
|
* $fallback - Add the setting only if it doesn't exist.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function set(
|
|
|
|
$setting,
|
|
|
|
$value,
|
|
|
|
$fallback = false
|
|
|
|
): int|bool {
|
2024-06-20 14:10:42 +00:00
|
|
|
if (isset($this->data[$setting]) and $fallback)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
$this->data[$setting] = $value;
|
|
|
|
|
|
|
|
if (class_exists("Trigger"))
|
|
|
|
Trigger::current()->call("change_setting", $setting, $value);
|
|
|
|
|
|
|
|
return $this->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: remove
|
|
|
|
* Removes a configuration setting.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* $setting - The setting name.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function remove(
|
|
|
|
$setting
|
|
|
|
): int|false {
|
2024-06-20 14:10:42 +00:00
|
|
|
unset($this->data[$setting]);
|
|
|
|
return $this->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: current
|
|
|
|
* Returns a singleton reference to the current configuration.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function & current(
|
|
|
|
): self {
|
2024-06-20 14:10:42 +00:00
|
|
|
static $instance = null;
|
|
|
|
$instance = (empty($instance)) ? new self() : $instance ;
|
|
|
|
return $instance;
|
|
|
|
}
|
|
|
|
}
|