Example #1
0
 /**
  * Get the base URL, possibly with a controller script
  * @method baseUrl
  * @static
  * @param {boolean} [$with_possible_controller=false] If this is true, and if the URL contains 
  *  the controller script, then the controller script is included 
  *  in the return value. You can also pass a string here, which
  *  will then be simply appended as the controller.
  */
 static function baseUrl($with_possible_controller = false)
 {
     if (isset(self::$base_url)) {
         if (is_string($with_possible_controller)) {
             if (empty($with_possible_controller)) {
                 return self::$app_root_url;
             }
             return self::$app_root_url . "/" . $with_possible_controller;
         }
         if ($with_possible_controller) {
             return self::$base_url;
         }
         return self::$app_root_url;
     }
     if (isset($_SERVER['SERVER_NAME'])) {
         // This is a web request, so we can automatically determine
         // the app root URL. If you want the canonical one which the developer
         // may have specified in the config field "Q"/"web"/"appRootUrl"
         // then just query it via Q_Config::get().
         // Infer things
         self::$controller_url = self::inferControllerUrl($script_name);
         // Get the app root URL
         self::$app_root_url = self::getAppRootUrl();
         // Automatically figure out whether to omit
         // the controller name from the url
         self::$controller_present = 0 == strncmp($_SERVER['REQUEST_URI'], $_SERVER['SCRIPT_NAME'], strlen($_SERVER['SCRIPT_NAME']));
         // Special case for action.php controller
         // in case a misconfigured web server executes index.php even though
         // a url of the form $base_url/action.php/... was requested,
         // we will try to detect action.php anyway, and set it accordingly
         $slashpos = strrpos($script_name, '/');
         $action_script_name = ($slashpos ? substr($script_name, 0, $slashpos) : '') . '/action.php';
         if (0 == strncmp($_SERVER['REQUEST_URI'], $action_script_name, strlen($action_script_name))) {
             self::$controller_url = substr(self::$controller_url, 0, strrpos(self::$controller_url, '/')) . '/action.php';
             self::$controller_present = true;
             Q::$controller = 'Q_ActionController';
         }
         // Set the base url
         self::$base_url = self::$controller_present ? self::$controller_url : self::$app_root_url;
     } else {
         // This is not a web request, and we absolutely need
         // the canonical app root URL to have been specified.
         $ar = Q_Config::get('Q', 'web', 'appRootUrl', false);
         if (!$ar) {
             throw new Q_Exception_MissingConfig(array('fieldpath' => 'Q/web/appRootUrl'));
         }
         $cs = Q_Config::get('Q', 'web', 'controllerSuffix', '');
         self::$app_root_url = $ar;
         self::$controller_url = $ar . $cs;
         self::$controller_present = false;
         self::$base_url = self::$app_root_url;
     }
     if (is_string($with_possible_controller)) {
         return self::$app_root_url . "/" . $with_possible_controller;
     }
     if ($with_possible_controller) {
         return self::$base_url;
     }
     return self::$app_root_url;
 }