-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathreturn.php
95 lines (82 loc) · 3.01 KB
/
return.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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
require_once('vendor/autoload.php');
use Denpa\Bitcoin\Client as DogecClient;
use GuzzleHttp\Client;
include 'config.php';
header('Access-Control-Allow-Origin: *');
header('Content-Type: application/json; charset=utf-8');
$dogec_rpc = new DogecClient('http://' . $username . ':' . $password . '@' . $host . ':' . $port);
$mysqli = new mysqli($db_host, $db_username, $db_password, $db_database);
$client = new Client();
if ($mysqli->connect_errno) {
echo "Failed to connect to MYSQL database" . $mysqli->connect_errno;
die();
}
$exists = $mysqli->query("SHOW TABLES LIKE 'invoice_status'")->num_rows == 1;
if (!$exists) {
echo "Table does not exist. Make sure to import sql file into database";
return;
}
if ($_GET) {
if (array_key_exists("api_key", $_GET) && array_key_exists("invoice", $_GET)) {
$api_key = preg_replace('/[^A-Za-z0-9\-]/', '', $_GET['api_key']);
$invoice_num = preg_replace('/[^A-Za-z0-9\-]/', '', $_GET['invoice']);
if ($mysqli->query("SELECT dogec_addr FROM api_keys WHERE `key` = '$api_key'")->num_rows != 1) {
echo json_encode([
"status"=>400,
"message"=>"Invalid API Key"
]);
return;
}
if ($mysqli->query("SELECT invoice FROM invoice_status WHERE invoice = '$invoice_num'")->num_rows != 1) {
echo json_encode([
"status"=>400,
"message"=>"Invalid Invoice"
]);
return;
}
$invoice = $mysqli->query("SELECT dogec_addr,amount FROM invoice_status WHERE invoice = '$invoice_num'")->fetch_array(MYSQLI_NUM);
$address = $invoice[0];
$amount = $invoice[1];
try {
$request = $client->request('GET', "https://api2.dogecash.org/balance/$address");
} catch(\Throwable $e) {
echo json_encode([
"status"=>400,
"message"=>"Unable to get address balance. Please contact admins."
]);
return;
}
$response = json_decode($request->getBody()->getContents(), true);
$addr_bal = $response['result']['balance'] / 1e8;
if ($addr_bal >= $amount) {
$mysqli->query("UPDATE invoice_status SET `status` = 'paid' WHERE invoice = '$invoice_num'");
echo json_encode([
"status"=>200,
"inv_status"=>"paid"
]);
return;
}
else if ($addr_bal > 0 && !($addr_bal >= $amount)) {
$mysqli->query("UPDATE invoice_status SET `status` = 'partial' WHERE invoice = '$invoice_num'");
echo json_encode([
"status"=>200,
"inv_status"=>"partial"
]);
return;
}
else {
echo json_encode([
"status"=>200,
"inv_status"=>"unpaid"
]);
return;
}
}
else {
echo json_encode([
"status"=>400,
"message"=>"Invalid Request"
]);
}
}