mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-05-06 08:05:18 -04:00
almost done with load/save of BanLists. Changed the item format to include masked_bytes, and changed subitem types. Also disabled code from rsgxsreputationitems.cc wich was a copy of the code from rsbanlistitems.cc
git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@8316 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
4ebc87b9c2
commit
20a2d42038
9 changed files with 376 additions and 68 deletions
|
@ -1420,10 +1420,10 @@ void RsGenExchange::notifyNewGroups(std::vector<RsNxsGrp *> &groups)
|
||||||
// TODO: move this to nxs layer to save bandwidth
|
// TODO: move this to nxs layer to save bandwidth
|
||||||
if(received == mReceivedGrps.end())
|
if(received == mReceivedGrps.end())
|
||||||
{
|
{
|
||||||
//#ifdef GEN_EXCH_DEBUG
|
#ifdef GEN_EXCH_DEBUG
|
||||||
std::cerr << "RsGenExchange::notifyNewGroups() Received GrpId: " << grp->grpId;
|
std::cerr << "RsGenExchange::notifyNewGroups() Received GrpId: " << grp->grpId;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
//#endif
|
#endif
|
||||||
|
|
||||||
GxsPendingItem<RsNxsGrp*, RsGxsGroupId> gpsi(grp, grp->grpId);
|
GxsPendingItem<RsNxsGrp*, RsGxsGroupId> gpsi(grp, grp->grpId);
|
||||||
mReceivedGrps.push_back(gpsi);
|
mReceivedGrps.push_back(gpsi);
|
||||||
|
|
|
@ -40,11 +40,15 @@ extern RsBanList *rsBanList ;
|
||||||
#define RSBANLIST_REASON_DHT 2
|
#define RSBANLIST_REASON_DHT 2
|
||||||
#define RSBANLIST_REASON_AUTO_RANGE 3
|
#define RSBANLIST_REASON_AUTO_RANGE 3
|
||||||
|
|
||||||
|
class RsTlvBanListEntry ;
|
||||||
|
|
||||||
class BanListPeer
|
class BanListPeer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
BanListPeer() ;
|
BanListPeer() ;
|
||||||
|
|
||||||
|
void toRsTlvBanListEntry(RsTlvBanListEntry& e) const ;
|
||||||
|
void fromRsTlvBanListEntry(const RsTlvBanListEntry& e) ;
|
||||||
|
|
||||||
struct sockaddr_storage addr;
|
struct sockaddr_storage addr;
|
||||||
uint8_t masked_bytes ; // 0 = []/32. 1=[]/24, 2=[]/16
|
uint8_t masked_bytes ; // 0 = []/32. 1=[]/24, 2=[]/16
|
||||||
|
|
|
@ -64,6 +64,15 @@ uint32_t RsBanListSerialiser::sizeList(RsBanListItem *item)
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t RsBanListSerialiser::sizeListConfig(RsBanListConfigItem *item)
|
||||||
|
{
|
||||||
|
uint32_t s = 8; /* header */
|
||||||
|
s += item->banned_peers.TlvSize();
|
||||||
|
s += 8 ; // update time
|
||||||
|
s += item->peerId.serial_size() ;
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
/* serialise the data to the buffer */
|
/* serialise the data to the buffer */
|
||||||
bool RsBanListSerialiser::serialiseList(RsBanListItem *item, void *data, uint32_t *pktsize)
|
bool RsBanListSerialiser::serialiseList(RsBanListItem *item, void *data, uint32_t *pktsize)
|
||||||
{
|
{
|
||||||
|
@ -100,7 +109,45 @@ bool RsBanListSerialiser::serialiseList(RsBanListItem *item, void *data, uin
|
||||||
|
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
/* serialise the data to the buffer */
|
||||||
|
bool RsBanListSerialiser::serialiseListConfig(RsBanListConfigItem *item, void *data, uint32_t *pktsize)
|
||||||
|
{
|
||||||
|
uint32_t tlvsize = sizeListConfig(item);
|
||||||
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
if (*pktsize < tlvsize)
|
||||||
|
return false; /* not enough space */
|
||||||
|
|
||||||
|
*pktsize = tlvsize;
|
||||||
|
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
ok &= setRsItemHeader(data, tlvsize, item->PacketId(), tlvsize);
|
||||||
|
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsBanListSerialiser::serialiseRoute() Header: " << ok << std::endl;
|
||||||
|
std::cerr << "RsBanListSerialiser::serialiseRoute() Size: " << tlvsize << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* skip the header */
|
||||||
|
offset += 8;
|
||||||
|
|
||||||
|
ok &= item->peerId.serialise(data, tlvsize, offset);
|
||||||
|
ok &= setRawTimeT(data, tlvsize, &offset,item->update_time);
|
||||||
|
|
||||||
|
/* add mandatory parts first */
|
||||||
|
ok &= item->banned_peers.SetTlv(data, tlvsize, &offset);
|
||||||
|
|
||||||
|
if (offset != tlvsize)
|
||||||
|
{
|
||||||
|
ok = false;
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsBanListSerialiser::serialiseRoute() Size Error! " << std::endl;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
return ok;
|
||||||
|
}
|
||||||
RsBanListItem *RsBanListSerialiser::deserialiseList(void *data, uint32_t *pktsize)
|
RsBanListItem *RsBanListSerialiser::deserialiseList(void *data, uint32_t *pktsize)
|
||||||
{
|
{
|
||||||
/* get the type and size */
|
/* get the type and size */
|
||||||
|
@ -150,28 +197,91 @@ RsBanListItem *RsBanListSerialiser::deserialiseList(void *data, uint32_t *pktsiz
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
RsBanListConfigItem *RsBanListSerialiser::deserialiseListConfig(void *data, uint32_t *pktsize)
|
||||||
|
{
|
||||||
|
/* get the type and size */
|
||||||
|
uint32_t rstype = getRsItemId(data);
|
||||||
|
uint32_t tlvsize = getRsItemSize(data);
|
||||||
|
|
||||||
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
|
||||||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) ||
|
||||||
|
(RS_SERVICE_TYPE_BANLIST != getRsItemService(rstype)) ||
|
||||||
|
(RS_PKT_SUBTYPE_BANLIST_CONFIG_ITEM != getRsItemSubType(rstype)))
|
||||||
|
{
|
||||||
|
return NULL; /* wrong type */
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*pktsize < tlvsize) /* check size */
|
||||||
|
return NULL; /* not enough data */
|
||||||
|
|
||||||
|
/* set the packet length */
|
||||||
|
*pktsize = tlvsize;
|
||||||
|
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
/* ready to load */
|
||||||
|
RsBanListConfigItem *item = new RsBanListConfigItem();
|
||||||
|
item->clear();
|
||||||
|
|
||||||
|
/* skip the header */
|
||||||
|
offset += 8;
|
||||||
|
|
||||||
|
ok &= item->peerId.deserialise(data, tlvsize, offset);
|
||||||
|
ok &= getRawTimeT(data, tlvsize, &offset,item->update_time);
|
||||||
|
|
||||||
|
/* add mandatory parts first */
|
||||||
|
ok &= item->banned_peers.GetTlv(data, tlvsize, &offset);
|
||||||
|
|
||||||
|
if (offset != tlvsize)
|
||||||
|
{
|
||||||
|
/* error */
|
||||||
|
delete item;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ok)
|
||||||
|
{
|
||||||
|
delete item;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
uint32_t RsBanListSerialiser::size(RsItem *i)
|
uint32_t RsBanListSerialiser::size(RsItem *i)
|
||||||
{
|
{
|
||||||
RsBanListItem *dri;
|
RsBanListItem *dri;
|
||||||
|
RsBanListConfigItem *drc;
|
||||||
|
|
||||||
if (NULL != (dri = dynamic_cast<RsBanListItem *>(i)))
|
if (NULL != (dri = dynamic_cast<RsBanListItem *>(i)))
|
||||||
{
|
{
|
||||||
return sizeList(dri);
|
return sizeList(dri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (NULL != (drc = dynamic_cast<RsBanListConfigItem *>(i)))
|
||||||
|
{
|
||||||
|
return sizeListConfig(drc);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RsBanListSerialiser::serialise(RsItem *i, void *data, uint32_t *pktsize)
|
bool RsBanListSerialiser::serialise(RsItem *i, void *data, uint32_t *pktsize)
|
||||||
{
|
{
|
||||||
RsBanListItem *dri;
|
RsBanListItem *dri;
|
||||||
|
RsBanListConfigItem *drc;
|
||||||
|
|
||||||
if (NULL != (dri = dynamic_cast<RsBanListItem *>(i)))
|
if (NULL != (dri = dynamic_cast<RsBanListItem *>(i)))
|
||||||
{
|
{
|
||||||
return serialiseList(dri, data, pktsize);
|
return serialiseList(dri, data, pktsize);
|
||||||
}
|
}
|
||||||
|
if (NULL != (drc = dynamic_cast<RsBanListConfigItem *>(i)))
|
||||||
|
{
|
||||||
|
return serialiseListConfig(drc, data, pktsize);
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,12 +301,30 @@ RsItem *RsBanListSerialiser::deserialise(void *data, uint32_t *pktsize)
|
||||||
case RS_PKT_SUBTYPE_BANLIST_ITEM:
|
case RS_PKT_SUBTYPE_BANLIST_ITEM:
|
||||||
return deserialiseList(data, pktsize);
|
return deserialiseList(data, pktsize);
|
||||||
break;
|
break;
|
||||||
|
case RS_PKT_SUBTYPE_BANLIST_CONFIG_ITEM:
|
||||||
|
return deserialiseListConfig(data, pktsize);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return NULL;
|
return NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RsBanListConfigItem::clear()
|
||||||
|
{
|
||||||
|
banned_peers.TlvClear() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::ostream &RsBanListConfigItem::print(std::ostream &out, uint16_t indent)
|
||||||
|
{
|
||||||
|
printRsItemBase(out, "RsBanListConfigItem", indent);
|
||||||
|
uint16_t int_Indent = indent + 2;
|
||||||
|
banned_peers.print(out, int_Indent);
|
||||||
|
|
||||||
|
printRsItemEnd(out, "RsBanListConfigItem", indent);
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,9 @@
|
||||||
#include "serialiser/rsserial.h"
|
#include "serialiser/rsserial.h"
|
||||||
#include "serialiser/rstlvbanlist.h"
|
#include "serialiser/rstlvbanlist.h"
|
||||||
|
|
||||||
#define RS_PKT_SUBTYPE_BANLIST_ITEM 0x01
|
#define RS_PKT_SUBTYPE_BANLIST_ITEM_deprecated 0x01
|
||||||
|
#define RS_PKT_SUBTYPE_BANLIST_CONFIG_ITEM 0x02
|
||||||
|
#define RS_PKT_SUBTYPE_BANLIST_ITEM 0x03
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
|
@ -47,33 +49,51 @@ class RsBanListItem: public RsItem
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~RsBanListItem();
|
virtual ~RsBanListItem();
|
||||||
virtual void clear();
|
virtual void clear();
|
||||||
std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
||||||
|
|
||||||
RsTlvBanList peerList;
|
RsTlvBanList peerList;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class RsBanListConfigItem: public RsItem
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsBanListConfigItem()
|
||||||
|
:RsItem(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_BANLIST, RS_PKT_SUBTYPE_BANLIST_CONFIG_ITEM) {}
|
||||||
|
|
||||||
|
virtual ~RsBanListConfigItem(){}
|
||||||
|
virtual void clear();
|
||||||
|
|
||||||
|
std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
||||||
|
|
||||||
|
RsPeerId peerId ;
|
||||||
|
time_t update_time ;
|
||||||
|
RsTlvBanList banned_peers;
|
||||||
|
};
|
||||||
|
|
||||||
class RsBanListSerialiser: public RsSerialType
|
class RsBanListSerialiser: public RsSerialType
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RsBanListSerialiser()
|
RsBanListSerialiser()
|
||||||
:RsSerialType(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_BANLIST)
|
:RsSerialType(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_BANLIST)
|
||||||
{ return; }
|
{ return; }
|
||||||
virtual ~RsBanListSerialiser()
|
virtual ~RsBanListSerialiser()
|
||||||
{ return; }
|
{ return; }
|
||||||
|
|
||||||
virtual uint32_t size(RsItem *);
|
virtual uint32_t size(RsItem *);
|
||||||
virtual bool serialise (RsItem *item, void *data, uint32_t *size);
|
virtual bool serialise (RsItem *item, void *data, uint32_t *size);
|
||||||
virtual RsItem * deserialise(void *data, uint32_t *size);
|
virtual RsItem * deserialise(void *data, uint32_t *size);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
virtual uint32_t sizeList(RsBanListItem *);
|
virtual uint32_t sizeList(RsBanListItem *);
|
||||||
virtual bool serialiseList (RsBanListItem *item, void *data, uint32_t *size);
|
virtual bool serialiseList (RsBanListItem *item, void *data, uint32_t *size);
|
||||||
virtual RsBanListItem *deserialiseList(void *data, uint32_t *size);
|
virtual RsBanListItem *deserialiseList(void *data, uint32_t *size);
|
||||||
|
|
||||||
|
virtual uint32_t sizeListConfig(RsBanListConfigItem *);
|
||||||
|
virtual bool serialiseListConfig (RsBanListConfigItem *item, void *data, uint32_t *size);
|
||||||
|
virtual RsBanListConfigItem *deserialiseListConfig(void *data, uint32_t *size);
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
|
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
|
#ifdef SUSPENDED
|
||||||
RsBanListItem::~RsBanListItem()
|
RsBanListItem::~RsBanListItem()
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -197,6 +198,7 @@ RsItem *RsBanListSerialiser::deserialise(void *data, uint32_t *pktsize)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -54,6 +54,7 @@ uint32_t RsTlvBanListEntry::TlvSize() const
|
||||||
s += 4; // level;
|
s += 4; // level;
|
||||||
s += 4; // reason;
|
s += 4; // reason;
|
||||||
s += 4; // age;
|
s += 4; // age;
|
||||||
|
s += 1; // masked_bytes;
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
|
|
||||||
|
@ -79,6 +80,8 @@ bool RsTlvBanListEntry::SetTlv(void *data, uint32_t size, uint32_t *offset) con
|
||||||
ok &= setRawUInt32(data, tlvend, offset, level);
|
ok &= setRawUInt32(data, tlvend, offset, level);
|
||||||
ok &= setRawUInt32(data, tlvend, offset, reason);
|
ok &= setRawUInt32(data, tlvend, offset, reason);
|
||||||
ok &= setRawUInt32(data, tlvend, offset, age);
|
ok &= setRawUInt32(data, tlvend, offset, age);
|
||||||
|
ok &= setRawUInt8(data, tlvend, offset, masked_bytes);
|
||||||
|
|
||||||
return ok;
|
return ok;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -112,6 +115,10 @@ bool RsTlvBanListEntry::GetTlv(void *data, uint32_t size, uint32_t *offset)
|
||||||
ok &= getRawUInt32(data, tlvend, offset, &(reason));
|
ok &= getRawUInt32(data, tlvend, offset, &(reason));
|
||||||
ok &= getRawUInt32(data, tlvend, offset, &(age));
|
ok &= getRawUInt32(data, tlvend, offset, &(age));
|
||||||
|
|
||||||
|
uint8_t tmp ;
|
||||||
|
ok &= getRawUInt8(data, tlvend, offset, &(tmp));
|
||||||
|
masked_bytes = tmp ;
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* NB: extra components could be added (for future expansion of the type).
|
* NB: extra components could be added (for future expansion of the type).
|
||||||
* or be present (if this code is reading an extended version).
|
* or be present (if this code is reading an extended version).
|
||||||
|
@ -153,8 +160,13 @@ std::ostream &RsTlvBanListEntry::print(std::ostream &out, uint16_t indent) const
|
||||||
out << "age:" << age;
|
out << "age:" << age;
|
||||||
out << std::endl;
|
out << std::endl;
|
||||||
|
|
||||||
|
printIndent(out, int_Indent);
|
||||||
|
out << "masked bytes:" << masked_bytes;
|
||||||
|
out << std::endl;
|
||||||
|
|
||||||
printEnd(out, "RsTlvBanListEntry", indent);
|
printEnd(out, "RsTlvBanListEntry", indent);
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,6 @@ virtual std::ostream &print(std::ostream &out, uint16_t indent) const;
|
||||||
uint8_t masked_bytes ;
|
uint8_t masked_bytes ;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
typedef t_RsTlvList<RsTlvBanListEntry,TLV_TYPE_BAN_LIST> RsTlvBanList;
|
typedef t_RsTlvList<RsTlvBanListEntry,TLV_TYPE_BAN_LIST> RsTlvBanList;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -25,11 +25,13 @@
|
||||||
|
|
||||||
#include "pqi/p3servicecontrol.h"
|
#include "pqi/p3servicecontrol.h"
|
||||||
#include "pqi/p3netmgr.h"
|
#include "pqi/p3netmgr.h"
|
||||||
|
#include "pqi/p3cfgmgr.h"
|
||||||
|
|
||||||
#include "util/rsnet.h"
|
#include "util/rsnet.h"
|
||||||
|
|
||||||
#include "services/p3banlist.h"
|
#include "services/p3banlist.h"
|
||||||
#include "serialiser/rsbanlistitems.h"
|
#include "serialiser/rsbanlistitems.h"
|
||||||
|
#include "serialiser/rsconfigitems.h"
|
||||||
#include "retroshare/rsdht.h"
|
#include "retroshare/rsdht.h"
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
@ -129,6 +131,27 @@ BanListPeer::BanListPeer()
|
||||||
mTs=0;
|
mTs=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BanListPeer::toRsTlvBanListEntry(RsTlvBanListEntry &e) const
|
||||||
|
{
|
||||||
|
e.addr.addr = addr;
|
||||||
|
e.level = level;
|
||||||
|
e.reason = reason;
|
||||||
|
e.masked_bytes = masked_bytes;
|
||||||
|
e.age = time(NULL) - mTs;
|
||||||
|
}
|
||||||
|
|
||||||
|
void BanListPeer::fromRsTlvBanListEntry(const RsTlvBanListEntry &e)
|
||||||
|
{
|
||||||
|
addr = e.addr.addr;
|
||||||
|
masked_bytes = e.masked_bytes; // 0 = []/32. 1=[]/24, 2=[]/16
|
||||||
|
reason = e.reason; // User, DHT
|
||||||
|
level = e.level; // LOCAL, FRIEND, FoF.
|
||||||
|
state = true; // true=>active, false=>just stored but inactive
|
||||||
|
connect_attempts = 0; // recorded by the BanList service
|
||||||
|
mTs = time(NULL) - e.age;
|
||||||
|
comment.clear() ; //
|
||||||
|
}
|
||||||
|
|
||||||
static sockaddr_storage makeBitsRange(const sockaddr_storage& addr,int masked_bytes)
|
static sockaddr_storage makeBitsRange(const sockaddr_storage& addr,int masked_bytes)
|
||||||
{
|
{
|
||||||
sockaddr_storage s ;
|
sockaddr_storage s ;
|
||||||
|
@ -166,8 +189,9 @@ void p3BanList::autoFigureOutBanRanges()
|
||||||
|
|
||||||
if(!mAutoRangeIps)
|
if(!mAutoRangeIps)
|
||||||
return ;
|
return ;
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << "Automatically figuring out IP ranges from banned IPs." << std::endl;
|
std::cerr << "Automatically figuring out IP ranges from banned IPs." << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
std::map<sockaddr_storage,ZeroedInt> range_map ;
|
std::map<sockaddr_storage,ZeroedInt> range_map ;
|
||||||
|
|
||||||
|
@ -178,11 +202,15 @@ void p3BanList::autoFigureOutBanRanges()
|
||||||
|
|
||||||
for(std::map<sockaddr_storage,ZeroedInt>::const_iterator it=range_map.begin();it!=range_map.end();++it)
|
for(std::map<sockaddr_storage,ZeroedInt>::const_iterator it=range_map.begin();it!=range_map.end();++it)
|
||||||
{
|
{
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << "Ban range: " << sockaddr_storage_iptostring(it->first) << " : " << it->second.n << std::endl;
|
std::cerr << "Ban range: " << sockaddr_storage_iptostring(it->first) << " : " << it->second.n << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
if(it->second.n >= mAutoRangeLimit)
|
if(it->second.n >= mAutoRangeLimit)
|
||||||
{
|
{
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " --> creating new ban range." << std::endl;
|
std::cerr << " --> creating new ban range." << std::endl;
|
||||||
|
#endif
|
||||||
BanListPeer& peer(mBanRanges[it->first]) ;
|
BanListPeer& peer(mBanRanges[it->first]) ;
|
||||||
|
|
||||||
if(peer.reason == RSBANLIST_REASON_USER)
|
if(peer.reason == RSBANLIST_REASON_USER)
|
||||||
|
@ -212,32 +240,42 @@ bool p3BanList::isAddressAccepted(const sockaddr_storage &addr)
|
||||||
sockaddr_storage addr_24 = makeBitsRange(addr,1) ;
|
sockaddr_storage addr_24 = makeBitsRange(addr,1) ;
|
||||||
sockaddr_storage addr_16 = makeBitsRange(addr,2) ;
|
sockaddr_storage addr_16 = makeBitsRange(addr,2) ;
|
||||||
|
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << "p3BanList::isAddressAccepted() testing " << sockaddr_storage_iptostring(addr) << " and range " << sockaddr_storage_iptostring(addr_24) ;
|
std::cerr << "p3BanList::isAddressAccepted() testing " << sockaddr_storage_iptostring(addr) << " and range " << sockaddr_storage_iptostring(addr_24) ;
|
||||||
|
#endif
|
||||||
|
|
||||||
std::map<sockaddr_storage,BanListPeer>::iterator it ;
|
std::map<sockaddr_storage,BanListPeer>::iterator it ;
|
||||||
|
|
||||||
if((it=mBanRanges.find(addr_16)) != mBanRanges.end())
|
if((it=mBanRanges.find(addr_16)) != mBanRanges.end())
|
||||||
{
|
{
|
||||||
++it->second.connect_attempts;
|
++it->second.connect_attempts;
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
||||||
|
#endif
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((it=mBanRanges.find(addr_24)) != mBanRanges.end())
|
if((it=mBanRanges.find(addr_24)) != mBanRanges.end())
|
||||||
{
|
{
|
||||||
++it->second.connect_attempts;
|
++it->second.connect_attempts;
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
||||||
|
#endif
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((it=mBanSet.find(addr)) != mBanSet.end())
|
if((it=mBanSet.find(addr)) != mBanSet.end())
|
||||||
{
|
{
|
||||||
++it->second.connect_attempts;
|
++it->second.connect_attempts;
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
std::cerr << " returning false. attempts=" << it->second.connect_attempts << std::endl;
|
||||||
|
#endif
|
||||||
return false ;
|
return false ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " returning true " << std::endl;
|
std::cerr << " returning true " << std::endl;
|
||||||
|
#endif
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -313,12 +351,16 @@ void p3BanList::getDhtInfo()
|
||||||
|
|
||||||
rsDht->getListOfBannedIps(filtered_peers) ;
|
rsDht->getListOfBannedIps(filtered_peers) ;
|
||||||
|
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << "p3BanList::getDhtInfo() Got list of banned IPs." << std::endl;
|
std::cerr << "p3BanList::getDhtInfo() Got list of banned IPs." << std::endl;
|
||||||
|
#endif
|
||||||
RsPeerId ownId = mServiceCtrl->getOwnId();
|
RsPeerId ownId = mServiceCtrl->getOwnId();
|
||||||
|
|
||||||
for(std::list<RsDhtFilteredPeer>::const_iterator it(filtered_peers.begin());it!=filtered_peers.end();++it)
|
for(std::list<RsDhtFilteredPeer>::const_iterator it(filtered_peers.begin());it!=filtered_peers.end();++it)
|
||||||
{
|
{
|
||||||
|
#ifdef DEBUG_BANLIST
|
||||||
std::cerr << " filtered peer: " << rs_inet_ntoa((*it).mAddr.sin_addr) << std::endl;
|
std::cerr << " filtered peer: " << rs_inet_ntoa((*it).mAddr.sin_addr) << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
int int_reason = RSBANLIST_REASON_DHT ;
|
int int_reason = RSBANLIST_REASON_DHT ;
|
||||||
int time_stamp = (*it).mLastSeen ;
|
int time_stamp = (*it).mLastSeen ;
|
||||||
|
@ -387,7 +429,7 @@ bool p3BanList::recvBanItem(RsBanListItem *item)
|
||||||
|
|
||||||
time_t now = time(NULL) ;
|
time_t now = time(NULL) ;
|
||||||
std::list<RsTlvBanListEntry>::const_iterator it;
|
std::list<RsTlvBanListEntry>::const_iterator it;
|
||||||
//for(it = item->peerList.entries.begin(); it != item->peerList.entries.end(); ++it)
|
|
||||||
for(it = item->peerList.mList.begin(); it != item->peerList.mList.end(); ++it)
|
for(it = item->peerList.mList.begin(); it != item->peerList.mList.end(); ++it)
|
||||||
{
|
{
|
||||||
// Order is important!.
|
// Order is important!.
|
||||||
|
@ -413,6 +455,108 @@ void p3BanList::updatePeer(const RsPeerId& /*id*/, const struct sockaddr_storage
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RsSerialiser *p3BanList::setupSerialiser()
|
||||||
|
{
|
||||||
|
RsSerialiser *rss = new RsSerialiser ;
|
||||||
|
|
||||||
|
rss->addSerialType(new RsBanListSerialiser()) ;
|
||||||
|
rss->addSerialType(new RsGeneralConfigSerialiser());
|
||||||
|
|
||||||
|
return rss ;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3BanList::saveList(bool &cleanup, std::list<RsItem*>& itemlist)
|
||||||
|
{
|
||||||
|
RsStackMutex stack(mBanMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
|
cleanup = true ;
|
||||||
|
|
||||||
|
for(std::map<RsPeerId,BanList>::const_iterator it(mBanSources.begin());it!=mBanSources.end();++it)
|
||||||
|
{
|
||||||
|
RsBanListConfigItem *item = new RsBanListConfigItem ;
|
||||||
|
|
||||||
|
item->peerId = it->second.mPeerId ;
|
||||||
|
item->update_time = it->second.mLastUpdate ;
|
||||||
|
item->banned_peers.TlvClear() ;
|
||||||
|
|
||||||
|
for(std::map<sockaddr_storage,BanListPeer>::const_iterator it2 = it->second.mBanPeers.begin();it2!=it->second.mBanPeers.end();++it2)
|
||||||
|
{
|
||||||
|
RsTlvBanListEntry e ;
|
||||||
|
it2->second.toRsTlvBanListEntry(e) ;
|
||||||
|
|
||||||
|
item->banned_peers.mList.push_back(e) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
itemlist.push_back(item) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
RsConfigKeyValueSet *vitem = new RsConfigKeyValueSet ;
|
||||||
|
|
||||||
|
RsTlvKeyValue kv;
|
||||||
|
|
||||||
|
kv.key = "IP_FILTERING_ENABLED";
|
||||||
|
kv.value = mIPFilteringEnabled?"TRUE":"FALSE" ;
|
||||||
|
vitem->tlvkvs.pairs.push_back(kv) ;
|
||||||
|
|
||||||
|
kv.key = "IP_FILTERING_AUTORANGE_IPS";
|
||||||
|
kv.value = mAutoRangeIps?"TRUE":"FALSE" ;
|
||||||
|
vitem->tlvkvs.pairs.push_back(kv) ;
|
||||||
|
|
||||||
|
kv.key = "IP_FILTERING_FRIEND_GATHERING_ENABLED";
|
||||||
|
kv.value = mIPFriendGatheringEnabled?"TRUE":"FALSE" ;
|
||||||
|
vitem->tlvkvs.pairs.push_back(kv) ;
|
||||||
|
|
||||||
|
kv.key = "IP_FILTERING_DHT_GATHERING_ENABLED";
|
||||||
|
kv.value = mIPDHTGatheringEnabled?"TRUE":"FALSE" ;
|
||||||
|
vitem->tlvkvs.pairs.push_back(kv) ;
|
||||||
|
|
||||||
|
itemlist.push_back(vitem) ;
|
||||||
|
|
||||||
|
return true ;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool p3BanList::loadList(std::list<RsItem*>& load)
|
||||||
|
{
|
||||||
|
RsStackMutex stack(mBanMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
|
for(std::list<RsItem*>::const_iterator it(load.begin());it!=load.end();++it)
|
||||||
|
{
|
||||||
|
RsConfigKeyValueSet *vitem = dynamic_cast<RsConfigKeyValueSet*>( *it ) ;
|
||||||
|
|
||||||
|
if(vitem != NULL)
|
||||||
|
for(std::list<RsTlvKeyValue>::const_iterator it2(vitem->tlvkvs.pairs.begin());it2!=vitem->tlvkvs.pairs.end();++it2)
|
||||||
|
{
|
||||||
|
if(it2->key == "IP_FILTERING_ENABLED") mIPFilteringEnabled = (it2->value=="TRUE") ;
|
||||||
|
if(it2->key == "IP_FILTERING_AUTORANGE_IPS") mAutoRangeIps = (it2->value=="TRUE") ;
|
||||||
|
if(it2->key == "IP_FILTERING_FRIEND_GATHERING_ENABLED") mIPFriendGatheringEnabled = (it2->value=="TRUE") ;
|
||||||
|
if(it2->key == "IP_FILTERING_DHT_GATHERING_ENABLED") mIPDHTGatheringEnabled = (it2->value=="TRUE") ;
|
||||||
|
}
|
||||||
|
|
||||||
|
RsBanListConfigItem *citem = dynamic_cast<RsBanListConfigItem*>( *it ) ;
|
||||||
|
|
||||||
|
if(citem != NULL)
|
||||||
|
{
|
||||||
|
BanList& bl(mBanSources[citem->peerId]) ;
|
||||||
|
|
||||||
|
bl.mPeerId = citem->peerId ;
|
||||||
|
bl.mLastUpdate = citem->update_time ;
|
||||||
|
|
||||||
|
bl.mBanPeers.clear() ;
|
||||||
|
|
||||||
|
for(std::list<RsTlvBanListEntry>::const_iterator it2(citem->banned_peers.mList.begin());it2!=citem->banned_peers.mList.end();++it2)
|
||||||
|
{
|
||||||
|
BanListPeer blp ;
|
||||||
|
blp.fromRsTlvBanListEntry(*it2) ;
|
||||||
|
|
||||||
|
bl.mBanPeers[blp.addr] = blp ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delete *it ;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true ;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3BanList::addBanEntry(const RsPeerId &peerId, const struct sockaddr_storage &addr,
|
bool p3BanList::addBanEntry(const RsPeerId &peerId, const struct sockaddr_storage &addr,
|
||||||
int level, uint32_t reason, time_t time_stamp,uint8_t masked_bytes)
|
int level, uint32_t reason, time_t time_stamp,uint8_t masked_bytes)
|
||||||
|
@ -506,7 +650,7 @@ int p3BanList::condenseBanSources_locked()
|
||||||
{
|
{
|
||||||
mBanSet.clear();
|
mBanSet.clear();
|
||||||
|
|
||||||
time_t now = time(NULL);
|
// time_t now = time(NULL);
|
||||||
RsPeerId ownId = mServiceCtrl->getOwnId();
|
RsPeerId ownId = mServiceCtrl->getOwnId();
|
||||||
|
|
||||||
#ifdef DEBUG_BANLIST
|
#ifdef DEBUG_BANLIST
|
||||||
|
@ -674,7 +818,7 @@ int p3BanList::sendBanSet(const RsPeerId& peerid)
|
||||||
RsBanListItem *item = new RsBanListItem();
|
RsBanListItem *item = new RsBanListItem();
|
||||||
item->PeerId(peerid);
|
item->PeerId(peerid);
|
||||||
|
|
||||||
time_t now = time(NULL);
|
//time_t now = time(NULL);
|
||||||
|
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mBanMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mBanMtx); /****** LOCKED MUTEX *******/
|
||||||
|
@ -682,17 +826,11 @@ int p3BanList::sendBanSet(const RsPeerId& peerid)
|
||||||
for(it = mBanSet.begin(); it != mBanSet.end(); ++it)
|
for(it = mBanSet.begin(); it != mBanSet.end(); ++it)
|
||||||
{
|
{
|
||||||
if (it->second.level >= RSBANLIST_ORIGIN_FRIEND)
|
if (it->second.level >= RSBANLIST_ORIGIN_FRIEND)
|
||||||
{
|
|
||||||
continue; // only share OWN for the moment.
|
continue; // only share OWN for the moment.
|
||||||
}
|
|
||||||
|
|
||||||
RsTlvBanListEntry bi;
|
RsTlvBanListEntry bi;
|
||||||
bi.addr.addr = it->second.addr;
|
it->second.toRsTlvBanListEntry(bi) ;
|
||||||
bi.reason = it->second.reason;
|
|
||||||
bi.level = it->second.level;
|
|
||||||
bi.age = now - it->second.mTs;
|
|
||||||
|
|
||||||
//item->peerList.entries.push_back(bi);
|
|
||||||
item->peerList.mList.push_back(bi);
|
item->peerList.mList.push_back(bi);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,7 +53,7 @@ class BanList
|
||||||
* Exchange list of Banned IP addresses with peers.
|
* Exchange list of Banned IP addresses with peers.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class p3BanList: public RsBanList, public p3Service, public pqiNetAssistPeerShare /* , public p3Config, public pqiMonitor */
|
class p3BanList: public RsBanList, public p3Service, public pqiNetAssistPeerShare, public p3Config /*, public pqiMonitor */
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
p3BanList(p3ServiceControl *sc, p3NetMgr *nm);
|
p3BanList(p3ServiceControl *sc, p3NetMgr *nm);
|
||||||
|
@ -85,6 +85,11 @@ public:
|
||||||
|
|
||||||
virtual void updatePeer(const RsPeerId& id, const struct sockaddr_storage &addr, int type, int reason, int time_stamp);
|
virtual void updatePeer(const RsPeerId& id, const struct sockaddr_storage &addr, int type, int reason, int time_stamp);
|
||||||
|
|
||||||
|
/*********************** p3config ******************************/
|
||||||
|
virtual RsSerialiser *setupSerialiser();
|
||||||
|
virtual bool saveList(bool &cleanup, std::list<RsItem *>& itemlist);
|
||||||
|
virtual bool loadList(std::list<RsItem *>& load);
|
||||||
|
|
||||||
/***** overloaded from p3Service *****/
|
/***** overloaded from p3Service *****/
|
||||||
/*!
|
/*!
|
||||||
* This retrieves all chat msg items and also (important!)
|
* This retrieves all chat msg items and also (important!)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue