3 * Require the settings and DB files.
5 require_once 'classes/Response.class.php';
6 require_once 'classes/UploadException.class.php';
7 require_once 'classes/UploadedFile.class.php';
8 require_once 'includes/database.inc.php';
11 * Generates name and checks in DB
14 function generateName($file)
19 // We start at N retries, and --N until we give up
20 $tries = UGUU_FILES_RETRIES
;
21 $length = UGUU_FILES_LENGTH
;
23 $ext = pathinfo($file->name
, PATHINFO_EXTENSION
);
25 $finfo = finfo_open(FILEINFO_MIME_TYPE
);
26 $type_mime = finfo_file($finfo, $file->tempfile
);
29 // Check if extension is a double-dot extension and, if true, override $ext
30 $revname = strrev($file->name
);
31 foreach ($doubledots as $ddot) {
32 if (stripos($revname, $ddot) === 0) {
38 // Iterate until we reach the maximum number of retries
41 'Gave up trying to find an unused name',
43 ); // HTTP status code "500 Internal Server Error"
48 for ($i = 0; $i < $length; ++
$i) {
49 $name .= $chars[mt_rand(0, strlen($chars))];
52 // Add the extension to the file name
53 if (isset($ext) && $ext !== '') {
57 //Check if mime is blacklisted
58 if (in_array($type_mime, unserialize(CONFIG_BLOCKED_MIME
))) {
59 http_response_code(415);
60 throw new Exception('Filetype not allowed!');
64 //Check if EXT is blacklisted
65 if (in_array($ext, unserialize(CONFIG_BLOCKED_EXTENSIONS
))) {
66 http_response_code(415);
67 throw new Exception('Filetype not allowed!');
71 // Check if a file with the same name does already exist in the database
72 $q = $db->prepare('SELECT COUNT(filename) FROM files WHERE filename = (:name)');
73 $q->bindValue(':name', $name, PDO
::PARAM_STR
);
75 $result = $q->fetchColumn();
76 // If it does, generate a new name
77 } while ($result > 0);
83 * Handles the uploading and db entry for a file.
85 * @param UploadedFile $file
89 function uploadFile($file)
97 throw new UploadException($file->error
);
100 // Generate a name for the file
101 $newname = generateName($file);
103 // Store the file's full file path in memory
104 $uploadFile = UGUU_FILES_ROOT
.$newname;
106 // Attempt to move it to the static directory
107 if (!move_uploaded_file($file->tempfile
, $uploadFile)) {
108 http_response_code(500);
110 'Failed to move file to destination',
112 ); // HTTP status code "500 Internal Server Error"
115 // Need to change permissions for the new file to make it world readable
116 if (!chmod($uploadFile, 0644)) {
117 http_response_code(500);
119 'Failed to change file permissions',
121 ); // HTTP status code "500 Internal Server Error"
124 // Add it to the database
125 $q = $db->prepare('INSERT INTO files (hash, originalname, filename, size, date) VALUES (:hash, :orig, :name, :size, :date)');
127 // Common parameters binding
128 $q->bindValue(':hash', $file->getSha1(), PDO
::PARAM_STR
);
129 $q->bindValue(':orig', strip_tags($file->name
), PDO
::PARAM_STR
);
130 $q->bindValue(':name', $newname, PDO
::PARAM_STR
);
131 $q->bindValue(':size', $file->size
, PDO
::PARAM_INT
);
132 $q->bindValue(':date', time(), PDO
::PARAM_INT
);
136 'hash' => $file->getSha1(),
137 'name' => $file->name
,
138 'url' => UGUU_URL
.rawurlencode($newname),
139 'size' => $file->size
,
144 * Reorder files array by file.
148 function diverseArray($files)
152 foreach ($files as $key1 => $value1) {
153 foreach ($value1 as $key2 => $value2) {
154 $result[$key2][$key1] = $value2;
162 * Reorganize the $_FILES array into something saner.
166 function refiles($files)
169 $files = diverseArray($files);
171 foreach ($files as $file) {
172 $f = new UploadedFile();
173 $f->name
= $file['name'];
174 $f->mime
= $file['type'];
175 $f->size
= $file['size'];
176 $f->tempfile
= $file['tmp_name'];
177 $f->error
= $file['error'];
184 $type = isset($_GET['output']) ? $_GET['output'] : 'json';
185 $response = new Response($type);
187 if (isset($_FILES['files'])) {
188 $uploads = refiles($_FILES['files']);
191 foreach ($uploads as $upload) {
192 $res[] = uploadFile($upload);
194 $response->send($res);
195 } catch (Exception
$e) {
196 $response->error($e->getCode(), $e->getMessage());
199 $response->error(400, 'No input file(s)');