forked from kestasjk/webDiplomacy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfp-webhook.php
77 lines (62 loc) · 3.05 KB
/
fp-webhook.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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
/*
Copyright (C) 2004-2022 Kestas J. Kuliukas
This file is part of webDiplomacy.
webDiplomacy is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
webDiplomacy 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 Affero General Public License
along with webDiplomacy. If not, see <http://www.gnu.org/licenses/>.
*/
define('IN_CODE', 1);
/**
* @package Base
*/
require_once('config.php');
require_once('header.php');
require_once('global/definitions.php');
require_once('objects/database.php');
if( !isset(Config::$fingerPrintWebHookUsername) || Config::$fingerPrintWebHookUsername == null ||
!isset(Config::$fingerPrintWebHookPassword) || Config::$fingerPrintWebHookPassword == null )
{
die('Fingerprinting web hook not configured');
}
require_once('header.php');
require_once('global/definitions.php');
require_once('objects/database.php');
if (!isset($_SERVER['PHP_AUTH_USER']))
{
header('WWW-Authenticate: Basic realm="webDiplomacy"');
header('HTTP/1.0 401 Unauthorized');
die('Not authorized');
}
if( $_SERVER['PHP_AUTH_USER'] !== Config::$fingerPrintWebHookUsername || $_SERVER['PHP_AUTH_PW'] !== Config::$fingerPrintWebHookPassword )
{
header('WWW-Authenticate: Basic realm="webDiplomacy"');
header('HTTP/1.0 401 Unauthorized');
die('Bad credentials');
}
$json_data = json_decode(file_get_contents("php://input"), true);
$requestId = isset($json_data['requestId']) ? $json_data['requestId'] : '';
$visitorId = isset($json_data['visitorId']) ? $json_data['visitorId'] : '';
$visitorFound = isset($json_data['visitorFound']) ? $json_data['visitorFound'] : '';
$incognito = isset($json_data['incognito']) ? $json_data['incognito'] : '';
if( isset($json_data['ipLocation']) )
{
$accuracyRadius = isset($json_data['ipLocation']['accuracyRadius']) ? $json_data['ipLocation']['accuracyRadius'] : 0;
$latitude = isset($json_data['ipLocation']['latitude']) ? $json_data['ipLocation']['latitude'] : 0;
$longitude = isset($json_data['ipLocation']['longitude']) ? $json_data['ipLocation']['longitude'] : 0;
}
$linkedId = isset($json_data['linkedId']) ? $json_data['linkedId'] : -1;
if( isset($json_data['confidence']) )
{
$confidence = isset($json_data['confidence']['score']) ? $json_data['confidence']['score'] : -1;
}
$DB->sql_put("INSERT INTO wD_FingerprintProRequests (requestId, visitorId, linkedId, confidence, visitorFound, incognito, latitude, longitude, accuracyRadius) VALUES ".
"('" . $requestId . "', '" . $visitorId . "', '" . $linkedId . "', '" . $confidence . "', '" . $visitorFound . "', '" . $incognito . "', '" . $latitude . "', '" . $longitude . "', '" . $accuracyRadius . "')");
$DB->sql_put("COMMIT");