71 lines
2.0 KiB
C++
71 lines
2.0 KiB
C++
#include "mongoStub.hpp"
|
|
|
|
mongoStub::mongoStub() {
|
|
if (this->client) {
|
|
this->db = client["fosscord"];
|
|
|
|
if (this->db) {
|
|
this->col = db["events"];
|
|
|
|
} else {
|
|
std::cout << "db not found";
|
|
exit(-1);
|
|
}
|
|
} else {
|
|
std::cout << "Client couldn't be initialized";
|
|
exit(-1);
|
|
}
|
|
}
|
|
|
|
// Too slow for my liking
|
|
std::vector<mongoStub::mongoMessage> mongoStub::getNewMessages(
|
|
mongocxx::change_stream* colCs) {
|
|
std::vector<mongoStub::mongoMessage> retVec;
|
|
|
|
for (auto&& event : *colCs) {
|
|
mongoStub::mongoMessage returnValue;
|
|
|
|
std::cout << bsoncxx::to_json(event) << std::endl;
|
|
|
|
// Only listen to insert events (to avoid "precondition failed: data"
|
|
// exception)
|
|
if (event["operationType"].get_utf8().value.to_string() != "insert") {
|
|
continue;
|
|
}
|
|
std::string evNameTmp =
|
|
event["fullDocument"]["event"].get_utf8().value.to_string();
|
|
if (evNameTmp == "UDP_CONNECTION") {
|
|
handleUdpRequest();
|
|
} else if (evNameTmp == "VOICE_REQUEST") {
|
|
continue;
|
|
}
|
|
|
|
returnValue.eventName = evNameTmp;
|
|
retVec.push_back(returnValue);
|
|
}
|
|
|
|
return retVec;
|
|
}
|
|
|
|
void mongoStub::handleUdpRequest() {
|
|
using bsoncxx::builder::basic::kvp;
|
|
using bsoncxx::builder::basic::sub_array;
|
|
using bsoncxx::builder::basic::sub_document;
|
|
|
|
auto builder = bsoncxx::builder::basic::document{};
|
|
|
|
builder.append(kvp("event", "VSERVER_UDP_RESPONSE"));
|
|
builder.append(kvp("op", "4"));
|
|
builder.append(kvp("d", [](sub_document subdoc) {
|
|
subdoc.append(kvp("mode", "CRYPT_MODE")),
|
|
subdoc.append(kvp("secret_key", [](sub_array subarr) {
|
|
subarr.append(1, 2, 3, 5); // HOW DO I GEN A SKEY?
|
|
}));
|
|
}));
|
|
|
|
|
|
bsoncxx::stdx::optional<mongocxx::result::insert_one> r= col.insert_one(builder.view());
|
|
std::cout << "Insert"<< std::endl;
|
|
}
|
|
|
|
void handleVoiceRequest() {} |