PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / trunk
Matomo Analytics – Powerful, Privacy-First Insights for WordPress vtrunk
5.11.1 5.11.0 5.10.2 5.10.1 trunk 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.3.2 4.0.0 4.0.1 4.0.2 4.0.3 4.0.4 4.1.0 4.1.1 4.1.2 4.1.3 4.10.0 4.11.0 4.12.0 4.13.0 4.13.2 4.13.3 4.13.4 4.13.5 4.14.0 4.14.1 4.14.2 4.15.0 4.15.1 4.15.2 4.15.3 4.2.0 4.3.0 4.3.1 4.4.1 4.4.2 4.5.0 4.6.0 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.10.0 5.2.0 5.2.1 5.2.2 5.3.0 5.3.1 5.3.2 5.3.3 5.6.0 5.6.1 5.7.0 5.7.1 5.8.0 5.8.1 5.8.2
matomo / app / libs / HTML / QuickForm2 / Element / InputFile.php
matomo / app / libs / HTML / QuickForm2 / Element Last commit date
Button.php 2 years ago Date.php 2 years ago Input.php 2 years ago InputButton.php 2 years ago InputCheckable.php 2 years ago InputCheckbox.php 2 years ago InputFile.php 1 year ago InputHidden.php 2 years ago InputImage.php 2 years ago InputPassword.php 2 years ago InputRadio.php 2 years ago InputReset.php 2 years ago InputSubmit.php 2 years ago InputText.php 2 years ago Select.php 2 years ago Static.php 2 years ago Textarea.php 2 years ago
InputFile.php
228 lines
1 <?php
2
3 namespace {
4 /**
5 * Class for <input type="file" /> elements
6 *
7 * PHP version 5
8 *
9 * LICENSE:
10 *
11 * Copyright (c) 2006-2010, Alexey Borzov <avb@php.net>,
12 * Bertrand Mansion <golgote@mamasam.com>
13 * All rights reserved.
14 *
15 * Redistribution and use in source and binary forms, with or without
16 * modification, are permitted provided that the following conditions
17 * are met:
18 *
19 * * Redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer.
21 * * Redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution.
24 * * The names of the authors may not be used to endorse or promote products
25 * derived from this software without specific prior written permission.
26 *
27 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
28 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
29 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
30 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
31 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
32 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
33 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
34 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
35 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
36 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
37 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38 *
39 * @category HTML
40 * @package HTML_QuickForm2
41 * @author Alexey Borzov <avb@php.net>
42 * @author Bertrand Mansion <golgote@mamasam.com>
43 * @license http://opensource.org/licenses/bsd-license.php New BSD License
44 * @version SVN: $Id: InputFile.php 300722 2010-06-24 10:15:52Z mansion $
45 * @link http://pear.php.net/package/HTML_QuickForm2
46 */
47 /**
48 * Base class for <input> elements
49 */
50 // require_once 'HTML/QuickForm2/Element/Input.php';
51 /**
52 * Class for <input type="file" /> elements
53 *
54 * @category HTML
55 * @package HTML_QuickForm2
56 * @author Alexey Borzov <avb@php.net>
57 * @author Bertrand Mansion <golgote@mamasam.com>
58 * @version Release: @package_version@
59 */
60 class HTML_QuickForm2_Element_InputFile extends \HTML_QuickForm2_Element_Input
61 {
62 /**
63 * Default language for error messages
64 */
65 const DEFAULT_LANGUAGE = 'en';
66 /**
67 * Localized error messages for PHP's file upload errors
68 * @var array
69 */
70 protected $errorMessages = array('en' => array(\UPLOAD_ERR_INI_SIZE => 'The uploaded file exceeds size permitted by PHP configuration (%d bytes)', \UPLOAD_ERR_FORM_SIZE => 'The uploaded file exceeds the MAX_FILE_SIZE directive in HTML form (%d bytes)', \UPLOAD_ERR_PARTIAL => 'The file was only partially uploaded', \UPLOAD_ERR_NO_TMP_DIR => 'Server error: temporary directory is missing', \UPLOAD_ERR_CANT_WRITE => 'Server error: failed to write the file to disk', \UPLOAD_ERR_EXTENSION => 'File upload was stopped by extension'), 'fr' => array(\UPLOAD_ERR_INI_SIZE => 'Le fichier envoy&eacute; exc&egrave;de la taille autoris&eacute;e par la configuration de PHP (%d octets)', \UPLOAD_ERR_FORM_SIZE => 'Le fichier envoy&eacute; exc&egrave;de la taille de MAX_FILE_SIZE sp&eacute;cifi&eacute;e dans le formulaire HTML (%d octets)', \UPLOAD_ERR_PARTIAL => 'Le fichier n\'a &eacute;t&eacute; que partiellement t&eacute;l&eacute;charg&eacute;', \UPLOAD_ERR_NO_TMP_DIR => 'Erreur serveur: le r&eacute;pertoire temporaire est manquant', \UPLOAD_ERR_CANT_WRITE => 'Erreur serveur: &eacute;chec de l\'&eacute;criture du fichier sur le disque', \UPLOAD_ERR_EXTENSION => 'L\'envoi de fichier est arr&ecirc;t&eacute; par l\'extension'), 'ru' => array(\UPLOAD_ERR_INI_SIZE => '&#x420;&#x430;&#x437;&#x43c;&#x435;&#x440; &#x437;&#x430;&#x433;&#x440;&#x443;&#x436;&#x435;&#x43d;&#x43d;&#x43e;&#x433;&#x43e; &#x444;&#x430;&#x439;&#x43b;&#x430; &#x43f;&#x440;&#x435;&#x432;&#x43e;&#x441;&#x445;&#x43e;&#x434;&#x438;&#x442; &#x43c;&#x430;&#x43a;&#x441;&#x438;&#x43c;&#x430;&#x43b;&#x44c;&#x43d;&#x43e; &#x440;&#x430;&#x437;&#x440;&#x435;&#x448;&#x451;&#x43d;&#x43d;&#x44b;&#x439; &#x43d;&#x430;&#x441;&#x442;&#x440;&#x43e;&#x439;&#x43a;&#x430;&#x43c;&#x438; PHP (%d &#x431;&#x430;&#x439;&#x442;)', \UPLOAD_ERR_FORM_SIZE => '&#x420;&#x430;&#x437;&#x43c;&#x435;&#x440; &#x437;&#x430;&#x433;&#x440;&#x443;&#x436;&#x435;&#x43d;&#x43d;&#x43e;&#x433;&#x43e; &#x444;&#x430;&#x439;&#x43b;&#x430; &#x43f;&#x440;&#x435;&#x432;&#x43e;&#x441;&#x445;&#x43e;&#x434;&#x438;&#x442; &#x434;&#x438;&#x440;&#x435;&#x43a;&#x442;&#x438;&#x432;&#x443; MAX_FILE_SIZE, &#x443;&#x43a;&#x430;&#x437;&#x430;&#x43d;&#x43d;&#x443;&#x44e; &#x432; &#x444;&#x43e;&#x440;&#x43c;&#x435; (%d &#x431;&#x430;&#x439;&#x442;)', \UPLOAD_ERR_PARTIAL => '&#x424;&#x430;&#x439;&#x43b; &#x431;&#x44b;&#x43b; &#x437;&#x430;&#x433;&#x440;&#x443;&#x436;&#x435;&#x43d; &#x43d;&#x435; &#x43f;&#x43e;&#x43b;&#x43d;&#x43e;&#x441;&#x442;&#x44c;&#x44e;', \UPLOAD_ERR_NO_TMP_DIR => '&#x41e;&#x448;&#x438;&#x431;&#x43a;&#x430; &#x43d;&#x430; &#x441;&#x435;&#x440;&#x432;&#x435;&#x440;&#x435;: &#x43e;&#x442;&#x441;&#x443;&#x442;&#x441;&#x442;&#x432;&#x443;&#x435;&#x442; &#x43a;&#x430;&#x442;&#x430;&#x43b;&#x43e;&#x433; &#x434;&#x43b;&#x44f; &#x432;&#x440;&#x435;&#x43c;&#x435;&#x43d;&#x43d;&#x44b;&#x445; &#x444;&#x430;&#x439;&#x43b;&#x43e;&#x432;', \UPLOAD_ERR_CANT_WRITE => '&#x41e;&#x448;&#x438;&#x431;&#x43a;&#x430; &#x43d;&#x430; &#x441;&#x435;&#x440;&#x432;&#x435;&#x440;&#x435;: &#x43d;&#x435; &#x443;&#x434;&#x430;&#x43b;&#x43e;&#x441;&#x44c; &#x437;&#x430;&#x43f;&#x438;&#x441;&#x430;&#x442;&#x44c; &#x444;&#x430;&#x439;&#x43b; &#x43d;&#x430; &#x434;&#x438;&#x441;&#x43a;', \UPLOAD_ERR_EXTENSION => '&#x417;&#x430;&#x433;&#x440;&#x443;&#x437;&#x43a;&#x430; &#x444;&#x430;&#x439;&#x43b;&#x430; &#x431;&#x44b;&#x43b;&#x430; &#x43e;&#x441;&#x442;&#x430;&#x43d;&#x43e;&#x432;&#x43b;&#x435;&#x43d;&#x430; &#x440;&#x430;&#x441;&#x448;&#x438;&#x440;&#x435;&#x43d;&#x438;&#x435;&#x43c;'));
71 /**
72 * Language to display error messages in
73 * @var string
74 */
75 protected $language;
76 /**
77 * Information on uploaded file, from submit data source
78 * @var array
79 */
80 protected $value = null;
81 protected $attributes = array('type' => 'file');
82 /**
83 * Class constructor
84 *
85 * Possible keys in $data array are:
86 * - 'language': language to display error messages in, it should either be
87 * already available in the class or provided in 'errorMessages'
88 * - 'errorMessages': an array of error messages with the following format
89 * <pre>
90 * 'language code 1' => array(
91 * UPLOAD_ERR_... => 'message',
92 * ...
93 * UPLOAD_ERR_... => 'message'
94 * ),
95 * ...
96 * 'language code N' => array(
97 * ...
98 * )
99 * </pre>
100 * Note that error messages for UPLOAD_ERR_INI_SIZE and UPLOAD_ERR_FORM_SIZE
101 * may contain '%d' placeholders that will be automatically replaced by the
102 * appropriate size limits. Note also that you don't need to provide messages
103 * for every possible error code in the arrays, you may e.g. override just
104 * one error message for a particular language.
105 *
106 * @param string Element name
107 * @param mixed Attributes (either a string or an array)
108 * @param array Data used to set up error messages for PHP's file
109 * upload errors.
110 */
111 public function __construct($name = null, $attributes = null, array $data = array())
112 {
113 if (isset($data['errorMessages'])) {
114 // neither array_merge() nor array_merge_recursive will do
115 foreach ($data['errorMessages'] as $lang => $ary) {
116 foreach ($ary as $code => $message) {
117 $this->errorMessages[$lang][$code] = $message;
118 }
119 }
120 unset($data['errorMessages']);
121 }
122 if (!isset($data['language'])) {
123 $this->language = self::DEFAULT_LANGUAGE;
124 } else {
125 $this->language = isset($this->errorMessages[$data['language']]) ? $data['language'] : self::DEFAULT_LANGUAGE;
126 unset($data['language']);
127 }
128 parent::__construct($name, $attributes, $data);
129 }
130 /**
131 * File upload elements cannot be frozen
132 *
133 * To properly "freeze" a file upload element one has to store the uploaded
134 * file somewhere and store the file info in session. This is way outside
135 * the scope of this class.
136 *
137 * @param bool Whether element should be frozen or editable. This
138 * parameter is ignored in case of file uploads
139 * @return bool Always returns false
140 */
141 public function toggleFrozen($freeze = null)
142 {
143 return \false;
144 }
145 /**
146 * Returns the information on uploaded file
147 *
148 * @return array|null
149 */
150 public function getValue()
151 {
152 return $this->value;
153 }
154 /**
155 * File upload's value cannot be set here
156 *
157 * @param mixed Value for file element, this parameter is ignored
158 * @return HTML_QuickForm2_Element_InputFile
159 */
160 public function setValue($value)
161 {
162 return $this;
163 }
164 public function updateValue()
165 {
166 foreach ($this->getDataSources() as $ds) {
167 if ($ds instanceof \HTML_QuickForm2_DataSource_Submit) {
168 $value = $ds->getUpload($this->getName());
169 if (null !== $value) {
170 $this->value = $value;
171 return;
172 }
173 }
174 }
175 $this->value = null;
176 }
177 /**
178 * Performs the server-side validation
179 *
180 * Before the Rules added to the element kick in, the element checks the
181 * error code added to the $_FILES array by PHP. If the code isn't
182 * UPLOAD_ERR_OK or UPLOAD_ERR_NO_FILE then a built-in error message will be
183 * displayed and no further validation will take place.
184 *
185 * @return boolean Whether the element is valid
186 */
187 protected function validate()
188 {
189 if (\strlen($this->error ?? '')) {
190 return \false;
191 }
192 if (isset($this->value['error']) && !\in_array($this->value['error'], array(\UPLOAD_ERR_OK, \UPLOAD_ERR_NO_FILE))) {
193 if (isset($this->errorMessages[$this->language][$this->value['error']])) {
194 $errorMessage = $this->errorMessages[$this->language][$this->value['error']];
195 } else {
196 $errorMessage = $this->errorMessages[self::DEFAULT_LANGUAGE][$this->value['error']];
197 }
198 if (\UPLOAD_ERR_INI_SIZE == $this->value['error']) {
199 $iniSize = \ini_get('upload_max_filesize');
200 $size = \intval($iniSize);
201 switch (\strtoupper(\substr($iniSize, -1))) {
202 case 'G':
203 $size *= 1024;
204 case 'M':
205 $size *= 1024;
206 case 'K':
207 $size *= 1024;
208 }
209 } elseif (\UPLOAD_ERR_FORM_SIZE == $this->value['error']) {
210 foreach ($this->getDataSources() as $ds) {
211 if ($ds instanceof \HTML_QuickForm2_DataSource_Submit) {
212 $size = \intval($ds->getValue('MAX_FILE_SIZE'));
213 break;
214 }
215 }
216 }
217 $this->error = isset($size) ? \sprintf($errorMessage, $size) : $errorMessage;
218 return \false;
219 }
220 return parent::validate();
221 }
222 public function addFilter($callback, ?array $options = null, $recursive = \true)
223 {
224 throw new \HTML_QuickForm2_Exception('InputFile elements do not support filters');
225 }
226 }
227 }
228