phpOMS/Uri/UriInterface.php
2018-03-13 23:35:20 +01:00

218 lines
3.4 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.1
*
* @package phpOMS\Uri
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link http://website.orange-management.de
*/
declare(strict_types=1);
namespace phpOMS\Uri;
/**
* Uri interface.
*
* @package phpOMS\Uri
* @license OMS License 1.0
* @link http://website.orange-management.de
* @since 1.0.0
*/
interface UriInterface
{
/**
* Is uri valid?
*
* @param string $uri Uri string
*
* @return bool
*
* @since 1.0.0
*/
public static function isValid(string $uri) : bool;
/**
* Get scheme.
*
* @return string
*
* @since 1.0.0
*/
public function getScheme() : string;
/**
* Get authority.
*
* @return string
*
* @since 1.0.0
*/
public function getAuthority() : string;
/**
* Get user info.
*
* @return string
*
* @since 1.0.0
*/
public function getUserInfo() : string;
/**
* Get host.
*
* @return string
*
* @since 1.0.0
*/
public function getHost() : string;
/**
* Get port.
*
* @return int
*
* @since 1.0.0
*/
public function getPort() : int;
/**
* Get path.
*
* @return string
*
* @since 1.0.0
*/
public function getPath() : string;
/**
* Get user.
*
* @return string
*
* @since 1.0.0
*/
public function getUser() : string;
/**
* Get password.
*
* @return string
*
* @since 1.0.0
*/
public function getPass() : string;
/**
* Get root path.
*
* @return string
*
* @since 1.0.0
*/
public function getRootPath() : string;
/**
* Set root path.
*
* @param string $root Root path
*
* @return void
*
* @since 1.0.0
*/
public function setRootPath(string $root) : void;
/**
* Get path element.
*
* @param int $pos Position of the path
*
* @return string
*
* @since 1.0.0
*/
public function getPathElement(int $pos) : string;
/**
* Get path elements.
*
* @return array
*
* @since 1.0.0
*/
public function getPathElements() : array;
/**
* Get query.
*
* @param string $key Query key
*
* @return string
*
* @since 1.0.0
*/
public function getQuery(string $key = null) : string;
/**
* Get query array.
*
* @return array
*
* @since 1.0.0
*/
public function getQueryArray() : array;
/**
* Get fragment.
*
* @return string
*
* @since 1.0.0
*/
public function getFragment() : string;
/**
* Get uri.
*
* @return string
*
* @since 1.0.0
*/
public function __toString();
/**
* Get base uri.
*
* @return string
*
* @since 1.0.0
*/
public function getBase() : string;
/**
* Get route representation of uri.
*
* @return string
*
* @since 1.0.0
*/
public function getRoute() : string;
/**
* Set uri.
*
* @param string $uri Uri
*
* @return void
*
* @since 1.0.0
*/
public function set(string $uri) : void;
}