Compare commits
No commits in common. "e0423f9bfc75353461586948c1d65c4596aeb613" and "8bdf357e1a58784c1b46e7ff8886295381862da0" have entirely different histories.
e0423f9bfc
...
8bdf357e1a
@ -47,37 +47,22 @@ Connection::~Connection(){
|
||||
close(fd);
|
||||
}
|
||||
|
||||
bool Connection::send(std::vector<Payload> payloads, bool size){
|
||||
if(size){
|
||||
unsigned char _size = payloads.size();
|
||||
::send(fd, &_size , sizeof(_size), 0);
|
||||
}
|
||||
bool Connection::send(std::vector<Payload> payloads){
|
||||
for (Payload& p : payloads) {
|
||||
::send(fd, p.getData() , p.getSize(), 0);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool Connection::send(Payload payload, bool size){
|
||||
return send(std::vector<Payload>{payload}, size);
|
||||
}
|
||||
|
||||
Payload Connection::recv(){
|
||||
Payload ret;
|
||||
|
||||
ssize_t size = 0, bytes;
|
||||
std::vector<unsigned char> received(100);
|
||||
while((bytes = ::recv(fd, received.data() + size, 100, 0)) > 0){
|
||||
size += bytes;
|
||||
received.resize(size+100);
|
||||
char temp[100];
|
||||
memset(temp, 0, 100);
|
||||
ssize_t size;
|
||||
while((size = ::recv(fd, temp, sizeof(temp), 0)) > 0){
|
||||
for(char& in: temp){
|
||||
ret.push_char(in);
|
||||
}
|
||||
}
|
||||
if(bytes == 0){
|
||||
received.shrink_to_fit();
|
||||
ret.setData(received);
|
||||
return ret;
|
||||
}
|
||||
|
||||
//Error Handling
|
||||
error = ErrorTypes::recv;
|
||||
return ret;
|
||||
}
|
||||
|
10
Connection.h
10
Connection.h
@ -5,6 +5,8 @@
|
||||
#include <vector>
|
||||
#include "Payload.h"
|
||||
|
||||
class Payload;
|
||||
|
||||
class Connection
|
||||
{
|
||||
private:
|
||||
@ -16,10 +18,7 @@ private:
|
||||
socket_creation = 10,
|
||||
get_ip,
|
||||
connect,
|
||||
|
||||
recv = 20,
|
||||
send
|
||||
}error = ErrorTypes::none;
|
||||
}error;
|
||||
|
||||
void p_HandleError();
|
||||
|
||||
@ -27,8 +26,7 @@ public:
|
||||
Connection(std::string server_ip, int port);
|
||||
~Connection();
|
||||
|
||||
bool send(std::vector<Payload> payload, bool size);
|
||||
bool send(Payload payload, bool size);
|
||||
bool send(std::vector<Payload> payload);
|
||||
Payload recv();
|
||||
|
||||
/**
|
||||
|
14
Payload.cpp
14
Payload.cpp
@ -1,23 +1,13 @@
|
||||
#include "Payload.h"
|
||||
|
||||
void Payload::push_char(unsigned char load){
|
||||
void Payload::push_char(char load){
|
||||
Data.push_back(load);
|
||||
}
|
||||
|
||||
unsigned char* Payload::getData(){
|
||||
char* Payload::getData(){
|
||||
return Data.data();
|
||||
}
|
||||
|
||||
void Payload::setData(std::vector<unsigned char> m_data){
|
||||
Data = m_data;
|
||||
}
|
||||
|
||||
size_t Payload::getSize(){
|
||||
return Data.size();
|
||||
}
|
||||
|
||||
Payload::Payload(){ }
|
||||
|
||||
Payload::Payload(std::vector<unsigned char> m_data)
|
||||
: Data(m_data){}
|
||||
|
||||
|
10
Payload.h
10
Payload.h
@ -7,17 +7,15 @@
|
||||
class Payload
|
||||
{
|
||||
private:
|
||||
std::vector<unsigned char> Data;
|
||||
std::vector<char> Data;
|
||||
public:
|
||||
size_t getSize();
|
||||
unsigned char* getData();
|
||||
char* getData();
|
||||
|
||||
void setData(std::vector<unsigned char>);
|
||||
|
||||
void push_char(unsigned char);
|
||||
void push_char(char);
|
||||
|
||||
Payload();
|
||||
Payload(std::vector<unsigned char>);
|
||||
virtual ~Payload();
|
||||
};
|
||||
|
||||
#endif /* PAYLOAD_H */
|
||||
|
23
main.cpp
23
main.cpp
@ -1,29 +1,8 @@
|
||||
#include "Connection.h"
|
||||
#include "Payload.h"
|
||||
#include <thread>
|
||||
#include <iostream>
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
Connection* c;
|
||||
if(argc == 1){
|
||||
c = new Connection("145.239.73.162", 25565);
|
||||
}else{
|
||||
c = new Connection(argv[1], atoi(argv[2]));
|
||||
}
|
||||
if(c->status() != 0){
|
||||
return 1;
|
||||
}
|
||||
std::vector<unsigned char> p_data{0xFE, 0x01, 0xFA, 0x00, 0x08, 0x00, 0x4D, 0x00, 0x43, 0x00, 0x7C, 0x00, 0x50, 0x00, 0x69, 0x00, 0x6E, 0x00, 0x67, 0x00, 0x48, 0x00, 0x6F, 0x00, 0x73, 0x00, 0x74};
|
||||
Payload p(p_data);
|
||||
|
||||
c->send(p, true);
|
||||
Payload response = c->recv();
|
||||
std::cout << response.getData() << std::endl;
|
||||
Connection c("145.239.73.162", 25565);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void test_server(std::string addr, int port, Payload p){
|
||||
Connection c(addr, port);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user