Add Munzee oauth and capture support (not tested fully)
This commit is contained in:
parent
487775734e
commit
6b9d631b7a
@ -84,4 +84,103 @@ if ($database->has('claimedcodes', ["AND" => ['code' => $VARS["code"], 'accounti
|
|||||||
$returndata['messages'][] = $Strings->build("You found one {item}", ["item" => $itemname], false);
|
$returndata['messages'][] = $Strings->build("You found one {item}", ["item" => $itemname], false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strpos($VARS["code"], "munzee") !== false && $database->has('munzee', ['accountid' => getRequestUser()->getUID()])) {
|
||||||
|
|
||||||
|
if (!empty($VARS["latitude"]) && !empty($VARS["longitude"]) && !empty($VARS["accuracy"])) {
|
||||||
|
$latitude = $VARS["latitude"];
|
||||||
|
$longitude = $VARS["longitude"];
|
||||||
|
$accuracy = $VARS["accuracy"];
|
||||||
|
/* Check if we need to refresh the bearer token first */
|
||||||
|
if ($database->has('munzee', ["AND" => ['accountid' => getRequestUser()->getUID(), 'expires[<=]' => (time() + 30)]])) {
|
||||||
|
$url = 'https://api.munzee.com/oauth/login';
|
||||||
|
$fields = array(
|
||||||
|
'client_id' => urlencode($SETTINGS["munzee"]["id"]),
|
||||||
|
'client_secret' => urlencode($SETTINGS["munzee"]["secret"]),
|
||||||
|
'grant_type' => 'refresh_token',
|
||||||
|
'refresh_token' => $database->select('munzee', 'refreshtoken', ['accountid' => getRequestUser()->getUID()])[0]
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach ($fields as $key => $value) {
|
||||||
|
$fields_string .= $key . '=' . $value . '&';
|
||||||
|
}
|
||||||
|
rtrim($fields_string, '&');
|
||||||
|
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
$options = array(
|
||||||
|
CURLOPT_URL => $url,
|
||||||
|
CURLOPT_POST => 1,
|
||||||
|
CURLOPT_POSTFIELDS => $fields_string,
|
||||||
|
CURLOPT_RETURNTRANSFER => 1, // return web page
|
||||||
|
CURLOPT_HEADER => false, // don't return headers
|
||||||
|
CURLOPT_ENCODING => "", // handle compressed
|
||||||
|
CURLOPT_USERAGENT => "TerranQuest Game Server", // name of client
|
||||||
|
CURLOPT_AUTOREFERER => true, // set referrer on redirect
|
||||||
|
CURLOPT_CONNECTTIMEOUT => 120, // time-out on connect
|
||||||
|
CURLOPT_TIMEOUT => 120, // time-out on response
|
||||||
|
);
|
||||||
|
curl_setopt_array($ch, $options);
|
||||||
|
|
||||||
|
$result = curl_exec($ch);
|
||||||
|
|
||||||
|
curl_close($ch);
|
||||||
|
|
||||||
|
$data = json_decode($result, TRUE)['data'];
|
||||||
|
$status_code = json_decode($result, TRUE)['status_code'];
|
||||||
|
if ($status_code == 200) {
|
||||||
|
$database->update('munzee', ['bearertoken' => $data['token']['access_token'], 'refreshtoken' => $data['token']['refresh_token'], 'expires' => $data['token']['expires']], ['accountid' => getRequestUser()->getUID()]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check again now */
|
||||||
|
if ($database->has('munzee', ["AND" => ['accountid' => getRequestUser()->getUID(), 'expires[>]' => (time() + 30)]])) {
|
||||||
|
$url = 'https://api.munzee.com/capture/light/';
|
||||||
|
$header = array(
|
||||||
|
'Authorization: ' . $database->select('munzee', ['bearertoken'], ['accountid' => getRequestUser()->getUID()])[0]['bearertoken']
|
||||||
|
);
|
||||||
|
|
||||||
|
$time = time();
|
||||||
|
$fields = ['data' => json_encode([
|
||||||
|
"language" => "EN",
|
||||||
|
"latitude" => $latitude,
|
||||||
|
"longitude" => $longitude,
|
||||||
|
"accuracy" => $accuracy,
|
||||||
|
"time" => time(),
|
||||||
|
"code" => $VARS["code"]
|
||||||
|
])
|
||||||
|
];
|
||||||
|
//open connection
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
$options = array(
|
||||||
|
CURLOPT_URL => $url,
|
||||||
|
CURLOPT_POST => true,
|
||||||
|
CURLOPT_POSTFIELDS => $fields,
|
||||||
|
CURLOPT_HTTPHEADER => $header,
|
||||||
|
CURLOPT_RETURNTRANSFER => true, // return web page
|
||||||
|
CURLOPT_HEADER => false, // don't return headers
|
||||||
|
CURLOPT_FOLLOWLOCATION => true, // follow redirects
|
||||||
|
CURLOPT_MAXREDIRS => 10, // stop after 10 redirects
|
||||||
|
CURLOPT_ENCODING => "", // handle compressed
|
||||||
|
CURLOPT_USERAGENT => "TerranQuest Game Server", // name of client
|
||||||
|
CURLOPT_AUTOREFERER => true, // set referrer on redirect
|
||||||
|
CURLOPT_CONNECTTIMEOUT => 120, // time-out on connect
|
||||||
|
CURLOPT_TIMEOUT => 120, // time-out on response
|
||||||
|
);
|
||||||
|
curl_setopt_array($ch, $options);
|
||||||
|
|
||||||
|
$result = curl_exec($ch);
|
||||||
|
//close connection
|
||||||
|
curl_close($ch);
|
||||||
|
|
||||||
|
|
||||||
|
$data = json_decode($result, TRUE);
|
||||||
|
if ($data['status_code'] == 200) {
|
||||||
|
// Add munzee capture info to response
|
||||||
|
$returndata["munzee"] = $data["data"]["result"];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
exitWithJson($returndata);
|
exitWithJson($returndata);
|
||||||
|
77
munzee.php
Normal file
77
munzee.php
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
require __DIR__ . "/required.php";
|
||||||
|
|
||||||
|
|
||||||
|
if (empty($VARS['code'])) {
|
||||||
|
$user = User::byUsername($VARS["username"]);
|
||||||
|
if (!$user->exists()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ($user->checkPassword($VARS["password"], true)) {
|
||||||
|
$_SESSION["userid"] = User::byUsername($VARS["username"])->getUID();
|
||||||
|
$_SESSION["munzeeauthed"] = true;
|
||||||
|
header("Location: https://api.munzee.com/oauth?response_type=code&client_id=" . $SETTINGS["munzee"]["id"] . "&redirect_uri=" + $SETTINGS["munzee"]["redirecturl"] + "&scope=read capture_light");
|
||||||
|
die("OK");
|
||||||
|
}
|
||||||
|
die("Login incorrect.");
|
||||||
|
} else {
|
||||||
|
if ($_SESSION["munzeeauthed"] !== true) {
|
||||||
|
die("Invalid session or session expired. Try again.");
|
||||||
|
}
|
||||||
|
$code = $VARS['code'];
|
||||||
|
$url = 'https://api.munzee.com/oauth/login';
|
||||||
|
$fields = array(
|
||||||
|
'client_id' => urlencode($SETTINGS["munzee"]["id"]),
|
||||||
|
'client_secret' => urlencode($SETTINGS["munzee"]["secret"]),
|
||||||
|
'grant_type' => 'authorization_code',
|
||||||
|
'code' => urlencode($code),
|
||||||
|
'redirect_uri' => urlencode($SETTINGS["munzee"]["redirecturl"])
|
||||||
|
);
|
||||||
|
//url-ify the data for the POST
|
||||||
|
foreach ($fields as $key => $value) {
|
||||||
|
$fields_string .= $key . '=' . $value . '&';
|
||||||
|
}
|
||||||
|
rtrim($fields_string, '&');
|
||||||
|
//open connection
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
$options = array(
|
||||||
|
CURLOPT_URL => $url,
|
||||||
|
CURLOPT_POST => 1,
|
||||||
|
CURLOPT_POSTFIELDS => $fields_string,
|
||||||
|
CURLOPT_RETURNTRANSFER => true, // return web page
|
||||||
|
CURLOPT_HEADER => false, // don't return headers
|
||||||
|
CURLOPT_FOLLOWLOCATION => true, // follow redirects
|
||||||
|
CURLOPT_MAXREDIRS => 10, // stop after 10 redirects
|
||||||
|
CURLOPT_ENCODING => "", // handle compressed
|
||||||
|
CURLOPT_USERAGENT => "TerranQuest Game Server", // name of client
|
||||||
|
CURLOPT_AUTOREFERER => true, // set referrer on redirect
|
||||||
|
CURLOPT_CONNECTTIMEOUT => 120, // time-out on connect
|
||||||
|
CURLOPT_TIMEOUT => 120, // time-out on response
|
||||||
|
);
|
||||||
|
curl_setopt_array($ch, $options);
|
||||||
|
//execute post
|
||||||
|
$result = curl_exec($ch);
|
||||||
|
//close connection
|
||||||
|
curl_close($ch);
|
||||||
|
|
||||||
|
$jsonresult = json_decode($result, TRUE);
|
||||||
|
$data = $jsonresult['data'];
|
||||||
|
if ($jsonresult['status_code'] == 200) {
|
||||||
|
if ($database->has('munzee', ['accountid' => $_SESSION['userid']])) {
|
||||||
|
$database->update('munzee', ['bearertoken' => $data['token']['access_token'], 'refreshtoken' => $data['token']['refresh_token'], 'expires' => $data['token']['expires']], ['accountid' => $_SESSION['userid']]);
|
||||||
|
} else {
|
||||||
|
$database->insert('munzee', ['bearertoken' => $data['token']['access_token'], 'refreshtoken' => $data['token']['refresh_token'], 'expires' => $data['token']['expires'], 'accountid' => $_SESSION['userid']]);
|
||||||
|
}
|
||||||
|
die($Strings->get("Your Munzee account has been linked to TerranQuest!", false));
|
||||||
|
} else {
|
||||||
|
die($Strings->get("Munzee is having problems right now. Try again later.", false));
|
||||||
|
}
|
||||||
|
}
|
@ -74,6 +74,11 @@ $SETTINGS = [
|
|||||||
"WATER_TOWER"
|
"WATER_TOWER"
|
||||||
]
|
]
|
||||||
],
|
],
|
||||||
|
"munzee" => [
|
||||||
|
"id" => "",
|
||||||
|
"secret" => "",
|
||||||
|
"redirecturl" => "https://gs.terranquest.net/munzee.php"
|
||||||
|
],
|
||||||
// List of required user permissions to access this app.
|
// List of required user permissions to access this app.
|
||||||
"permissions" => [
|
"permissions" => [
|
||||||
],
|
],
|
||||||
|
Loading…
x
Reference in New Issue
Block a user