. // //-------------------- // // IMPORTANT NOTICE: // // Do not edit this file unless you know what you are doing. Instead, // please use the HashOver administration panel to graphically adjust // the settings, or create/edit the settings JSON file. // Automated settings class Settings extends SensitiveSettings { public $themePath; public $rootDirectory; public $commentsRoot; public $commentsPath; public $httpRoot; public $httpBackend; public $httpImages; public $cookieExpiration; public $scheme; public $domain; public $absolutePath; public function __construct () { // Set encoding mb_internal_encoding ('UTF-8'); // Get parent directory $root_directory = dirname (dirname (__DIR__)); // Get HTTP root directory $root_position = mb_strlen (realpath ($_SERVER['DOCUMENT_ROOT'])); $http_directory = mb_substr ($root_directory, $root_position); // Replace backslashes with forward slashes on Windows if (DIRECTORY_SEPARATOR === '\\') { $root_directory = str_replace ('\\', '/', $root_directory); $http_directory = str_replace ('\\', '/', $http_directory); } $http_directory = preg_replace("%/[^/]+/[^/]+$%", "", $_SERVER['REQUEST_URI']); // Root directory for script $this->rootDirectory = $root_directory; // Comments directory path $this->commentsRoot = $root_directory . '/comments'; $this->commentsPath = $this->commentsRoot; // Root directory for HTTP $this->httpRoot = $http_directory; // Backend directory for HTTP $this->httpBackend = $http_directory . '/backend'; // Image directory for HTTP $this->httpImages = $http_directory . '/images'; // Cookie expiration date $this->cookieExpiration = time () + 60 * 60 * 24 * 30; // Get connection scheme $this->scheme = $this->isHTTPS () ? 'https' : 'http'; // Domain name for refer checking & notifications $this->domain = Misc::getArrayItem ($_SERVER, 'HTTP_HOST') ?: 'localhost'; // Absolute path or remote access $this->absolutePath = $this->scheme . '://' . $this->domain; // Load JSON settings $this->loadSettingsFile (); // Synchronize settings $this->syncSettings (); } // Checks if connection is on HTTPS/SSL public function isHTTPS () { // The connection is HTTPS if server says so if (!empty ($_SERVER['HTTPS']) and $_SERVER['HTTPS'] !== 'off') { return true; } // Assume the connection is HTTPS on standard SSL port if (Misc::getArrayItem ($_SERVER, 'SERVER_PORT') === 443) { return true; } return false; } // Synchronizes specific settings after remote changes public function syncSettings () { // Theme path $this->themePath = 'themes/' . $this->theme; // Check if timezone is set to auto if ($this->serverTimezone === 'auto') { // If so, set timezone setting to current timezone $this->serverTimezone = date_default_timezone_get (); } else { // If not, set timezone to given timezone $tz = @date_default_timezone_set ($this->serverTimezone); // And throw exception if timezone ID is invalid if ($tz === false) { throw new \Exception (sprintf ( '"%s" is not a valid timezone', $this->serverTimezone )); } } // Disable likes and dislikes if cookies are disabled if ($this->setsCookies === false) { $this->allowsLikes = false; $this->allowsDislikes = false; } // Setup default field options foreach (array ('name', 'password', 'email', 'website') as $field) { if (!isset ($this->fieldOptions[$field])) { $this->fieldOptions[$field] = true; } } // Disable password if name is disabled if ($this->fieldOptions['name'] === false) { $this->fieldOptions['password'] = false; } // Disable login if name or password is disabled if ($this->fieldOptions['name'] === false or $this->fieldOptions['password'] === false) { $this->allowsLogin = false; } // Disable autologin if login is disabled if ($this->allowsLogin === false) { $this->usesAutoLogin = false; } // Check if the Gravatar default image name is not custom if ($this->gravatarDefault !== 'custom') { // If so, list Gravatar default image names $gravatar_defaults = array ('identicon', 'monsterid', 'wavatar', 'retro'); // And set Gravatar default image to custom if its value is invalid if (!in_array ($this->gravatarDefault, $gravatar_defaults, true)) { $this->gravatarDefault = 'custom'; } } // Backend directory for HTTP $this->httpBackend = $this->httpRoot . '/backend'; // Image directory for HTTP $this->httpImages = $this->httpRoot . '/images'; } // Overrides settings based on JSON data protected function overrideSettings ($json, $class = 'Settings') { // Parse JSON data $settings = @json_decode ($json, true); // Return void if data is anything other than an array if (!is_array ($settings)) { return; } // Loop through JSON data foreach ($settings as $setting => $value) { // Check if the key contains dashes if (mb_strpos ($setting, '-') !== false) { // If so, convert setting key to lowercase $setting = mb_strtolower ($setting); // Then convert dashed-case setting key to camelCase $setting = preg_replace_callback ('/-([a-z])/', function ($grp) { return mb_strtoupper ($grp[1]); }, $setting); } // Check if the setting from the JSON data exists if (property_exists ('HashOver\\' . $class, $setting)) { // If so, get default setting type $default_type = gettype ($this->{$setting}); // Skip setting if its an empty string if ($default_type === 'string' and empty ($value)) { continue; } // Otherwise, override default if setting types match if (gettype ($value) === $default_type) { $this->{$setting} = $value; } } } } // Reads JSON settings file and uses it to override default settings protected function loadSettingsFile () { // JSON settings file path $path = $this->getAbsolutePath ('config/settings.json'); // Check if JSON settings file exists if (file_exists ($path)) { // If so, read the file $json = @file_get_contents ($path); // And override settings $this->overrideSettings ($json); } } // Accepts JSON data from the frontend to override default settings public function loadUserSettings ($json) { // Only override settings safe to expose to the frontend $this->overrideSettings ($json, 'SafeSettings'); // Synchronize settings $this->syncSettings (); } // Returns a server-side absolute file path public function getAbsolutePath ($file) { return $this->rootDirectory . '/' . trim ($file, '/'); } // Returns a client-side path for a file within the HashOver root public function getHttpPath ($file) { return $this->httpRoot . '/' . trim ($file, '/'); } // Returns a client-side path for a file within the backend directory public function getBackendPath ($file) { return $this->httpBackend . '/' . trim ($file, '/'); } // Returns a client-side path for a file within the images directory public function getImagePath ($filename) { $path = $this->httpImages . '/' . trim ($filename, '/'); $path .= '.' . $this->imageFormat; return $path; } // Returns a client-side path for a file within the configured theme public function getThemePath ($file, $http = true) { // Path to the requested file in the configured theme $theme_file = $this->themePath . '/' . $file; // Use the same file from the default theme if it doesn't exist if (!file_exists ($this->getAbsolutePath ($theme_file))) { $theme_file = 'themes/default/' . $file; } // Convert the theme file path for HTTP use if told to if ($http !== false) { $theme_file = $this->getHttpPath ($theme_file); } return $theme_file; } // Check if a given API format is enabled public function apiStatus ($api) { // Check if the given API is enabled if (is_array ($this->enabledApi)) { // Return enabled if all available APIs are enabled if (in_array ('all', $this->enabledApi)) { return 'enabled'; } // Return enabled if the given API is enabled if (in_array ($api, $this->enabledApi)) { return 'enabled'; } } // Otherwise, assume API is disabled by default return 'disabled'; } }