-
Notifications
You must be signed in to change notification settings - Fork 24
/
jsonrpc.php
60 lines (48 loc) · 1.86 KB
/
jsonrpc.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
<?php
/*
Open Media Collectors Database
Copyright (C) 2001,2013 by Jason Pell
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 2
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, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
// This must be first - includes config.php
require_once("./include/begin.inc.php");
include_once("./lib/JsonRpcServer.class.php");
// TODO - enable a plugin layer
include_once("./lib/jsonrpc/ItemSearch.class.php");
function request_http_basic_auth() {
header('WWW-Authenticate: Basic realm="' . htmlspecialchars(get_opendb_title()) . '"');
header('HTTP/1.0 401 Unauthorized');
}
if (is_site_enabled()) {
if (!isset($_SERVER['PHP_AUTH_USER'])) {
request_http_basic_auth();
} else {
$userId = $_SERVER['PHP_AUTH_USER'];
$password = $_SERVER['PHP_AUTH_PW'];
if (is_user_active($userId) && validate_user_passwd($userId, $password)) {
$server = new JsonRpcServer();
// TODO - currently no role based permissions are being performed for these services.
$server->registerClass(new ItemSearch());
$server->handle();
} else {
request_http_basic_auth();
}
}
} else {
header('HTTP/1.0 503 Service Unavailable');
echo "<h1>" . get_opendb_lang_var('site_is_disabled') . "</h1>";
echo get_opendb_lang_var('site_is_disabled');
}
// Cleanup after begin.inc.php
require_once("./include/end.inc.php");
?>