612 行
		
	
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			612 行
		
	
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|  | <?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed'); | ||
|  | /** | ||
|  |  * CodeIgniter | ||
|  |  * | ||
|  |  * An open source application development framework for PHP 5.1.6 or newer | ||
|  |  * | ||
|  |  * @package		CodeIgniter | ||
|  |  * @author		ExpressionEngine Dev Team | ||
|  |  * @copyright	Copyright (c) 2008 - 2011, EllisLab, Inc. | ||
|  |  * @license		http://codeigniter.com/user_guide/license.html | ||
|  |  * @link		http://codeigniter.com | ||
|  |  * @since		Version 1.0 | ||
|  |  * @filesource | ||
|  |  */ | ||
|  | 
 | ||
|  | // ------------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | /** | ||
|  |  * URI Class | ||
|  |  * | ||
|  |  * Parses URIs and determines routing | ||
|  |  * | ||
|  |  * @package		CodeIgniter | ||
|  |  * @subpackage	Libraries | ||
|  |  * @category	URI | ||
|  |  * @author		ExpressionEngine Dev Team | ||
|  |  * @link		http://codeigniter.com/user_guide/libraries/uri.html | ||
|  |  */ | ||
|  | class CI_URI { | ||
|  | 
 | ||
|  | 	var	$keyval			= array(); | ||
|  | 	var $uri_string; | ||
|  | 	var $segments		= array(); | ||
|  | 	var $rsegments		= array(); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Constructor | ||
|  | 	 * | ||
|  | 	 * Simply globalizes the $RTR object.  The front | ||
|  | 	 * loads the Router class early on so it's not available | ||
|  | 	 * normally as other classes are. | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 */ | ||
|  | 	function __construct() | ||
|  | 	{ | ||
|  | 		$this->config =& load_class('Config', 'core'); | ||
|  | 		log_message('debug', "URI Class Initialized"); | ||
|  | 	} | ||
|  | 
 | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Get the URI String | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function _fetch_uri_string() | ||
|  | 	{ | ||
|  | 		if (strtoupper($this->config->item('uri_protocol')) == 'AUTO') | ||
|  | 		{ | ||
|  | 			// Is the request coming from the command line?
 | ||
|  | 			if (defined('STDIN')) | ||
|  | 			{ | ||
|  | 				$this->uri_string = $this->_parse_cli_args(); | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// Let's try the REQUEST_URI first, this will work in most situations
 | ||
|  | 			if ($uri = $this->_detect_uri()) | ||
|  | 			{ | ||
|  | 				$this->uri_string = $uri; | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// Is there a PATH_INFO variable?
 | ||
|  | 			// Note: some servers seem to have trouble with getenv() so we'll test it two ways
 | ||
|  | 			$path = (isset($_SERVER['PATH_INFO'])) ? $_SERVER['PATH_INFO'] : @getenv('PATH_INFO'); | ||
|  | 			if (trim($path, '/') != '' && $path != "/".SELF) | ||
|  | 			{ | ||
|  | 				$this->uri_string = $path; | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// No PATH_INFO?... What about QUERY_STRING?
 | ||
|  | 			$path =  (isset($_SERVER['QUERY_STRING'])) ? $_SERVER['QUERY_STRING'] : @getenv('QUERY_STRING'); | ||
|  | 			if (trim($path, '/') != '') | ||
|  | 			{ | ||
|  | 				$this->uri_string = $path; | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// As a last ditch effort lets try using the $_GET array
 | ||
|  | 			if (is_array($_GET) && count($_GET) == 1 && trim(key($_GET), '/') != '') | ||
|  | 			{ | ||
|  | 				$this->uri_string = key($_GET); | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// We've exhausted all our options...
 | ||
|  | 			$this->uri_string = ''; | ||
|  | 		} | ||
|  | 		else | ||
|  | 		{ | ||
|  | 			$uri = strtoupper($this->config->item('uri_protocol')); | ||
|  | 
 | ||
|  | 			if ($uri == 'REQUEST_URI') | ||
|  | 			{ | ||
|  | 				$this->uri_string = $this->_detect_uri(); | ||
|  | 				return; | ||
|  | 			} | ||
|  | 			elseif ($uri == 'CLI') | ||
|  | 			{ | ||
|  | 				$this->uri_string = $this->_parse_cli_args(); | ||
|  | 				return; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			$this->uri_string = (isset($_SERVER[$uri])) ? $_SERVER[$uri] : @getenv($uri); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		// If the URI contains only a slash we'll kill it
 | ||
|  | 		if ($this->uri_string == '/') | ||
|  | 		{ | ||
|  | 			$this->uri_string = ''; | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Detects the URI | ||
|  | 	 * | ||
|  | 	 * This function will detect the URI automatically and fix the query string | ||
|  | 	 * if necessary. | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	private function _detect_uri() | ||
|  | 	{ | ||
|  | 		if ( ! isset($_SERVER['REQUEST_URI'])) | ||
|  | 		{ | ||
|  | 			return ''; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		$uri = $_SERVER['REQUEST_URI']; | ||
|  | 		if (strpos($uri, $_SERVER['SCRIPT_NAME']) === 0) | ||
|  | 		{ | ||
|  | 			$uri = substr($uri, strlen($_SERVER['SCRIPT_NAME'])); | ||
|  | 		} | ||
|  | 		elseif (strpos($uri, dirname($_SERVER['SCRIPT_NAME'])) === 0) | ||
|  | 		{ | ||
|  | 			$uri = substr($uri, strlen(dirname($_SERVER['SCRIPT_NAME']))); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		// This section ensures that even on servers that require the URI to be in the query string (Nginx) a correct
 | ||
|  | 		// URI is found, and also fixes the QUERY_STRING server var and $_GET array.
 | ||
|  | 		if (strncmp($uri, '?/', 2) === 0) | ||
|  | 		{ | ||
|  | 			$uri = substr($uri, 2); | ||
|  | 		} | ||
|  | 		$parts = preg_split('#\?#i', $uri, 2); | ||
|  | 		$uri = $parts[0]; | ||
|  | 		if (isset($parts[1])) | ||
|  | 		{ | ||
|  | 			$_SERVER['QUERY_STRING'] = $parts[1]; | ||
|  | 			parse_str($_SERVER['QUERY_STRING'], $_GET); | ||
|  | 		} | ||
|  | 		else | ||
|  | 		{ | ||
|  | 			$_SERVER['QUERY_STRING'] = ''; | ||
|  | 			$_GET = array(); | ||
|  | 		} | ||
|  | 		 | ||
|  | 		if ($uri == '/' || empty($uri)) | ||
|  | 		{ | ||
|  | 			return '/'; | ||
|  | 		} | ||
|  | 				 | ||
|  | 		$uri = parse_url($uri, PHP_URL_PATH); | ||
|  | 
 | ||
|  | 		// Do some final cleaning of the URI and return it
 | ||
|  | 		return str_replace(array('//', '../'), '/', trim($uri, '/')); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Parse cli arguments | ||
|  | 	 * | ||
|  | 	 * Take each command line argument and assume it is a URI segment. | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	private function _parse_cli_args() | ||
|  | 	{ | ||
|  | 		$args = array_slice($_SERVER['argv'], 1); | ||
|  | 
 | ||
|  | 		return $args ? '/' . implode('/', $args) : ''; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Filter segments for malicious characters | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @param	string | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function _filter_uri($str) | ||
|  | 	{ | ||
|  | 		if ($str != '' && $this->config->item('permitted_uri_chars') != '' && $this->config->item('enable_query_strings') == FALSE) | ||
|  | 		{ | ||
|  | 			// preg_quote() in PHP 5.3 escapes -, so the str_replace() and addition of - to preg_quote() is to maintain backwards
 | ||
|  | 			// compatibility as many are unaware of how characters in the permitted_uri_chars will be parsed as a regex pattern
 | ||
|  | 			if ( ! preg_match("|^[".str_replace(array('\\-', '\-'), '-', preg_quote($this->config->item('permitted_uri_chars'), '-'))."]+$|i", $str)) | ||
|  | 			{ | ||
|  | 				show_error('The URI you submitted has disallowed characters.', 400); | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		// Convert programatic characters to entities
 | ||
|  | 		$bad	= array('$',		'(',		')',		'%28',		'%29'); | ||
|  | 		$good	= array('$',	'(',	')',	'(',	')'); | ||
|  | 
 | ||
|  | 		return str_replace($bad, $good, $str); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Remove the suffix from the URL if needed | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	void | ||
|  | 	 */ | ||
|  | 	function _remove_url_suffix() | ||
|  | 	{ | ||
|  | 		if  ($this->config->item('url_suffix') != "") | ||
|  | 		{ | ||
|  | 			$this->uri_string = preg_replace("|".preg_quote($this->config->item('url_suffix'))."$|", "", $this->uri_string); | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Explode the URI Segments. The individual segments will | ||
|  | 	 * be stored in the $this->segments array. | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	void | ||
|  | 	 */ | ||
|  | 	function _explode_segments() | ||
|  | 	{ | ||
|  | 		foreach (explode("/", preg_replace("|/*(.+?)/*$|", "\\1", $this->uri_string)) as $val) | ||
|  | 		{ | ||
|  | 			// Filter segments for security
 | ||
|  | 			$val = trim($this->_filter_uri($val)); | ||
|  | 
 | ||
|  | 			if ($val != '') | ||
|  | 			{ | ||
|  | 				$this->segments[] = $val; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 	/** | ||
|  | 	 * Re-index Segments | ||
|  | 	 * | ||
|  | 	 * This function re-indexes the $this->segment array so that it | ||
|  | 	 * starts at 1 rather than 0.  Doing so makes it simpler to | ||
|  | 	 * use functions like $this->uri->segment(n) since there is | ||
|  | 	 * a 1:1 relationship between the segment array and the actual segments. | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @return	void | ||
|  | 	 */ | ||
|  | 	function _reindex_segments() | ||
|  | 	{ | ||
|  | 		array_unshift($this->segments, NULL); | ||
|  | 		array_unshift($this->rsegments, NULL); | ||
|  | 		unset($this->segments[0]); | ||
|  | 		unset($this->rsegments[0]); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch a URI Segment | ||
|  | 	 * | ||
|  | 	 * This function returns the URI segment based on the number provided. | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	integer | ||
|  | 	 * @param	bool | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function segment($n, $no_result = FALSE) | ||
|  | 	{ | ||
|  | 		return ( ! isset($this->segments[$n])) ? $no_result : $this->segments[$n]; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch a URI "routed" Segment | ||
|  | 	 * | ||
|  | 	 * This function returns the re-routed URI segment (assuming routing rules are used) | ||
|  | 	 * based on the number provided.  If there is no routing this function returns the | ||
|  | 	 * same result as $this->segment() | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	integer | ||
|  | 	 * @param	bool | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function rsegment($n, $no_result = FALSE) | ||
|  | 	{ | ||
|  | 		return ( ! isset($this->rsegments[$n])) ? $no_result : $this->rsegments[$n]; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Generate a key value pair from the URI string | ||
|  | 	 * | ||
|  | 	 * This function generates and associative array of URI data starting | ||
|  | 	 * at the supplied segment. For example, if this is your URI: | ||
|  | 	 * | ||
|  | 	 *	example.com/user/search/name/joe/location/UK/gender/male | ||
|  | 	 * | ||
|  | 	 * You can use this function to generate an array with this prototype: | ||
|  | 	 * | ||
|  | 	 * array ( | ||
|  | 	 *			name => joe | ||
|  | 	 *			location => UK | ||
|  | 	 *			gender => male | ||
|  | 	 *		 ) | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	integer	the starting segment number | ||
|  | 	 * @param	array	an array of default values | ||
|  | 	 * @return	array | ||
|  | 	 */ | ||
|  | 	function uri_to_assoc($n = 3, $default = array()) | ||
|  | 	{ | ||
|  | 		return $this->_uri_to_assoc($n, $default, 'segment'); | ||
|  | 	} | ||
|  | 	/** | ||
|  | 	 * Identical to above only it uses the re-routed segment array | ||
|  | 	 * | ||
|  | 	 */ | ||
|  | 	function ruri_to_assoc($n = 3, $default = array()) | ||
|  | 	{ | ||
|  | 		return $this->_uri_to_assoc($n, $default, 'rsegment'); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Generate a key value pair from the URI string or Re-routed URI string | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @param	integer	the starting segment number | ||
|  | 	 * @param	array	an array of default values | ||
|  | 	 * @param	string	which array we should use | ||
|  | 	 * @return	array | ||
|  | 	 */ | ||
|  | 	function _uri_to_assoc($n = 3, $default = array(), $which = 'segment') | ||
|  | 	{ | ||
|  | 		if ($which == 'segment') | ||
|  | 		{ | ||
|  | 			$total_segments = 'total_segments'; | ||
|  | 			$segment_array = 'segment_array'; | ||
|  | 		} | ||
|  | 		else | ||
|  | 		{ | ||
|  | 			$total_segments = 'total_rsegments'; | ||
|  | 			$segment_array = 'rsegment_array'; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		if ( ! is_numeric($n)) | ||
|  | 		{ | ||
|  | 			return $default; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		if (isset($this->keyval[$n])) | ||
|  | 		{ | ||
|  | 			return $this->keyval[$n]; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		if ($this->$total_segments() < $n) | ||
|  | 		{ | ||
|  | 			if (count($default) == 0) | ||
|  | 			{ | ||
|  | 				return array(); | ||
|  | 			} | ||
|  | 
 | ||
|  | 			$retval = array(); | ||
|  | 			foreach ($default as $val) | ||
|  | 			{ | ||
|  | 				$retval[$val] = FALSE; | ||
|  | 			} | ||
|  | 			return $retval; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		$segments = array_slice($this->$segment_array(), ($n - 1)); | ||
|  | 
 | ||
|  | 		$i = 0; | ||
|  | 		$lastval = ''; | ||
|  | 		$retval  = array(); | ||
|  | 		foreach ($segments as $seg) | ||
|  | 		{ | ||
|  | 			if ($i % 2) | ||
|  | 			{ | ||
|  | 				$retval[$lastval] = $seg; | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 				$retval[$seg] = FALSE; | ||
|  | 				$lastval = $seg; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			$i++; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		if (count($default) > 0) | ||
|  | 		{ | ||
|  | 			foreach ($default as $val) | ||
|  | 			{ | ||
|  | 				if ( ! array_key_exists($val, $retval)) | ||
|  | 				{ | ||
|  | 					$retval[$val] = FALSE; | ||
|  | 				} | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		// Cache the array for reuse
 | ||
|  | 		$this->keyval[$n] = $retval; | ||
|  | 		return $retval; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Generate a URI string from an associative array | ||
|  | 	 * | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	array	an associative array of key/values | ||
|  | 	 * @return	array | ||
|  | 	 */ | ||
|  | 	function assoc_to_uri($array) | ||
|  | 	{ | ||
|  | 		$temp = array(); | ||
|  | 		foreach ((array)$array as $key => $val) | ||
|  | 		{ | ||
|  | 			$temp[] = $key; | ||
|  | 			$temp[] = $val; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		return implode('/', $temp); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch a URI Segment and add a trailing slash | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	integer | ||
|  | 	 * @param	string | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function slash_segment($n, $where = 'trailing') | ||
|  | 	{ | ||
|  | 		return $this->_slash_segment($n, $where, 'segment'); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch a URI Segment and add a trailing slash | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @param	integer | ||
|  | 	 * @param	string | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function slash_rsegment($n, $where = 'trailing') | ||
|  | 	{ | ||
|  | 		return $this->_slash_segment($n, $where, 'rsegment'); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch a URI Segment and add a trailing slash - helper function
 | ||
|  | 	 * | ||
|  | 	 * @access	private | ||
|  | 	 * @param	integer | ||
|  | 	 * @param	string | ||
|  | 	 * @param	string | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function _slash_segment($n, $where = 'trailing', $which = 'segment') | ||
|  | 	{ | ||
|  | 		$leading	= '/'; | ||
|  | 		$trailing	= '/'; | ||
|  | 
 | ||
|  | 		if ($where == 'trailing') | ||
|  | 		{ | ||
|  | 			$leading	= ''; | ||
|  | 		} | ||
|  | 		elseif ($where == 'leading') | ||
|  | 		{ | ||
|  | 			$trailing	= ''; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		return $leading.$this->$which($n).$trailing; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Segment Array | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	array | ||
|  | 	 */ | ||
|  | 	function segment_array() | ||
|  | 	{ | ||
|  | 		return $this->segments; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Routed Segment Array | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	array | ||
|  | 	 */ | ||
|  | 	function rsegment_array() | ||
|  | 	{ | ||
|  | 		return $this->rsegments; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Total number of segments | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	integer | ||
|  | 	 */ | ||
|  | 	function total_segments() | ||
|  | 	{ | ||
|  | 		return count($this->segments); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Total number of routed segments | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	integer | ||
|  | 	 */ | ||
|  | 	function total_rsegments() | ||
|  | 	{ | ||
|  | 		return count($this->rsegments); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch the entire URI string | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function uri_string() | ||
|  | 	{ | ||
|  | 		return $this->uri_string; | ||
|  | 	} | ||
|  | 
 | ||
|  | 
 | ||
|  | 	// --------------------------------------------------------------------
 | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * Fetch the entire Re-routed URI string | ||
|  | 	 * | ||
|  | 	 * @access	public | ||
|  | 	 * @return	string | ||
|  | 	 */ | ||
|  | 	function ruri_string() | ||
|  | 	{ | ||
|  | 		return '/'.implode('/', $this->rsegment_array()); | ||
|  | 	} | ||
|  | 
 | ||
|  | } | ||
|  | // END URI Class
 | ||
|  | 
 | ||
|  | /* End of file URI.php */ | ||
|  | /* Location: ./system/core/URI.php */ |