-
Notifications
You must be signed in to change notification settings - Fork 2
/
index.php
63 lines (54 loc) · 1.97 KB
/
index.php
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
<?php
/*
* Copyright (C) 2013 payutc <[email protected]>
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
require("users.php");
// Parse l'url
$path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
$actions = explode('/', $path);
// On cherche index.php et on ne garde que ce qu'il y a après
$first = array_search("index.php", $actions) + 1;
$actions = array_slice($actions, $first);
if($actions[0] != "v1"){
die("Version non supportée");
}
if(empty($_GET["key"]) || $_GET["key"] != "fauxginger"){
die("Clé invalide (la clé est 'fauxginger')");
}
if(empty($actions[1])){
die("Pas d'action");
}
if($actions[1] == "find"){
die("Action non implémentée");
}
if($actions[1] == "badge" && !empty($actions[2])){
$user = Users::getByBadge($actions[2]);
echo $user ? json_encode($user) : null;
} else if($actions[1] == "mail" && !empty($actions[2])){
$user = Users::getByEmail($actions[2]);
echo $user ? json_encode($user) : null;
} else if(!empty($actions[1])){
if(!empty($actions[2]) && $actions[2] == "cotisations"){
$cotisations = Cotisations::getByUser($actions[1]);
echo $cotisations ? json_encode($cotisations) : null;
}
else if(empty($actions[2])){
$user = Users::getByLogin($actions[1]);
echo $user ? json_encode($user) : null;
}
}
if(!isset($user) && !isset($cotisations)){
header("HTTP/1.0 404 Not Found");
}