. */ /** * Handles config values */ class uConfig { // version number static $version = "0.2-beta"; // default map drawing framework static $mapapi = "openlayers"; // gmaps key static $gkey = null; // openlayers additional map layers // OpenCycleMap (0 = no, 1 = yes) static $layer_ocm = 1; // MapQuest-OSM (0 = no, 1 = yes) static $layer_mq = 1; // osmapa.pl (0 = no, 1 = yes) static $layer_osmapa = 1; // UMP (0 = no, 1 = yes) static $layer_ump = 1; // default coordinates for initial map static $init_latitude = 52.23; static $init_longitude = 21.01; // MySQL config static $dbhost = ""; // mysql host, eg. localhost static $dbuser = ""; // database user static $dbpass = ""; // database pass static $dbname = ""; // database name static $dbprefix = ""; // optional table names prefix, eg. "ulogger_" // require login/password authentication static $require_authentication = true; // all users tracks are visible to authenticated user static $public_tracks = false; // admin user who has access to all users locations // none if empty static $admin_user = ""; // miniumum required length of user password static $pass_lenmin = 12; // required strength of user password // 0 = no requirements, // 1 = require mixed case letters (lower and upper), // 2 = require mixed case and numbers // 3 = require mixed case, numbers and non-alphanumeric characters static $pass_strength = 2; // Default interval in seconds for live auto reload static $interval = 10; // Default language static $lang = "en"; // units static $units = "metric"; private static $fileLoaded = false; /** * Constructor */ public function __construct() { $this->setFromFile(); $this->setFromCookies(); } /** * Read config values from "/config.php" file */ private function setFromFile() { $configFile = ROOT_DIR . "/config.php"; if (self::$fileLoaded || !file_exists($configFile)) { return; } self::$fileLoaded = true; include_once($configFile); if (isset($mapapi)) { self::$mapapi = $mapapi; } if (isset($gkey)) { self::$gkey = $gkey; } if (isset($layer_ocm)) { self::$layer_ocm = $layer_ocm; } if (isset($layer_mq)) { self::$layer_mq = $layer_mq; } if (isset($layer_osmapa)) { self::$layer_osmapa = $layer_osmapa; } if (isset($layer_ump)) { self::$layer_ump = $layer_ump; } if (isset($init_latitude)) { self::$init_latitude = $init_latitude; } if (isset($init_longitude)) { self::$init_longitude = $init_longitude; } if (isset($dbhost)) { self::$dbhost = $dbhost; } if (isset($dbuser)) { self::$dbuser = $dbuser; } if (isset($dbpass)) { self::$dbpass = $dbpass; } if (isset($dbname)) { self::$dbname = $dbname; } if (isset($dbprefix)) { self::$dbprefix = $dbprefix; } if (isset($require_authentication)) { self::$require_authentication = (bool) $require_authentication; } if (isset($public_tracks)) { self::$public_tracks = (bool) $public_tracks; } if (isset($admin_user)) { self::$admin_user = $admin_user; } if (isset($pass_lenmin)) { self::$pass_lenmin = (int) $pass_lenmin; } if (isset($pass_strength)) { self::$pass_strength = (int) $pass_strength; } if (isset($interval)) { self::$interval = (int) $interval; } if (isset($lang)) { self::$lang = $lang; } if (isset($units)) { self::$units = $units; } if (!self::$require_authentication) { // tracks must be public if we don't require authentication self::$public_tracks = true; } } /** * Read config values stored in cookies */ private function setFromCookies() { if (isset($_COOKIE["ulogger_api"])) { self::$mapapi = $_COOKIE["ulogger_api"]; } if (isset($_COOKIE["ulogger_lang"])) { self::$lang = $_COOKIE["ulogger_lang"]; } if (isset($_COOKIE["ulogger_units"])) { self::$units = $_COOKIE["ulogger_units"]; } if (isset($_COOKIE["ulogger_interval"])) { self::$interval = $_COOKIE["ulogger_interval"]; } } public function isFileLoaded() { return self::$fileLoaded; } /** * Regex to test if password matches strength and length requirements. * Valid for both php and javascript */ public function passRegex() { static $regex = ""; if (self::$pass_strength > 0) { // lower and upper case $regex .= "(?=.*[a-z])(?=.*[A-Z])"; } if (self::$pass_strength > 1) { // digits $regex .= "(?=.*[0-9])"; } if (self::$pass_strength > 2) { // not latin, not digits $regex .= "(?=.*[^a-zA-Z0-9])"; } if (self::$pass_lenmin > 0) { $regex .= "(?=.{" . self::$pass_lenmin . ",})"; } if (!empty($regex)) { $regex = "/" . $regex . "/"; } return $regex; } } ?>