source: vendor/psr/http-message/src/UploadedFileInterface.php@ e3d4e0a

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

Upload project files

  • Property mode set to 100644
File size: 4.6 KB
Line 
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}
Note: See TracBrowser for help on using the repository browser.