some fixes

This commit is contained in:
fluttershy 2024-12-31 05:58:15 +05:00
parent 4249733fe9
commit 41d1bd5268
7 changed files with 29 additions and 104 deletions

1
.gitignore vendored

@ -1 +1,2 @@
build/
.vscode/

76
.vscode/settings.json vendored

@ -1,76 +0,0 @@
{
"files.associations": {
"any": "cpp",
"array": "cpp",
"atomic": "cpp",
"bit": "cpp",
"*.tcc": "cpp",
"bitset": "cpp",
"cctype": "cpp",
"charconv": "cpp",
"chrono": "cpp",
"clocale": "cpp",
"cmath": "cpp",
"codecvt": "cpp",
"compare": "cpp",
"concepts": "cpp",
"condition_variable": "cpp",
"cstdarg": "cpp",
"cstddef": "cpp",
"cstdint": "cpp",
"cstdio": "cpp",
"cstdlib": "cpp",
"cstring": "cpp",
"ctime": "cpp",
"cwchar": "cpp",
"cwctype": "cpp",
"deque": "cpp",
"forward_list": "cpp",
"list": "cpp",
"map": "cpp",
"set": "cpp",
"string": "cpp",
"unordered_map": "cpp",
"unordered_set": "cpp",
"vector": "cpp",
"exception": "cpp",
"algorithm": "cpp",
"functional": "cpp",
"iterator": "cpp",
"memory": "cpp",
"memory_resource": "cpp",
"numeric": "cpp",
"optional": "cpp",
"random": "cpp",
"ratio": "cpp",
"string_view": "cpp",
"system_error": "cpp",
"tuple": "cpp",
"type_traits": "cpp",
"utility": "cpp",
"format": "cpp",
"initializer_list": "cpp",
"iomanip": "cpp",
"iosfwd": "cpp",
"iostream": "cpp",
"istream": "cpp",
"limits": "cpp",
"mutex": "cpp",
"new": "cpp",
"numbers": "cpp",
"ostream": "cpp",
"ranges": "cpp",
"semaphore": "cpp",
"span": "cpp",
"sstream": "cpp",
"stdexcept": "cpp",
"stop_token": "cpp",
"streambuf": "cpp",
"text_encoding": "cpp",
"thread": "cpp",
"cinttypes": "cpp",
"typeinfo": "cpp",
"valarray": "cpp",
"variant": "cpp"
}
}

@ -19,7 +19,7 @@ private:
public:
Channel(const json& data) : data(data), web(*WebSocket::getInstance()), req(*NetworkManager::getInstance()) {}
string send(const json& msg) const {
return req.request("POST", dapi + "/channels/" + data["d"]["channel_id"].get<string>() + "/messages", web.getToken(), msg.dump());
return req.request("POST", dapi + "/channels/" + data["d"]["channel_id"].get<string>() + "/messages", msg.dump());
}
};
#endif

@ -19,7 +19,7 @@ private:
public:
Message(const json& data) : data(data), web(*WebSocket::getInstance()), req(*NetworkManager::getInstance()) {};
string send(const string& id, const json& msg) {
return req.request("POST", dapi + "/channels/" + id + "/messages", web.getToken(), msg.dump());
return req.request("POST", dapi + "/channels/" + id + "/messages", msg.dump());
}
};
#endif

