Issues (160)

src/rest.php (1 issue)

Labels
Severity
1
<?php
2
3
/**
4
 * Includes the side wide settings.
5
 */
6
require_once '../vendor/autoload.php';
7
8
header("Access-Control-Allow-Origin: *"); // enable CORS for the whole REST API
9
10
try {
11
    $model = new Model();
12
    $controller = new RestController($model);
13
    $request = new Request($model);
14
    $path = $request->getServerConstant('PATH_INFO') ? $request->getServerConstant('PATH_INFO') : ''; // eg. "/search"
15
    $parts = explode('/', $path);
0 ignored issues
show
It seems like $path can also be of type null; however, parameter $string of explode() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

15
    $parts = explode('/', /** @scrutinizer ignore-type */ $path);
Loading history...
16
    $request->setUri($request->getQueryParam('uri'));
17
    $request->setLang($request->getQueryParam('lang'));
18
    if ($request->getQueryParam('vocab')) {
19
        $request->setVocab($request->getQueryParam('vocab'));
20
    }
21
    if ($request->getQueryParam('clang')) {
22
        $request->setContentLang($request->getQueryParam('clang'));
23
    } elseif ($request->getQueryParam('lang')) {
24
        $request->setContentLang($request->getQueryParam('lang'));
25
    }
26
27
    if (sizeof($parts) < 2 || $parts[1] == "") {
28
        header("HTTP/1.0 404 Not Found");
29
        echo("404 Not Found");
30
    } elseif ($parts[1] == 'vocabularies') {
31
        $controller->vocabularies($request);
32
    } elseif ($parts[1] == 'search') {
33
        $controller->search($request);
34
    } elseif ($parts[1] == 'label') {
35
        $controller->label($request);
36
    } elseif ($parts[1] == 'types') {
37
        $controller->types($request);
38
    } elseif ($parts[1] == 'data') {
39
        $controller->data($request);
40
    } elseif (sizeof($parts) == 2) {
41
        header("Location: " . $parts[1] . "/");
42
    } else {
43
        $vocab = $parts[1];
44
        try {
45
            $request->setVocab($parts[1]);
46
        } catch (Exception | ValueError $e) {
47
            header("HTTP/1.0 404 Not Found");
48
            header("Content-type: text/plain; charset=utf-8");
49
            echo("404 Not Found : Vocabulary id '$parts[1]' not found.");
50
            return;
51
        }
52
        $lang = $request->getQueryParam('lang') ? $request->getQueryParam('lang') : $request->getVocab()->getConfig()->getDefaultLanguage();
53
        $request->setLang($lang);
54
        if ($parts[2] == '') {
55
            $controller->vocabularyInformation($request);
56
        } elseif ($parts[2] == 'types') {
57
            $controller->types($request);
58
        } elseif ($parts[2] == 'topConcepts') {
59
            $controller->topConcepts($request);
60
        } elseif ($parts[2] == 'data') {
61
            $controller->data($request);
62
        } elseif ($parts[2] == 'mappings') {
63
            $controller->mappings($request);
64
        } elseif ($parts[2] == 'search') {
65
            $controller->search($request);
66
        } elseif ($parts[2] == 'label') {
67
            $controller->label($request);
68
        } elseif ($parts[2] == 'lookup') {
69
            $controller->lookup($request);
70
        } elseif ($parts[2] == 'index' && sizeof($parts) == 4) {
71
            $letter = $parts[3];
72
            if ($letter == "") {
73
                $controller->indexLetters($request);
74
            } else {
75
                $controller->indexConcepts($letter, $request);
76
            }
77
        } elseif ($parts[2] == 'broader') {
78
            $controller->broader($request);
79
        } elseif ($parts[2] == 'broaderTransitive') {
80
            $controller->broaderTransitive($request);
81
        } elseif ($parts[2] == 'narrower') {
82
            $controller->narrower($request);
83
        } elseif ($parts[2] == 'narrowerTransitive') {
84
            $controller->narrowerTransitive($request);
85
        } elseif ($parts[2] == 'hierarchy') {
86
            $controller->hierarchy($request);
87
        } elseif ($parts[2] == 'children') {
88
            $controller->children($request);
89
        } elseif ($parts[2] == 'related') {
90
            $controller->related($request);
91
        } elseif ($parts[2] == 'vocabularyStatistics') {
92
            $controller->vocabularyStatistics($request);
93
        } elseif ($parts[2] == 'labelStatistics') {
94
            $controller->labelStatistics($request);
95
        } elseif ($parts[2] == 'groups') {
96
            $controller->groups($request);
97
        } elseif ($parts[2] == 'groupMembers') {
98
            $controller->groupMembers($request);
99
        } elseif ($parts[2] == 'new') {
100
            $controller->newConcepts($request);
101
        } elseif ($parts[2] == 'modified') {
102
            $controller->modifiedConcepts($request);
103
        } else {
104
            header("HTTP/1.0 404 Not Found");
105
            echo("404 Not Found");
106
        }
107
    }
108
} catch (Exception $e) {
109
    header("HTTP/1.0 500 Internal Server Error");
110
    echo('ERROR: ' . $e->getMessage());
111
}
112