parse header

This commit is contained in:
/jdi/ 2015-09-24 20:01:26 +02:00
parent dad4770cd8
commit 5795bc1d32
6 changed files with 123 additions and 79 deletions

View file

@ -6,11 +6,12 @@
*/ */
#include <stdio.h> #include <stdio.h>
#include "Utils.h"
#include "Program.h" #include "Program.h"
#include "Device.h" #include "device/Device.h"
#include "Host.h" #include "device/Host.h"
#include "Socket.h" #include "transfer/Socket.h"
#include "Packet.h" #include "transfer/Packet.h"
Program::Program() { Program::Program() {
// TODO Auto-generated constructor stub // TODO Auto-generated constructor stub
@ -22,28 +23,20 @@ Program::~Program() {
int Program::run() { int Program::run() {
Device d = Device(); Device d = Device();
printf(" %d", d.getName()); printf(" %d\n", d.getName());
bytes b = { 255, 255, 0, 0 }; bytes b = { 255, 255, 0, 0 };
Host h = Host(); Host h = Host();
Packet p = Packet(Packet::DISCOVERY); Packet p = Packet(Packet::DISCOVERY);
p.setBody(b); p.setBody(b);
p.setHostMac(h.getMac()); p.setHostMac(h.getMac());
bytes a = p.getBytes(); bytes a = p.getBytes();
printf("\na =");
for (unsigned i = 0; i < sizeof(a); i++)
printf(" %d", a[i]);
p.encode(a); p.encode(a);
printf("\nb =");
for (unsigned i = 0; i < sizeof(a); i++)
printf(" %d", a[i]);
printf("\n");
try { try {
asio::io_service io_service; asio::io_service io_service;
Socket s(io_service, dst_port, src_port); Socket s(io_service);
//s.listen(); s.init(dst_port, src_port);
s.send(a); s.send(a);
io_service.run(); io_service.run();
} catch (std::exception& e) { } catch (std::exception& e) {

View file

@ -84,14 +84,6 @@ int main(int argc, char *argv[]) {
optind++; optind++;
} }
if (p.src_port != 0) {
printf("src_port = %d\n", p.src_port);
}
if (p.dst_port != 0) {
printf("dst_port = %d\n", p.dst_port);
}
if (p.run()) if (p.run())
exit(EXIT_SUCCESS); exit(EXIT_SUCCESS);
else else

View file

@ -5,11 +5,13 @@
* Author: jdi * Author: jdi
*/ */
#include <string.h> #include <cstring>
#include <cstdlib> #include <cstdlib>
#include <time.h> #include <cstdio>
#include <ctime>
#include "Packet.h" #include "Packet.h"
#include "../Types.h" #include "../Types.h"
#include "../Utils.h"
Packet::Packet(OpCode c) { Packet::Packet(OpCode c) {
srand(time(NULL)); srand(time(NULL));
@ -17,13 +19,10 @@ Packet::Packet(OpCode c) {
opCode = c; opCode = c;
} }
Packet::~Packet() {
// TODO Auto-generated destructor stub
}
bytes Packet::getBytes() { bytes Packet::getBytes() {
int i = 0; int i = 0;
push(body, i, payload); for (unsigned j = 0; j < payload.size(); j++)
push(body, i, payload[j]);
push(body, i, (int) PACKET_END); push(body, i, (int) PACKET_END);
i = 0; i = 0;
push(head, i, version); push(head, i, version);
@ -31,16 +30,44 @@ bytes Packet::getBytes() {
push(head, i, switchMac); push(head, i, switchMac);
push(head, i, hostMac); push(head, i, hostMac);
push(head, i, sequenceId); push(head, i, sequenceId);
push(head, i, err); push(head, i, errorCode);
push(head, i, this->getLength()); push(head, i, this->getLength());
push(head, i, fragmentOffset); push(head, i, fragmentOffset);
push(head, i, flag); push(head, i, flag);
push(head, i, tokenId); push(head, i, tokenId);
push(head, i, checkSum); push(head, i, checkSum);
bytes data = head + body; bytes data = head + body;
utils::printBytes("Send Head:\t",head);
return data; return data;
} }
void Packet::parse(bytes data) {
memcpy(&head[0], &data[0], HEADER_LEN);
body.resize(data.size() - HEADER_LEN);
memcpy(&body[0], &data[HEADER_LEN], data.size() - HEADER_LEN);
utils::printBytes("Receive Head:\t",head);
int i = 0;
short checkLen = 0x0;
pull(head, i, version);
pull(head, i, opCode);
pull(head, i, switchMac, switchMac.size());
pull(head, i, hostMac, hostMac.size());
pull(head, i, sequenceId);
pull(head, i, errorCode);
pull(head, i, checkLen);
pull(head, i, fragmentOffset);
pull(head, i, flag);
pull(head, i, tokenId);
pull(head, i, checkSum);
utils::printBytes("MAC: ", switchMac);
utils::printBytes("MAC: ", hostMac);
if(this->getLength()!= checkLen){
printf("Packet Length doesn't match: %hd != %hd\n", this->getLength(), checkLen);
}
dataset d;
payload = {};
}
void Packet::setBody(bytes data) { void Packet::setBody(bytes data) {
this->body = data; this->body = data;
} }
@ -118,8 +145,7 @@ void Packet::encode(bytes &data) {
} }
void Packet::push(bytes &arr, int &index, byte data) { void Packet::push(bytes &arr, int &index, byte data) {
arr[index] = data; arr[index++] = data;
index++;
} }
void Packet::push(bytes &arr, int &index, bytes data) { void Packet::push(bytes &arr, int &index, bytes data) {
@ -151,7 +177,31 @@ void Packet::push(bytes &arr, int &index, dataset data) {
push(arr, index, data.value); push(arr, index, data.value);
} }
void Packet::push(bytes &arr, int &index, datasets data) { void Packet::pull(bytes &arr, int &index, byte &ret) {
for (unsigned j = 0; j < data.size(); j++) ret = arr[index++];
push(arr, index, data[j]); }
void Packet::pull(bytes &arr, int &index, bytes &ret, unsigned len) {
ret.resize(len);
memcpy(&ret[0], &arr[index], len);
index+=len;
}
void Packet::pull(bytes &arr, int &index, short &ret) {
ret = (arr[index++] << 8);
ret |= arr[index++] & 0xFF;
ret &=0xFFFF;
}
void Packet::pull(bytes &arr, int &index, int &ret) {
ret = arr[index++] << 24;
ret |= (arr[index++] & 0xFF) << 16;
ret |= (arr[index++] & 0xFF) << 8;
ret |= arr[index++] & 0xFF;
}
void Packet::pull(bytes &arr, int &index, dataset &ret) {
pull(arr, index, ret.type);
pull(arr, index, ret.len);
pull(arr, index, ret.value, (unsigned) ret.len);
} }

View file

@ -19,9 +19,10 @@ public:
DISCOVERY, GET, SET DISCOVERY, GET, SET
}; };
Packet(OpCode); Packet(OpCode);
virtual ~Packet(); virtual ~Packet(){};
void encode(bytes&); void encode(bytes&);
bytes getBytes(); bytes getBytes();
void parse(bytes);
short getLength() const ; short getLength() const ;
int getCheckSum() const; int getCheckSum() const;
short getSequenceId() const; short getSequenceId() const;
@ -47,7 +48,7 @@ private:
short sequenceId; short sequenceId;
short tokenId = 0; short tokenId = 0;
short fragmentOffset = 0; short fragmentOffset = 0;
int err = 0; int errorCode = 0;
int checkSum = 0; int checkSum = 0;
short flag = 0; short flag = 0;
@ -59,7 +60,12 @@ private:
void push(bytes&, int&, byte); void push(bytes&, int&, byte);
void push(bytes&, int&, bytes); void push(bytes&, int&, bytes);
void push(bytes&, int&, dataset); void push(bytes&, int&, dataset);
void push(bytes&, int&, datasets);
void pull(bytes&, int&, short&);
void pull(bytes&, int&, int&);
void pull(bytes&, int&, byte&);
void pull(bytes&, int&, bytes&, unsigned);
void pull(bytes&, int&, dataset&);
}; };
#endif /* PACKET_H_ */ #endif /* PACKET_H_ */

View file

@ -6,75 +6,76 @@
*/ */
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <cstdio>
#include <stdio.h> #include <cerrno>
#include <unistd.h> #include <cstring>
#include <errno.h> #include <cstdlib>
#include <string.h>
#include <stdlib.h>
#include <iostream> #include <iostream>
#include <unistd.h>
#include <asio.hpp> #include <asio.hpp>
#include "Socket.h" #include "Socket.h"
#include "../Types.h" #include "../Types.h"
#include "../device/Host.h" #include "../device/Host.h"
#include "Packet.h" #include "Packet.h"
Socket::Socket(asio::io_service& io_service, short dst_port, short src_port) : Socket::Socket(asio::io_service& io_service) :
socket_(io_service) { send_socket_(io_service), receive_socket_(io_service) {
}
void Socket::init(short dst_port, short src_port) {
wildcard_endpoint_ = asio::ip::udp::endpoint(
asio::ip::address::from_string("0.0.0.0"), src_port);
local_endpoint_ = asio::ip::udp::endpoint( local_endpoint_ = asio::ip::udp::endpoint(
asio::ip::address::from_string("192.168.0.3"), src_port); //a asio::ip::address::from_string("192.168.0.3"), src_port);
remote_endpoint_ = asio::ip::udp::endpoint(
asio::ip::address_v4::from_string("255.255.255.255"), dst_port);
broadcast_endpoint_ = asio::ip::udp::endpoint( broadcast_endpoint_ = asio::ip::udp::endpoint(
asio::ip::address_v4::from_string("255.255.255.255"), dst_port); asio::ip::address_v4::from_string("255.255.255.255"), dst_port);
asio::ip::address_v4 local_addr = asio::ip::address_v4::from_string(
"192.168.0.3");
socket_.open(asio::ip::udp::v4()); send_socket_.open(asio::ip::udp::v4());
socket_.bind(local_endpoint_); //TODO reuse Address send_socket_.set_option(asio::socket_base::broadcast(true));
send_socket_.set_option(asio::socket_base::reuse_address(true));
send_socket_.bind(local_endpoint_); //TODO reuse Address
//socket_.set_option(asio::ip::multicast::outbound_interface(local_addr)); // TODO broadcast outbound interface receive_socket_.open(asio::ip::udp::v4());
socket_.set_option(asio::socket_base::broadcast(true)); receive_socket_.set_option(asio::socket_base::broadcast(true));
socket_.set_option(asio::socket_base::reuse_address(true)); receive_socket_.set_option(asio::socket_base::reuse_address(true));
receive_socket_.bind(wildcard_endpoint_); //TODO reuse Address
} }
Socket::~Socket() {
// TODO Auto-generated destructor stub
}
void Socket::send(bytes data) { void Socket::send(bytes data) {
unsigned char * a = &data[0]; unsigned char * a = &data[0];
send_socket_.async_send_to(asio::buffer(a, data.size()),
socket_.async_send_to(asio::buffer(a, data.size()), broadcast_endpoint_, broadcast_endpoint_,
[this](asio::error_code ec, std::size_t bytes_sent) [this](asio::error_code ec, std::size_t bytes_sent)
{ {
listen(); listen();
}); });
printf("Send\n");
} }
void Socket::listen() { void Socket::listen() {
socket_.async_receive_from(asio::buffer(data_, max_length), receive_socket_.async_receive_from(asio::buffer(data_, MAX_LENGTH),
remote_endpoint_, remote_endpoint_,
[this](asio::error_code ec, std::size_t bytes_recvd) [this](asio::error_code ec, std::size_t bytes_recvd)
{ {
printf("Echo");
if (ec || bytes_recvd == 0) { if (ec || bytes_recvd == 0) {
listen(); listen();
} else { } else {
printf("Receive %s\n", data_); data_.resize(bytes_recvd);
Packet p = Packet(Packet::DISCOVERY);
p.encode(data_);
p.parse(data_);
/*
sleep(1);
bytes b = {255, 255, 0, 0}; bytes b = {255, 255, 0, 0};
Host h = Host(); Host h = Host();
Packet p = Packet(Packet::DISCOVERY); p = Packet(Packet::DISCOVERY);
p.setBody(b); p.setBody(b);
p.setHostMac(h.getMac()); p.setHostMac(h.getMac());
bytes a = p.getBytes(); bytes a = p.getBytes();
p.encode(a); p.encode(a);
send(a); send(a);
*/
} }
}); });

View file

@ -11,21 +11,23 @@
#include <asio.hpp> #include <asio.hpp>
#include "../Types.h" #include "../Types.h"
#define MAX_LENGTH 1024
class Socket { class Socket {
public: public:
Socket(asio::io_service&, short, short); Socket(asio::io_service&);
virtual ~Socket(); virtual ~Socket(){};
void init(short, short);
void send(bytes); void send(bytes);
void listen(); void listen();
private: private:
asio::ip::udp::socket socket_; asio::ip::udp::socket send_socket_;
asio::ip::udp::socket receive_socket_;
asio::ip::udp::endpoint broadcast_endpoint_; asio::ip::udp::endpoint broadcast_endpoint_;
asio::ip::udp::endpoint remote_endpoint_; asio::ip::udp::endpoint remote_endpoint_;
asio::ip::udp::endpoint wildcard_endpoint_;
asio::ip::udp::endpoint local_endpoint_; asio::ip::udp::endpoint local_endpoint_;
enum { bytes data_ = bytes(MAX_LENGTH);
max_length = 1024
};
char data_[max_length];
}; };