File: check-progress.php

package info (click to toggle)
php-uploadprogress 2.0.2%2B%2B-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 320 kB
  • sloc: ansic: 429; xml: 335; php: 45; makefile: 1
file content (73 lines) | stat: -rw-r--r-- 2,929 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<?php

/*
  +----------------------------------------------------------------------+
  | Uploadprogress extension                                             |
  +----------------------------------------------------------------------+
  | Copyright (c) The PHP Group                                          |
  +----------------------------------------------------------------------+
  | This source file is subject to version 3.01 of the PHP license,      |
  | that is bundled with this package in the file LICENSE, and is        |
  | available through the world-wide-web at the following url:           |
  | http://www.php.net/license/3_01.txt.                                 |
  | If you did not receive a copy of the PHP license and are unable to   |
  | obtain it through the world-wide-web, please send a note to          |
  | license@php.net so we can mail you a copy immediately.               |
  +----------------------------------------------------------------------+
  | Author: Ben Ramsey (ramsey@php.net)                                  |
  +----------------------------------------------------------------------+
*/

// If the client did not include an identifier in their request, then we cannot
// look up information about the upload, so we return a "not found" error. This
// is only for the sake of example and does not imply this is how your
// application should behave.
$identifier = filter_input(INPUT_GET, 'identifier', FILTER_SANITIZE_STRING);
$fieldName = filter_input(INPUT_GET, 'fieldName', FILTER_SANITIZE_STRING);

if ($identifier === null || $fieldName === null) {
    header('HTTP/1.1 404 Not Found');
    exit;
}

// Retrieve information about the file and the contents received so far.
// 4KB should be enough to read the MIME type of the file.
$info = uploadprogress_get_info($identifier);
$contents = uploadprogress_get_contents($identifier, $fieldName, 4096);

if (!$info || !$contents) {
    header('HTTP/1.1 500 Internal Server Error');
    header('Content-Type: application/json');

    $errors =[];

    if (!$info) {
        $errors[] = 'Received ' . var_export($info, true) . ' when calling uploadprogress_get_info()';
    }

    if (!$contents) {
        $errors[] = 'Received ' . var_export($contents, true) . ' when calling uploadprogress_get_contents()';
    }

    echo json_encode([
        'error' => 'An error occurred.',
        'messages' => $errors,
    ]);

    exit;
}

// Get the MIME type of the bytes uploaded, using the Fileinfo extension.
$finfo = new finfo(FILEINFO_MIME_TYPE);
$detectedMimeType = $finfo->buffer($contents);

$info = array_merge($info, [
    'detectedMimeType' => $detectedMimeType,
]);

// In our example, we respond with the uploadprogress information, as well as
// the detected MIME type from the initial bytes uploaded (if we can detect it).
header('HTTP/1.1 200 OK');
header('Content-Type: application/json');

echo json_encode($info);