-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathsteamuv.cpp
88 lines (76 loc) · 2.6 KB
/
steamuv.cpp
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
#include <iostream>
#include <functional>
#include <uv.h>
#include "steam++.h"
using namespace Steam;
uv_tcp_t sock;
uv_timer_t timer;
std::string read_buffer;
std::string write_buffer;
std::string::size_type read_offset = 0;
extern SteamClient client;
SteamClient client(
// write callback
[](std::size_t length, std::function<void(unsigned char* buffer)> fill) {
auto write = new uv_write_t;
// TODO: check if previous write has finished
write_buffer.resize(length);
fill(reinterpret_cast<unsigned char*>(&write_buffer[0]));
auto buf = uv_buf_init(&write_buffer[0], write_buffer.size());
uv_write(write, (uv_stream_t*)&sock, &buf, 1, [](uv_write_t* req, int status) {
delete req;
});
},
// set_inverval callback
[](std::function<void()> callback, int timeout) {
auto callback_heap = new std::function<void()>(std::move(callback));
timer.data = callback_heap;
uv_timer_start(&timer, [](uv_timer_t* handle, int status) {
auto callback = reinterpret_cast<std::function<void()>*>(handle->data);
(*callback)();
// TODO: delete it somewhere
}, timeout * 1000, timeout * 1000);
}
);
int main() {
uv_tcp_init(uv_default_loop(), &sock);
uv_timer_init(uv_default_loop(), &timer);
auto &endpoint = servers[rand() % (sizeof(servers) / sizeof(servers[0]))];
auto connect = new uv_connect_t;
sockaddr_in addr;
uv_ip4_addr(endpoint.host, endpoint.port, &addr);
uv_tcp_connect(connect, &sock, (sockaddr*)&addr, [](uv_connect_t* req, int status) {
auto length = client.connected();
read_buffer.resize(length);
uv_read_start(req->handle, [](uv_handle_t* handle, size_t suggested_size, uv_buf_t* buf) {
*buf = uv_buf_init(&read_buffer[read_offset], read_buffer.size() - read_offset);
}, [](uv_stream_t* stream, ssize_t nread, const uv_buf_t* buf) {
if (nread < 1) {
auto str = uv_strerror(nread);
}
read_offset += nread;
if (read_offset == read_buffer.size()) {
auto next_length = client.readable(reinterpret_cast<unsigned char*>(&read_buffer[0]));
read_offset = 0;
read_buffer.resize(next_length);
}
});
delete req;
});
client.onHandshake = [] {
client.LogOn("username", "password", nullptr, "optional code");
};
client.onLogOn = [](EResult result, SteamID steamID) {
if (result == EResult::OK) {
std::cout << "logged on!" << std::endl;
client.SetPersonaState(EPersonaState::Online);
client.JoinChat(103582791432594962);
}
};
client.onChatMsg = [](SteamID room, SteamID chatter, std::string message) {
if (message == "ping") {
client.SendChatMessage(room, "pong");
}
};
return uv_run(uv_default_loop(), uv_run_mode::UV_RUN_DEFAULT);
}