1<?php 2 3namespace Psr\Http\Message; 4 5/** 6 * Representation of an incoming, server-side HTTP request. 7 * 8 * Per the HTTP specification, this interface includes properties for 9 * each of the following: 10 * 11 * - Protocol version 12 * - HTTP method 13 * - URI 14 * - Headers 15 * - Message body 16 * 17 * Additionally, it encapsulates all data as it has arrived to the 18 * application from the CGI and/or PHP environment, including: 19 * 20 * - The values represented in $_SERVER. 21 * - Any cookies provided (generally via $_COOKIE) 22 * - Query string arguments (generally via $_GET, or as parsed via parse_str()) 23 * - Upload files, if any (as represented by $_FILES) 24 * - Deserialized body parameters (generally from $_POST) 25 * 26 * $_SERVER values MUST be treated as immutable, as they represent application 27 * state at the time of request; as such, no methods are provided to allow 28 * modification of those values. The other values provide such methods, as they 29 * can be restored from $_SERVER or the request body, and may need treatment 30 * during the application (e.g., body parameters may be deserialized based on 31 * content type). 32 * 33 * Additionally, this interface recognizes the utility of introspecting a 34 * request to derive and match additional parameters (e.g., via URI path 35 * matching, decrypting cookie values, deserializing non-form-encoded body 36 * content, matching authorization headers to users, etc). These parameters 37 * are stored in an "attributes" property. 38 * 39 * Requests are considered immutable; all methods that might change state MUST 40 * be implemented such that they retain the internal state of the current 41 * message and return an instance that contains the changed state. 42 */ 43interface ServerRequestInterface extends RequestInterface 44{ 45 /** 46 * Retrieve server parameters. 47 * 48 * Retrieves data related to the incoming request environment, 49 * typically derived from PHP's $_SERVER superglobal. The data IS NOT 50 * REQUIRED to originate from $_SERVER. 51 * 52 * @return array 53 */ 54 public function getServerParams(): array; 55 56 /** 57 * Retrieve cookies. 58 * 59 * Retrieves cookies sent by the client to the server. 60 * 61 * The data MUST be compatible with the structure of the $_COOKIE 62 * superglobal. 63 * 64 * @return array 65 */ 66 public function getCookieParams(): array; 67 68 /** 69 * Return an instance with the specified cookies. 70 * 71 * The data IS NOT REQUIRED to come from the $_COOKIE superglobal, but MUST 72 * be compatible with the structure of $_COOKIE. Typically, this data will 73 * be injected at instantiation. 74 * 75 * This method MUST NOT update the related Cookie header of the request 76 * instance, nor related values in the server params. 77 * 78 * This method MUST be implemented in such a way as to retain the 79 * immutability of the message, and MUST return an instance that has the 80 * updated cookie values. 81 * 82 * @param array $cookies Array of key/value pairs representing cookies. 83 * @return static 84 */ 85 public function withCookieParams(array $cookies): ServerRequestInterface; 86 87 /** 88 * Retrieve query string arguments. 89 * 90 * Retrieves the deserialized query string arguments, if any. 91 * 92 * Note: the query params might not be in sync with the URI or server 93 * params. If you need to ensure you are only getting the original 94 * values, you may need to parse the query string from `getUri()->getQuery()` 95 * or from the `QUERY_STRING` server param. 96 * 97 * @return array 98 */ 99 public function getQueryParams(): array; 100 101 /** 102 * Return an instance with the specified query string arguments. 103 * 104 * These values SHOULD remain immutable over the course of the incoming 105 * request. They MAY be injected during instantiation, such as from PHP's 106 * $_GET superglobal, or MAY be derived from some other value such as the 107 * URI. In cases where the arguments are parsed from the URI, the data 108 * MUST be compatible with what PHP's parse_str() would return for 109 * purposes of how duplicate query parameters are handled, and how nested 110 * sets are handled. 111 * 112 * Setting query string arguments MUST NOT change the URI stored by the 113 * request, nor the values in the server params. 114 * 115 * This method MUST be implemented in such a way as to retain the 116 * immutability of the message, and MUST return an instance that has the 117 * updated query string arguments. 118 * 119 * @param array $query Array of query string arguments, typically from 120 * $_GET. 121 * @return static 122 */ 123 public function withQueryParams(array $query): ServerRequestInterface; 124 125 /** 126 * Retrieve normalized file upload data. 127 * 128 * This method returns upload metadata in a normalized tree, with each leaf 129 * an instance of Psr\Http\Message\UploadedFileInterface. 130 * 131 * These values MAY be prepared from $_FILES or the message body during 132 * instantiation, or MAY be injected via withUploadedFiles(). 133 * 134 * @return array An array tree of UploadedFileInterface instances; an empty 135 * array MUST be returned if no data is present. 136 */ 137 public function getUploadedFiles(): array; 138 139 /** 140 * Create a new instance with the specified uploaded files. 141 * 142 * This method MUST be implemented in such a way as to retain the 143 * immutability of the message, and MUST return an instance that has the 144 * updated body parameters. 145 * 146 * @param array $uploadedFiles An array tree of UploadedFileInterface instances. 147 * @return static 148 * @throws \InvalidArgumentException if an invalid structure is provided. 149 */ 150 public function withUploadedFiles(array $uploadedFiles): ServerRequestInterface; 151 152 /** 153 * Retrieve any parameters provided in the request body. 154 * 155 * If the request Content-Type is either application/x-www-form-urlencoded 156 * or multipart/form-data, and the request method is POST, this method MUST 157 * return the contents of $_POST. 158 * 159 * Otherwise, this method may return any results of deserializing 160 * the request body content; as parsing returns structured content, the 161 * potential types MUST be arrays or objects only. A null value indicates 162 * the absence of body content. 163 * 164 * @return null|array|object The deserialized body parameters, if any. 165 * These will typically be an array or object. 166 */ 167 public function getParsedBody(); 168 169 /** 170 * Return an instance with the specified body parameters. 171 * 172 * These MAY be injected during instantiation. 173 * 174 * If the request Content-Type is either application/x-www-form-urlencoded 175 * or multipart/form-data, and the request method is POST, use this method 176 * ONLY to inject the contents of $_POST. 177 * 178 * The data IS NOT REQUIRED to come from $_POST, but MUST be the results of 179 * deserializing the request body content. Deserialization/parsing returns 180 * structured data, and, as such, this method ONLY accepts arrays or objects, 181 * or a null value if nothing was available to parse. 182 * 183 * As an example, if content negotiation determines that the request data 184 * is a JSON payload, this method could be used to create a request 185 * instance with the deserialized parameters. 186 * 187 * This method MUST be implemented in such a way as to retain the 188 * immutability of the message, and MUST return an instance that has the 189 * updated body parameters. 190 * 191 * @param null|array|object $data The deserialized body data. This will 192 * typically be in an array or object. 193 * @return static 194 * @throws \InvalidArgumentException if an unsupported argument type is 195 * provided. 196 */ 197 public function withParsedBody($data): ServerRequestInterface; 198 199 /** 200 * Retrieve attributes derived from the request. 201 * 202 * The request "attributes" may be used to allow injection of any 203 * parameters derived from the request: e.g., the results of path 204 * match operations; the results of decrypting cookies; the results of 205 * deserializing non-form-encoded message bodies; etc. Attributes 206 * will be application and request specific, and CAN be mutable. 207 * 208 * @return array Attributes derived from the request. 209 */ 210 public function getAttributes(): array; 211 212 /** 213 * Retrieve a single derived request attribute. 214 * 215 * Retrieves a single derived request attribute as described in 216 * getAttributes(). If the attribute has not been previously set, returns 217 * the default value as provided. 218 * 219 * This method obviates the need for a hasAttribute() method, as it allows 220 * specifying a default value to return if the attribute is not found. 221 * 222 * @see getAttributes() 223 * @param string $name The attribute name. 224 * @param mixed $default Default value to return if the attribute does not exist. 225 * @return mixed 226 */ 227 public function getAttribute(string $name, $default = null); 228 229 /** 230 * Return an instance with the specified derived request attribute. 231 * 232 * This method allows setting a single derived request attribute as 233 * described in getAttributes(). 234 * 235 * This method MUST be implemented in such a way as to retain the 236 * immutability of the message, and MUST return an instance that has the 237 * updated attribute. 238 * 239 * @see getAttributes() 240 * @param string $name The attribute name. 241 * @param mixed $value The value of the attribute. 242 * @return static 243 */ 244 public function withAttribute(string $name, $value): ServerRequestInterface; 245 246 /** 247 * Return an instance that removes the specified derived request attribute. 248 * 249 * This method allows removing a single derived request attribute as 250 * described in getAttributes(). 251 * 252 * This method MUST be implemented in such a way as to retain the 253 * immutability of the message, and MUST return an instance that removes 254 * the attribute. 255 * 256 * @see getAttributes() 257 * @param string $name The attribute name. 258 * @return static 259 */ 260 public function withoutAttribute(string $name): ServerRequestInterface; 261} 262