source: vendor/psr/http-message/src/UriInterface.php

Last change on this file was e3d4e0a, checked in by Vlado 222039 <vlado.popovski@…>, 7 days ago

Upload project files

  • Property mode set to 100644
File size: 12.5 KB
Line 
1<?php
2
3namespace Psr\Http\Message;
4
5/**
6 * Value object representing a URI.
7 *
8 * This interface is meant to represent URIs according to RFC 3986 and to
9 * provide methods for most common operations. Additional functionality for
10 * working with URIs can be provided on top of the interface or externally.
11 * Its primary use is for HTTP requests, but may also be used in other
12 * contexts.
13 *
14 * Instances of this interface are considered immutable; all methods that
15 * might change state MUST be implemented such that they retain the internal
16 * state of the current instance and return an instance that contains the
17 * changed state.
18 *
19 * Typically the Host header will be also be present in the request message.
20 * For server-side requests, the scheme will typically be discoverable in the
21 * server parameters.
22 *
23 * @link http://tools.ietf.org/html/rfc3986 (the URI specification)
24 */
25interface UriInterface
26{
27 /**
28 * Retrieve the scheme component of the URI.
29 *
30 * If no scheme is present, this method MUST return an empty string.
31 *
32 * The value returned MUST be normalized to lowercase, per RFC 3986
33 * Section 3.1.
34 *
35 * The trailing ":" character is not part of the scheme and MUST NOT be
36 * added.
37 *
38 * @see https://tools.ietf.org/html/rfc3986#section-3.1
39 * @return string The URI scheme.
40 */
41 public function getScheme(): string;
42
43 /**
44 * Retrieve the authority component of the URI.
45 *
46 * If no authority information is present, this method MUST return an empty
47 * string.
48 *
49 * The authority syntax of the URI is:
50 *
51 * <pre>
52 * [user-info@]host[:port]
53 * </pre>
54 *
55 * If the port component is not set or is the standard port for the current
56 * scheme, it SHOULD NOT be included.
57 *
58 * @see https://tools.ietf.org/html/rfc3986#section-3.2
59 * @return string The URI authority, in "[user-info@]host[:port]" format.
60 */
61 public function getAuthority(): string;
62
63 /**
64 * Retrieve the user information component of the URI.
65 *
66 * If no user information is present, this method MUST return an empty
67 * string.
68 *
69 * If a user is present in the URI, this will return that value;
70 * additionally, if the password is also present, it will be appended to the
71 * user value, with a colon (":") separating the values.
72 *
73 * The trailing "@" character is not part of the user information and MUST
74 * NOT be added.
75 *
76 * @return string The URI user information, in "username[:password]" format.
77 */
78 public function getUserInfo(): string;
79
80 /**
81 * Retrieve the host component of the URI.
82 *
83 * If no host is present, this method MUST return an empty string.
84 *
85 * The value returned MUST be normalized to lowercase, per RFC 3986
86 * Section 3.2.2.
87 *
88 * @see http://tools.ietf.org/html/rfc3986#section-3.2.2
89 * @return string The URI host.
90 */
91 public function getHost(): string;
92
93 /**
94 * Retrieve the port component of the URI.
95 *
96 * If a port is present, and it is non-standard for the current scheme,
97 * this method MUST return it as an integer. If the port is the standard port
98 * used with the current scheme, this method SHOULD return null.
99 *
100 * If no port is present, and no scheme is present, this method MUST return
101 * a null value.
102 *
103 * If no port is present, but a scheme is present, this method MAY return
104 * the standard port for that scheme, but SHOULD return null.
105 *
106 * @return null|int The URI port.
107 */
108 public function getPort(): ?int;
109
110 /**
111 * Retrieve the path component of the URI.
112 *
113 * The path can either be empty or absolute (starting with a slash) or
114 * rootless (not starting with a slash). Implementations MUST support all
115 * three syntaxes.
116 *
117 * Normally, the empty path "" and absolute path "/" are considered equal as
118 * defined in RFC 7230 Section 2.7.3. But this method MUST NOT automatically
119 * do this normalization because in contexts with a trimmed base path, e.g.
120 * the front controller, this difference becomes significant. It's the task
121 * of the user to handle both "" and "/".
122 *
123 * The value returned MUST be percent-encoded, but MUST NOT double-encode
124 * any characters. To determine what characters to encode, please refer to
125 * RFC 3986, Sections 2 and 3.3.
126 *
127 * As an example, if the value should include a slash ("/") not intended as
128 * delimiter between path segments, that value MUST be passed in encoded
129 * form (e.g., "%2F") to the instance.
130 *
131 * @see https://tools.ietf.org/html/rfc3986#section-2
132 * @see https://tools.ietf.org/html/rfc3986#section-3.3
133 * @return string The URI path.
134 */
135 public function getPath(): string;
136
137 /**
138 * Retrieve the query string of the URI.
139 *
140 * If no query string is present, this method MUST return an empty string.
141 *
142 * The leading "?" character is not part of the query and MUST NOT be
143 * added.
144 *
145 * The value returned MUST be percent-encoded, but MUST NOT double-encode
146 * any characters. To determine what characters to encode, please refer to
147 * RFC 3986, Sections 2 and 3.4.
148 *
149 * As an example, if a value in a key/value pair of the query string should
150 * include an ampersand ("&") not intended as a delimiter between values,
151 * that value MUST be passed in encoded form (e.g., "%26") to the instance.
152 *
153 * @see https://tools.ietf.org/html/rfc3986#section-2
154 * @see https://tools.ietf.org/html/rfc3986#section-3.4
155 * @return string The URI query string.
156 */
157 public function getQuery(): string;
158
159 /**
160 * Retrieve the fragment component of the URI.
161 *
162 * If no fragment is present, this method MUST return an empty string.
163 *
164 * The leading "#" character is not part of the fragment and MUST NOT be
165 * added.
166 *
167 * The value returned MUST be percent-encoded, but MUST NOT double-encode
168 * any characters. To determine what characters to encode, please refer to
169 * RFC 3986, Sections 2 and 3.5.
170 *
171 * @see https://tools.ietf.org/html/rfc3986#section-2
172 * @see https://tools.ietf.org/html/rfc3986#section-3.5
173 * @return string The URI fragment.
174 */
175 public function getFragment(): string;
176
177 /**
178 * Return an instance with the specified scheme.
179 *
180 * This method MUST retain the state of the current instance, and return
181 * an instance that contains the specified scheme.
182 *
183 * Implementations MUST support the schemes "http" and "https" case
184 * insensitively, and MAY accommodate other schemes if required.
185 *
186 * An empty scheme is equivalent to removing the scheme.
187 *
188 * @param string $scheme The scheme to use with the new instance.
189 * @return static A new instance with the specified scheme.
190 * @throws \InvalidArgumentException for invalid or unsupported schemes.
191 */
192 public function withScheme(string $scheme): UriInterface;
193
194 /**
195 * Return an instance with the specified user information.
196 *
197 * This method MUST retain the state of the current instance, and return
198 * an instance that contains the specified user information.
199 *
200 * Password is optional, but the user information MUST include the
201 * user; an empty string for the user is equivalent to removing user
202 * information.
203 *
204 * @param string $user The user name to use for authority.
205 * @param null|string $password The password associated with $user.
206 * @return static A new instance with the specified user information.
207 */
208 public function withUserInfo(string $user, ?string $password = null): UriInterface;
209
210 /**
211 * Return an instance with the specified host.
212 *
213 * This method MUST retain the state of the current instance, and return
214 * an instance that contains the specified host.
215 *
216 * An empty host value is equivalent to removing the host.
217 *
218 * @param string $host The hostname to use with the new instance.
219 * @return static A new instance with the specified host.
220 * @throws \InvalidArgumentException for invalid hostnames.
221 */
222 public function withHost(string $host): UriInterface;
223
224 /**
225 * Return an instance with the specified port.
226 *
227 * This method MUST retain the state of the current instance, and return
228 * an instance that contains the specified port.
229 *
230 * Implementations MUST raise an exception for ports outside the
231 * established TCP and UDP port ranges.
232 *
233 * A null value provided for the port is equivalent to removing the port
234 * information.
235 *
236 * @param null|int $port The port to use with the new instance; a null value
237 * removes the port information.
238 * @return static A new instance with the specified port.
239 * @throws \InvalidArgumentException for invalid ports.
240 */
241 public function withPort(?int $port): UriInterface;
242
243 /**
244 * Return an instance with the specified path.
245 *
246 * This method MUST retain the state of the current instance, and return
247 * an instance that contains the specified path.
248 *
249 * The path can either be empty or absolute (starting with a slash) or
250 * rootless (not starting with a slash). Implementations MUST support all
251 * three syntaxes.
252 *
253 * If the path is intended to be domain-relative rather than path relative then
254 * it must begin with a slash ("/"). Paths not starting with a slash ("/")
255 * are assumed to be relative to some base path known to the application or
256 * consumer.
257 *
258 * Users can provide both encoded and decoded path characters.
259 * Implementations ensure the correct encoding as outlined in getPath().
260 *
261 * @param string $path The path to use with the new instance.
262 * @return static A new instance with the specified path.
263 * @throws \InvalidArgumentException for invalid paths.
264 */
265 public function withPath(string $path): UriInterface;
266
267 /**
268 * Return an instance with the specified query string.
269 *
270 * This method MUST retain the state of the current instance, and return
271 * an instance that contains the specified query string.
272 *
273 * Users can provide both encoded and decoded query characters.
274 * Implementations ensure the correct encoding as outlined in getQuery().
275 *
276 * An empty query string value is equivalent to removing the query string.
277 *
278 * @param string $query The query string to use with the new instance.
279 * @return static A new instance with the specified query string.
280 * @throws \InvalidArgumentException for invalid query strings.
281 */
282 public function withQuery(string $query): UriInterface;
283
284 /**
285 * Return an instance with the specified URI fragment.
286 *
287 * This method MUST retain the state of the current instance, and return
288 * an instance that contains the specified URI fragment.
289 *
290 * Users can provide both encoded and decoded fragment characters.
291 * Implementations ensure the correct encoding as outlined in getFragment().
292 *
293 * An empty fragment value is equivalent to removing the fragment.
294 *
295 * @param string $fragment The fragment to use with the new instance.
296 * @return static A new instance with the specified fragment.
297 */
298 public function withFragment(string $fragment): UriInterface;
299
300 /**
301 * Return the string representation as a URI reference.
302 *
303 * Depending on which components of the URI are present, the resulting
304 * string is either a full URI or relative reference according to RFC 3986,
305 * Section 4.1. The method concatenates the various components of the URI,
306 * using the appropriate delimiters:
307 *
308 * - If a scheme is present, it MUST be suffixed by ":".
309 * - If an authority is present, it MUST be prefixed by "//".
310 * - The path can be concatenated without delimiters. But there are two
311 * cases where the path has to be adjusted to make the URI reference
312 * valid as PHP does not allow to throw an exception in __toString():
313 * - If the path is rootless and an authority is present, the path MUST
314 * be prefixed by "/".
315 * - If the path is starting with more than one "/" and no authority is
316 * present, the starting slashes MUST be reduced to one.
317 * - If a query is present, it MUST be prefixed by "?".
318 * - If a fragment is present, it MUST be prefixed by "#".
319 *
320 * @see http://tools.ietf.org/html/rfc3986#section-4.1
321 * @return string
322 */
323 public function __toString(): string;
324}
Note: See TracBrowser for help on using the repository browser.