@ -22,7 +22,7 @@ public:
return data["d"]["author"]["id"];
}
string me() const {
return req.request("GET", dapi + "/users/@me", web.getToken(), "");
return req.request("GET", dapi + "/users/@me", "");
}
bool isBot() {
try {

@ -2,7 +2,6 @@
#define GATEWAY_WEBSOCKET_HPP_
#include <utils/enums.hpp>
#include <string>
#include <unordered_map>
#include <utils/json.hpp>
#include <thread>
#include <iostream>
@ -17,7 +16,7 @@ using namespace std::chrono;
using namespace std::chrono_literals;
class WebSocket {
private:
std::unordered_map<int, std::string> events = {
std::array<std::pair<int, std::string_view>, 73> events = {{
{APPLICATION_COMMAND_PERMISSIONS_UPDATE, "APPLICATION_COMMAND_PERMISSIONS_UPDATE"},
{AUTO_MODERATION_ACTION_EXECUTION, "AUTO_MODERATION_ACTION_EXECUTION"},
{AUTO_MODERATION_RULE_CREATE, "AUTO_MODERATION_RULE_CREATE"},
@ -91,29 +90,16 @@ private:
{VOICE_SERVER_UPDATE, "VOICE_SERVER_UPDATE"},
{VOICE_STATE_UPDATE, "VOICE_STATE_UPDATE"},
{WEBHOOKS_UPDATE, "WEBHOOKS_UPDATE"}
};
}};
bool connected = false;
static bool initialized, isBot;
static WebSocket* instance;
static int i;
static std::string t;
ix::WebSocket webSocket;
int heartbeat_interval, lastS;
json payload = { {"op", 1},{"d", nullptr} }, id, res;
static std::string t;
std::unordered_map<std::string, std::function<void(const json&)>> eventHandlers;
void test() {
std::thread([this]() {
while (1) {
json prsUpdate = { {"op", 3},{"d", {{"since", 9187921},{"activities", json::array({{"name", "dsa"}, {"type", 1}})},{"status", "online"},{"afk", false}}} };
//json voice = { {"op", 4},{"d", {{"guild_id", "1322653635875967140"},{"channel_id", nullptr},{"self_mute", false},{"self_deaf", false}}} };
webSocket.send(prsUpdate.dump());
std::this_thread::sleep_for(10000ms);
json prsUpdate2 = { {"op", 3},{"d", {{"since", 9187921},{"activities", json::array({{"name", "asd"}, {"type", 1}})},{"status", "idle"},{"afk", false}}} };
webSocket.send(prsUpdate2.dump());
std::this_thread::sleep_for(10000ms);
}
}).detach();
}
std::unordered_map<std::string_view, std::function<void(const json&)>> eventHandlers;
WebSocket(const std::string& token, const int intents, bool isBot) : lastS(0), heartbeat_interval(-1) {
WebSocket::t = token;
WebSocket::i = intents;
@ -168,6 +154,18 @@ private:
webSocket.start();
}
public:
void sendPresenceUpdate(int statusType, const std::string& activityName) {
json prsUpdate = {
{"op", 3},
{"d", {
{"since", 9187921},
{"activities", json::array({{"name", activityName}, {"type", statusType}})},
{"status", statusType == 1 ? "online" : "idle"},
{"afk", false}
}}
};
webSocket.send(prsUpdate.dump());
}
static WebSocket* getInstance(const std::string& token = "", const int intents = 0, bool bot = true) {
if (!instance) {
if (token.empty() || intents == 0) {
@ -189,13 +187,13 @@ public:
return WebSocket::i;
}
void on(const int event, std::function<void(const json&)> handler) {
eventHandlers[events[event]] = [handler](const json& message) {
eventHandlers[events[event].second] = [handler](const json& message) {
json eventData = message.get<json>();
handler(eventData);
};
}
void once(const int event, std::function<void(const json&)> handler) {
eventHandlers[events[event]] = [event, this, handler, isCalled = false](const json& message) mutable {
eventHandlers[events[event].second] = [event, this, handler, isCalled = false](const json& message) mutable {
if (isCalled == false) {
isCalled = true;
const json& eventData = message.get<json>();
@ -212,7 +210,7 @@ public:
}).detach();
}
void stop() {
while (1) std::this_thread::sleep_for(1s);
connected = false;
}
void start() {
while (1) std::this_thread::sleep_for(1ms);

@ -9,11 +9,13 @@
#include <netdb.h>
#include <unistd.h>
#include <utils/types.hpp>
#include <gateway/websocket.hpp>
using std::cout;
using std::cerr;
using std::endl;
class NetworkManager {
private:
WebSocket& web;
static NetworkManager* instance;
SSL_CTX* ctx;
int sock = -1;
@ -55,7 +57,7 @@ private:
}
freeaddrinfo(res);
}
NetworkManager() : ctx(nullptr), result("") {
NetworkManager() : ctx(nullptr), result(""), web(*WebSocket::getInstance()) {
if (!ctx) {
ctx = SSL_CTX_new(TLS_client_method());
if (!ctx) {
@ -80,10 +82,10 @@ public:
if (ctx) SSL_CTX_free(ctx);
close(sock);
}
const std::string& request(const std::string& method, const std::string& path, const std::string& authorization, const std::string& data) {
auto net = [this, method, path, authorization, data, bytesRead = 0, request = std::string("")]() mutable -> void {
const std::string& request(const std::string& method, const std::string& path, const std::string& data) {
auto net = [this, method, path, data, bytesRead = 0, request = std::string("")]() mutable -> void {
request = method + " " + path + " HTTP/1.1\r\nHost: discord.com\r\nAccept: application/json\r\nContent-Type: application/json\r\n";
request += "Authorization: " + authorization + "\r\n";
request += "Authorization: " + web.getToken() + "\r\n";
request += "Content-Length: " + std::to_string(data.length()) + "\r\n";
#ifdef DEBUG
request += "Connection: close\r\n\r\n";