Compare commits
No commits in common. "574bef34e22a2a446f4688b82a47de4c4cf2610f" and "86c91f74887e891a782a93cd11928170789749bd" have entirely different histories.
574bef34e2
...
86c91f7488
9 changed files with 50 additions and 69 deletions
2
Makefile
2
Makefile
|
@ -1,5 +1,5 @@
|
||||||
CXX=g++
|
CXX=g++
|
||||||
CXXFLAGS=-Wall -Wextra -Werror -pedantic -std=c++14 -O2
|
CXXFLAGS=-Wall -Wextra -Werror -pedantic -std=c++14 -O0 -g
|
||||||
CXXLIBS=-lpthread
|
CXXLIBS=-lpthread
|
||||||
|
|
||||||
OBJS = Bytes.o main.o protocol.o neighbours.o packetParser.o configFile.o \
|
OBJS = Bytes.o main.o protocol.o neighbours.o packetParser.o configFile.o \
|
||||||
|
|
34
README.md
34
README.md
|
@ -1,35 +1,3 @@
|
||||||
# M1-nw-project
|
# M1-nw-project
|
||||||
|
|
||||||
Projet de cours "réseau", M1 <https://tobast.fr/m1/nw-project.pdf>
|
Master 1 network course project <https://tobast.fr/m1/nw-project.pdf>
|
||||||
|
|
||||||
## Dépendances
|
|
||||||
|
|
||||||
* `g++` (version supportant c++14) ou tout autre compilateur c++ (éditer le
|
|
||||||
Makefile pour changer `CXX`)
|
|
||||||
* Bibliothèques standard POSIX
|
|
||||||
|
|
||||||
## Compiler
|
|
||||||
|
|
||||||
Lancer simplement `make`.
|
|
||||||
|
|
||||||
## Lancer
|
|
||||||
|
|
||||||
Le programme fourni prend en argument le chemin vers un fichier de
|
|
||||||
configuration, dont chaque ligne commence par un mot-clé suivi de ses
|
|
||||||
arguments.
|
|
||||||
|
|
||||||
* `id [ID du programme]` : laisser vide par défaut, sera généré
|
|
||||||
automatiquement.
|
|
||||||
* `bootstrap [ID du nœud] [adresse IPv6 du nœud] [port]` : déclare le nœud
|
|
||||||
comme nœud de bootstrap. L'adresse peut être IPv4-mapped, eg.
|
|
||||||
`::FFFF:42.42.42.42`.
|
|
||||||
* `data [id de donnée] [donnée]` : déclare une donnée à propager. Si l'id est
|
|
||||||
0, il sera tiré au hasard puis enregistré. La donnée peut contenir des
|
|
||||||
espaces, et s'étend jusqu'à la fin de la ligne.
|
|
||||||
|
|
||||||
Le programme, à l'initialisation, lit le fichier puis le réécrit avec
|
|
||||||
éventuellement des données tirées au hasard si nécessaire (eg. ID du nœud, des
|
|
||||||
données).
|
|
||||||
|
|
||||||
Le programme produit des logs verbeux mais humainement lisibles sur sa sortie
|
|
||||||
d'erreur (stderr).
|
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
#include "dataStore.h"
|
#include "dataStore.h"
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdlib>
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
DataStore::DataStore(Protocol* proto) : proto(proto)
|
DataStore::DataStore(Protocol* proto) : proto(proto)
|
||||||
|
@ -18,7 +17,7 @@ DataStore::~DataStore() {
|
||||||
|
|
||||||
void DataStore::update() {
|
void DataStore::update() {
|
||||||
while(!timeEvents.empty()) {
|
while(!timeEvents.empty()) {
|
||||||
TimeEvent evt = timeEvents.top();
|
const TimeEvent& evt = timeEvents.top();
|
||||||
if(evt.time > time(NULL)) // We're done for now.
|
if(evt.time > time(NULL)) // We're done for now.
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -90,18 +89,12 @@ void DataStore::handleExpire(u64 id, u32 seqno) {
|
||||||
cleanData(id);
|
cleanData(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataStore::handleRepublish(u64 datId) {
|
void DataStore::handleRepublish(u64 id) {
|
||||||
if(data.find(datId) == data.end() || !data[datId].isMine) {
|
if(data.find(id) == data.end() || !data[id].isMine)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
curSeqno[datId] = time(NULL);
|
curSeqno[id] = time(NULL);
|
||||||
|
handleFlood(id);
|
||||||
timeEvents.push(TimeEvent(
|
|
||||||
time(NULL) + csts::TIME_REPUBLISH_DATA,
|
|
||||||
curSeqno[datId], datId, EV_REPUBLISH));
|
|
||||||
|
|
||||||
handleFlood(datId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataStore::handleFlood(u64 id) {
|
void DataStore::handleFlood(u64 id) {
|
||||||
|
|
|
@ -57,7 +57,7 @@ class DataStore {
|
||||||
|
|
||||||
private: //meth
|
private: //meth
|
||||||
void handleExpire(u64 id, u32 seqno);
|
void handleExpire(u64 id, u32 seqno);
|
||||||
void handleRepublish(u64 datId);
|
void handleRepublish(u64 id);
|
||||||
void handleFlood(u64 id);
|
void handleFlood(u64 id);
|
||||||
|
|
||||||
void cleanData(u64 id);
|
void cleanData(u64 id);
|
||||||
|
|
3
main.cpp
3
main.cpp
|
@ -56,8 +56,7 @@ int main(int argc, char** argv) {
|
||||||
for(u8 chr : dat.second)
|
for(u8 chr : dat.second)
|
||||||
pck << chr;
|
pck << chr;
|
||||||
dataStore.addData(pck, time(NULL), dat.first, true);
|
dataStore.addData(pck, time(NULL), dat.first, true);
|
||||||
fprintf(stderr, "[INFO] Adding data `%s` (%lX)\n",
|
fprintf(stderr, "[INFO] Adding data `%s`\n", dat.second.c_str());
|
||||||
dat.second.c_str(), dat.first);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Neighbours neighboursManager(&proto, &dataStore);
|
Neighbours neighboursManager(&proto, &dataStore);
|
||||||
|
|
|
@ -94,7 +94,6 @@ void Neighbours::fullUpdate() {
|
||||||
void Neighbours::addPotentialNei(const Neighbour& nei) {
|
void Neighbours::addPotentialNei(const Neighbour& nei) {
|
||||||
if(neiType.find(nei.id) != neiType.end())
|
if(neiType.find(nei.id) != neiType.end())
|
||||||
return; // We already know him
|
return; // We already know him
|
||||||
fprintf(stderr, "[INFO] Adding potential neighbour %lX\n", nei.id);
|
|
||||||
potentialNei.push_back(nei);
|
potentialNei.push_back(nei);
|
||||||
lastRecv.insert({nei.id, 0});
|
lastRecv.insert({nei.id, 0});
|
||||||
lastIHU.insert({nei.id, 0});
|
lastIHU.insert({nei.id, 0});
|
||||||
|
|
|
@ -14,11 +14,6 @@ PacketParser::PacketParser(Neighbours* nei, Protocol* proto,
|
||||||
|
|
||||||
void PacketParser::parse(Bytes pck, const SockAddr& addr) {
|
void PacketParser::parse(Bytes pck, const SockAddr& addr) {
|
||||||
u64 peerId;
|
u64 peerId;
|
||||||
if(pck.size() < 8) {
|
|
||||||
fprintf(stderr, "[WARNING] Bad packet size.\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
pck >> peerId;
|
pck >> peerId;
|
||||||
neighbours->receivedFrom(peerId, addr);
|
neighbours->receivedFrom(peerId, addr);
|
||||||
|
|
||||||
|
@ -29,10 +24,6 @@ void PacketParser::parse(Bytes pck, const SockAddr& addr) {
|
||||||
|
|
||||||
void PacketParser::readTLV(Bytes& pck, u64 nei, const SockAddr& addr) {
|
void PacketParser::readTLV(Bytes& pck, u64 nei, const SockAddr& addr) {
|
||||||
u8 type, len;
|
u8 type, len;
|
||||||
if(pck.size() < 2) {
|
|
||||||
fprintf(stderr, "[WARNING] Bad packet size from %lX.\n", nei);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
pck >> type >> len;
|
pck >> type >> len;
|
||||||
|
|
||||||
fprintf(stderr, "[INFO] Parsing %d from %lX.\n", type, nei);
|
fprintf(stderr, "[INFO] Parsing %d from %lX.\n", type, nei);
|
||||||
|
@ -95,6 +86,8 @@ void PacketParser::receiveNeigh(Bytes& pck) {
|
||||||
if(id == protocol->getSelfId())
|
if(id == protocol->getSelfId())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
fprintf(stderr, "[INFO] Adding neighbour %lX\n", id);
|
||||||
|
|
||||||
Neighbour nei(id, addr);
|
Neighbour nei(id, addr);
|
||||||
neighbours->addPotentialNei(nei);
|
neighbours->addPotentialNei(nei);
|
||||||
}
|
}
|
||||||
|
|
41
protocol.cpp
41
protocol.cpp
|
@ -83,23 +83,33 @@ void Protocol::sendBody(const Bytes& body, const u64& id) {
|
||||||
return sendBody(body, addrOfId(id));
|
return sendBody(body, addrOfId(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Protocol::sendEmpty(u64 to) {
|
void Protocol::sendEmpty(const SockAddr& to) {
|
||||||
sendBody(Bytes(), to);
|
sendBody(Bytes(), to);
|
||||||
}
|
}
|
||||||
|
void Protocol::sendEmpty(u64 to) {
|
||||||
void Protocol::sendIHU(u64 id) {
|
sendEmpty(addrOfId(to));
|
||||||
Bytes pck;
|
|
||||||
pck << csts::TLV_IHU << (u8) 8 << id;
|
|
||||||
sendBody(pck, id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Protocol::sendNReq(u64 to) {
|
void Protocol::sendIHU(const SockAddr& to, u64 id) {
|
||||||
|
Bytes pck;
|
||||||
|
pck << csts::TLV_IHU << (u8) 8 << id;
|
||||||
|
sendBody(pck, to);
|
||||||
|
}
|
||||||
|
void Protocol::sendIHU(u64 id) {
|
||||||
|
sendIHU(addrOfId(id), id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Protocol::sendNReq(const SockAddr& to) {
|
||||||
Bytes pck;
|
Bytes pck;
|
||||||
pck << csts::TLV_NR << (u8) 0;
|
pck << csts::TLV_NR << (u8) 0;
|
||||||
sendBody(pck, to);
|
sendBody(pck, to);
|
||||||
}
|
}
|
||||||
|
void Protocol::sendNReq(u64 id) {
|
||||||
|
sendNReq(addrOfId(id));
|
||||||
|
}
|
||||||
|
|
||||||
void Protocol::sendNeighbours(u64 to, const std::vector<Neighbour>& neigh) {
|
void Protocol::sendNeighbours(const SockAddr& to,
|
||||||
|
const std::vector<Neighbour>& neigh) {
|
||||||
Bytes pck;
|
Bytes pck;
|
||||||
u8 len = neigh.size() * (8+16+2);
|
u8 len = neigh.size() * (8+16+2);
|
||||||
pck << csts::TLV_NEIGH << len;
|
pck << csts::TLV_NEIGH << len;
|
||||||
|
@ -114,8 +124,11 @@ void Protocol::sendNeighbours(u64 to, const std::vector<Neighbour>& neigh) {
|
||||||
|
|
||||||
sendBody(pck, to);
|
sendBody(pck, to);
|
||||||
}
|
}
|
||||||
|
void Protocol::sendNeighbours(u64 id, const std::vector<Neighbour>& neigh) {
|
||||||
|
sendNeighbours(addrOfId(id), neigh);
|
||||||
|
}
|
||||||
|
|
||||||
void Protocol::sendData(u64 to, const Bytes& data,
|
void Protocol::sendData(const SockAddr& to, const Bytes& data,
|
||||||
u32 seqno, u64 datId)
|
u32 seqno, u64 datId)
|
||||||
{
|
{
|
||||||
Bytes pck;
|
Bytes pck;
|
||||||
|
@ -125,12 +138,20 @@ void Protocol::sendData(u64 to, const Bytes& data,
|
||||||
<< data;
|
<< data;
|
||||||
sendBody(pck, to);
|
sendBody(pck, to);
|
||||||
}
|
}
|
||||||
|
void Protocol::sendData(u64 id, const Bytes& data, u32 seqno,
|
||||||
|
u64 datId)
|
||||||
|
{
|
||||||
|
sendData(addrOfId(id), data, seqno, datId);
|
||||||
|
}
|
||||||
|
|
||||||
void Protocol::sendIHave(u64 to, u64 datId, u32 seqno) {
|
void Protocol::sendIHave(const SockAddr& to, u64 datId, u32 seqno) {
|
||||||
Bytes pck;
|
Bytes pck;
|
||||||
pck << csts::TLV_IHAVE << (u8) 12 << seqno << datId;
|
pck << csts::TLV_IHAVE << (u8) 12 << seqno << datId;
|
||||||
sendBody(pck, to);
|
sendBody(pck, to);
|
||||||
}
|
}
|
||||||
|
void Protocol::sendIHave(u64 id, u64 datId, u32 seqno) {
|
||||||
|
sendIHave(addrOfId(id), datId, seqno);
|
||||||
|
}
|
||||||
|
|
||||||
void Protocol::startPollNetwork() {
|
void Protocol::startPollNetwork() {
|
||||||
pollThread = std::thread([this] { this->pollNetwork(); });
|
pollThread = std::thread([this] { this->pollNetwork(); });
|
||||||
|
|
|
@ -44,20 +44,28 @@ class Protocol {
|
||||||
void sendBody(const Bytes& body, const u64& id);
|
void sendBody(const Bytes& body, const u64& id);
|
||||||
/** Sends the given `body` (wrapped in headers) */
|
/** Sends the given `body` (wrapped in headers) */
|
||||||
|
|
||||||
|
void sendEmpty(const SockAddr& to);
|
||||||
void sendEmpty(u64 to);
|
void sendEmpty(u64 to);
|
||||||
|
|
||||||
|
void sendIHU(const SockAddr& to, u64 id);
|
||||||
void sendIHU(u64 id);
|
void sendIHU(u64 id);
|
||||||
/** Sends a IHU packet */
|
/** Sends a IHU packet */
|
||||||
|
|
||||||
|
void sendNReq(const SockAddr& to);
|
||||||
void sendNReq(u64 id);
|
void sendNReq(u64 id);
|
||||||
/** Sends a neighbour request packet */
|
/** Sends a neighbour request packet */
|
||||||
|
|
||||||
|
void sendNeighbours(const SockAddr& to,
|
||||||
|
const std::vector<Neighbour>& neigh);
|
||||||
void sendNeighbours(u64 id,
|
void sendNeighbours(u64 id,
|
||||||
const std::vector<Neighbour>& neigh);
|
const std::vector<Neighbour>& neigh);
|
||||||
/** Sends a neighbours list packet */
|
/** Sends a neighbours list packet */
|
||||||
|
|
||||||
|
void sendData(const SockAddr& to, const Bytes& data,
|
||||||
|
u32 seqno, u64 datId);
|
||||||
void sendData(u64 id, const Bytes& data, u32 seqno, u64 datId);
|
void sendData(u64 id, const Bytes& data, u32 seqno, u64 datId);
|
||||||
|
|
||||||
|
void sendIHave(const SockAddr& to, u64 datId, u32 seqno);
|
||||||
void sendIHave(u64 id, u64 datId, u32 seqno);
|
void sendIHave(u64 id, u64 datId, u32 seqno);
|
||||||
/** Sends a IHave packet for `datId` */
|
/** Sends a IHave packet for `datId` */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue