mirror of
https://github.com/BeamMP/BeamMP-Launcher.git
synced 2025-07-01 15:36:10 +00:00
123 lines
3.9 KiB
C++
Executable File
123 lines
3.9 KiB
C++
Executable File
// Copyright (c) 2019-present Anonymous275.
|
|
// BeamMP Launcher code is not in the public domain and is not free software.
|
|
// One must be granted explicit permission by the copyright holder in order to modify or distribute any part of the source or binaries.
|
|
// Anything else is prohibited. Modified works may not be published and have be upstreamed to the official repository.
|
|
///
|
|
/// Created by Anonymous275 on 11/26/2020
|
|
///
|
|
|
|
#include "Http.h"
|
|
#include <filesystem>
|
|
#include "Logger.h"
|
|
#include <fstream>
|
|
#include "Json.h"
|
|
|
|
namespace fs = std::filesystem;
|
|
std::string PublicKey;
|
|
extern bool LoginAuth;
|
|
std::string Role;
|
|
|
|
void UpdateKey(const char* newKey){
|
|
if(newKey && std::isalnum(newKey[0])){
|
|
std::ofstream Key("key");
|
|
if(Key.is_open()){
|
|
Key << newKey;
|
|
Key.close();
|
|
}else fatal("Cannot write to disk!");
|
|
}else if(fs::exists("key")){
|
|
remove("key");
|
|
}
|
|
}
|
|
|
|
/// "username":"value","password":"value"
|
|
/// "Guest":"Name"
|
|
/// "pk":"private_key"
|
|
|
|
std::string GetFail(const std::string& R){
|
|
std::string DRet = R"({"success":false,"message":)";
|
|
DRet += "\""+R+"\"}";
|
|
error(R);
|
|
return DRet;
|
|
}
|
|
|
|
std::string Login(const std::string& fields){
|
|
if(fields == "LO"){
|
|
LoginAuth = false;
|
|
UpdateKey(nullptr);
|
|
return "";
|
|
}
|
|
info("Attempting to authenticate...");
|
|
std::string Buffer = HTTP::Post("https://auth.beammp.com/userlogin", fields) + "\n";
|
|
json::Document d;
|
|
d.Parse(Buffer.c_str());
|
|
if(Buffer == "-1"){
|
|
return GetFail("Failed to communicate with the auth system!");
|
|
}
|
|
|
|
if (Buffer.at(0) != '{' || d.HasParseError()) {
|
|
error(Buffer);
|
|
return GetFail("Invalid answer from authentication servers, please try again later!");
|
|
}
|
|
if(!d["success"].IsNull() && d["success"].GetBool()){
|
|
LoginAuth = true;
|
|
if(!d["private_key"].IsNull()){
|
|
UpdateKey(d["private_key"].GetString());
|
|
}
|
|
if(!d["public_key"].IsNull()){
|
|
PublicKey = d["public_key"].GetString();
|
|
}
|
|
info("Authentication successful!");
|
|
}else info("Authentication failed!");
|
|
if(!d["message"].IsNull()){
|
|
d.RemoveMember("private_key");
|
|
d.RemoveMember("public_key");
|
|
rapidjson::StringBuffer buffer;
|
|
rapidjson::Writer<rapidjson::StringBuffer> writer(buffer);
|
|
d.Accept(writer);
|
|
return buffer.GetString();
|
|
}
|
|
return GetFail("Invalid message parsing!");
|
|
}
|
|
|
|
void CheckLocalKey(){
|
|
if(fs::exists("key") && fs::file_size("key") < 100){
|
|
std::ifstream Key("key");
|
|
if(Key.is_open()) {
|
|
auto Size = fs::file_size("key");
|
|
std::string Buffer(Size, 0);
|
|
Key.read(&Buffer[0], Size);
|
|
Key.close();
|
|
|
|
for (char& c : Buffer) {
|
|
if (!std::isalnum(c) && c != '-') {
|
|
UpdateKey(nullptr);
|
|
return;
|
|
}
|
|
}
|
|
|
|
Buffer = HTTP::Post("https://auth.beammp.com/userlogin", R"({"pk":")" + Buffer + "\"}");
|
|
|
|
json::Document d;
|
|
d.Parse(Buffer.c_str());
|
|
if (Buffer == "-1" || Buffer.at(0) != '{' || d.HasParseError()) {
|
|
error(Buffer);
|
|
info("Invalid answer from authentication servers.");
|
|
UpdateKey(nullptr);
|
|
}
|
|
if(d["success"].GetBool()){
|
|
LoginAuth = true;
|
|
UpdateKey(d["private_key"].GetString());
|
|
PublicKey = d["public_key"].GetString();
|
|
Role = d["role"].GetString();
|
|
//info(Role);
|
|
}else{
|
|
info("Auto-Authentication unsuccessful please re-login!");
|
|
UpdateKey(nullptr);
|
|
}
|
|
}else{
|
|
warn("Could not open saved key!");
|
|
UpdateKey(nullptr);
|
|
}
|
|
}else UpdateKey(nullptr);
|
|
}
|