URL helper class.
Class declared in SYSPATH/classes/kohana/url.php on line 11.
Gets the base URL to the application.
To specify a protocol, provide the protocol as a string or request object.
If a protocol is used, a complete URL will be generated using the
$_SERVER['HTTP_HOST'] variable.
// Absolute URL path with no host or protocol
echo URL::base();
// Absolute URL path with host, https protocol and index.php if set
echo URL::base('https', TRUE);
// Absolute URL path with host and protocol from $request
echo URL::base($request);
mixed
$protocol
 = NULL - Protocol string, [Request], or booleanboolean
$index
 = bool FALSE - Add index file to URL?stringpublic static function base($protocol = NULL, $index = FALSE)
{
	// Start with the configured base URL
	$base_url = Kohana::$base_url;
	if ($protocol === TRUE)
	{
		// Use the initial request to get the protocol
		$protocol = Request::$initial;
	}
	if ($protocol instanceof Request)
	{
		// Use the current protocol
		$protocol = $protocol->protocol();
	}
	if ( ! $protocol)
	{
		// Use the configured default protocol
		$protocol = parse_url($base_url, PHP_URL_SCHEME);
	}
	if ($index === TRUE AND ! empty(Kohana::$index_file))
	{
		// Add the index file to the URL
		$base_url .= Kohana::$index_file.'/';
	}
	if (is_string($protocol))
	{
		if ($port = parse_url($base_url, PHP_URL_PORT))
		{
			// Found a port, make it usable for the URL
			$port = ':'.$port;
		}
		if ($domain = parse_url($base_url, PHP_URL_HOST))
		{
			// Remove everything but the path from the URL
			$base_url = parse_url($base_url, PHP_URL_PATH);
		}
		else
		{
			// Attempt to use HTTP_HOST and fallback to SERVER_NAME
			$domain = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : $_SERVER['SERVER_NAME'];
		}
		// Add the protocol and domain to the base URL
		$base_url = $protocol.'://'.$domain.$port.$base_url;
	}
	return $base_url;
}Merges the current GET parameters with an array of new or overloaded parameters and returns the resulting query string.
// Returns "?sort=title&limit=10" combined with any existing GET values
$query = URL::query(array('sort' => 'title', 'limit' => 10));
Typically you would use this when you are sorting query results, or something similar.
Parameters with a NULL value are left out.
array
$params
 = NULL - Array of GET parametersboolean
$use_get
 = bool TRUE - Include current request GET parametersstringpublic static function query(array $params = NULL, $use_get = TRUE)
{
	if ($use_get)
	{
		if ($params === NULL)
		{
			// Use only the current parameters
			$params = $_GET;
		}
		else
		{
			// Merge the current and new parameters
			$params = array_merge($_GET, $params);
		}
	}
	if (empty($params))
	{
		// No query parameters
		return '';
	}
	// Note: http_build_query returns an empty string for a params array with only NULL values
	$query = http_build_query($params, '', '&');
	// Don't prepend '?' to an empty string
	return ($query === '') ? '' : ('?'.$query);
}Fetches an absolute site URL based on a URI segment.
echo URL::site('foo/bar');
string
$uri
 = string(0) "" - Site URI to convertmixed
$protocol
 = NULL - Protocol string or [Request] class to use protocol fromboolean
$index
 = bool TRUE - Include the index_page in the URLstringpublic static function site($uri = '', $protocol = NULL, $index = TRUE)
{
	// Chop off possible scheme, host, port, user and pass parts
	$path = preg_replace('~^[-a-z0-9+.]++://[^/]++/?~', '', trim($uri, '/'));
	if ( ! UTF8::is_ascii($path))
	{
		// Encode all non-ASCII characters, as per RFC 1738
		$path = preg_replace('~([^/]+)~e', 'rawurlencode("$1")', $path);
	}
	// Concat the URL
	return URL::base($protocol, $index).$path;
}Convert a phrase to a URL-safe title.
echo URL::title('My Blog Post'); // "my-blog-post"
string
$title
required - Phrase to convertstring
$separator
 = string(1) "-" - Word separator (any single character)boolean
$ascii_only
 = bool FALSE - Transliterate to ASCII?stringpublic static function title($title, $separator = '-', $ascii_only = FALSE)
{
	if ($ascii_only === TRUE)
	{
		// Transliterate non-ASCII characters
		$title = UTF8::transliterate_to_ascii($title);
		// Remove all characters that are not the separator, a-z, 0-9, or whitespace
		$title = preg_replace('![^'.preg_quote($separator).'a-z0-9\s]+!', '', strtolower($title));
	}
	else
	{
		// Remove all characters that are not the separator, letters, numbers, or whitespace
		$title = preg_replace('![^'.preg_quote($separator).'\pL\pN\s]+!u', '', UTF8::strtolower($title));
	}
	// Replace all separator characters and whitespace by a single separator
	$title = preg_replace('!['.preg_quote($separator).'\s]+!u', $separator, $title);
	// Trim separators from the beginning and end
	return trim($title, $separator);
}