1<?php
2
3namespace Psr\Http\Message;
4
5/**
6 * Value object representing a file uploaded through an HTTP request.
7 *
8 * Instances of this interface are considered immutable; all methods that
9 * might change state MUST be implemented such that they retain the internal
10 * state of the current instance and return an instance that contains the
11 * changed state.
12 */
13interface UploadedFileInterface
14{
15    /**
16     * Retrieve a stream representing the uploaded file.
17     *
18     * This method MUST return a StreamInterface instance, representing the
19     * uploaded file. The purpose of this method is to allow utilizing native PHP
20     * stream functionality to manipulate the file upload, such as
21     * stream_copy_to_stream() (though the result will need to be decorated in a
22     * native PHP stream wrapper to work with such functions).
23     *
24     * If the moveTo() method has been called previously, this method MUST raise
25     * an exception.
26     *
27     * @return StreamInterface Stream representation of the uploaded file.
28     * @throws \RuntimeException in cases when no stream is available or can be
29     *     created.
30     */
31    public function getStream(): StreamInterface;
32
33    /**
34     * Move the uploaded file to a new location.
35     *
36     * Use this method as an alternative to move_uploaded_file(). This method is
37     * guaranteed to work in both SAPI and non-SAPI environments.
38     * Implementations must determine which environment they are in, and use the
39     * appropriate method (move_uploaded_file(), rename(), or a stream
40     * operation) to perform the operation.
41     *
42     * $targetPath may be an absolute path, or a relative path. If it is a
43     * relative path, resolution should be the same as used by PHP's rename()
44     * function.
45     *
46     * The original file or stream MUST be removed on completion.
47     *
48     * If this method is called more than once, any subsequent calls MUST raise
49     * an exception.
50     *
51     * When used in an SAPI environment where $_FILES is populated, when writing
52     * files via moveTo(), is_uploaded_file() and move_uploaded_file() SHOULD be
53     * used to ensure permissions and upload status are verified correctly.
54     *
55     * If you wish to move to a stream, use getStream(), as SAPI operations
56     * cannot guarantee writing to stream destinations.
57     *
58     * @see http://php.net/is_uploaded_file
59     * @see http://php.net/move_uploaded_file
60     * @param string $targetPath Path to which to move the uploaded file.
61     * @throws \InvalidArgumentException if the $targetPath specified is invalid.
62     * @throws \RuntimeException on any error during the move operation, or on
63     *     the second or subsequent call to the method.
64     */
65    public function moveTo(string $targetPath): void;
66
67    /**
68     * Retrieve the file size.
69     *
70     * Implementations SHOULD return the value stored in the "size" key of
71     * the file in the $_FILES array if available, as PHP calculates this based
72     * on the actual size transmitted.
73     *
74     * @return int|null The file size in bytes or null if unknown.
75     */
76    public function getSize(): ?int;
77
78    /**
79     * Retrieve the error associated with the uploaded file.
80     *
81     * The return value MUST be one of PHP's UPLOAD_ERR_XXX constants.
82     *
83     * If the file was uploaded successfully, this method MUST return
84     * UPLOAD_ERR_OK.
85     *
86     * Implementations SHOULD return the value stored in the "error" key of
87     * the file in the $_FILES array.
88     *
89     * @see http://php.net/manual/en/features.file-upload.errors.php
90     * @return int One of PHP's UPLOAD_ERR_XXX constants.
91     */
92    public function getError(): int;
93
94    /**
95     * Retrieve the filename sent by the client.
96     *
97     * Do not trust the value returned by this method. A client could send
98     * a malicious filename with the intention to corrupt or hack your
99     * application.
100     *
101     * Implementations SHOULD return the value stored in the "name" key of
102     * the file in the $_FILES array.
103     *
104     * @return string|null The filename sent by the client or null if none
105     *     was provided.
106     */
107    public function getClientFilename(): ?string;
108
109    /**
110     * Retrieve the media type sent by the client.
111     *
112     * Do not trust the value returned by this method. A client could send
113     * a malicious media type with the intention to corrupt or hack your
114     * application.
115     *
116     * Implementations SHOULD return the value stored in the "type" key of
117     * the file in the $_FILES array.
118     *
119     * @return string|null The media type sent by the client or null if none
120     *     was provided.
121     */
122    public function getClientMediaType(): ?string;
123}
124