/* * libretroshare/src/services/p3banlist.h * * Exchange list of Peers for Banning / Whitelisting. * * Copyright 2011 by Robert Fernie. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License Version 2 as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. * * Please report all bugs and problems to "retroshare@lunamutt.com". * */ #ifndef SERVICE_RSBANLIST_HEADER #define SERVICE_RSBANLIST_HEADER #include #include #include #include "rsitems/rsbanlistitems.h" #include "services/p3service.h" #include "retroshare/rsbanlist.h" class p3ServiceControl; class p3NetMgr; class BanList { public: RsPeerId mPeerId; /* from */ time_t mLastUpdate; std::map mBanPeers; }; //!The RS BanList service. /** * * Exchange list of Banned IP addresses with peers. */ class p3BanList: public RsBanList, public p3Service, public pqiNetAssistPeerShare, public p3Config /*, public pqiMonitor */ { public: p3BanList(p3ServiceControl *sc, p3NetMgr *nm); virtual RsServiceInfo getServiceInfo(); /***** overloaded from RsBanList *****/ virtual bool isAddressAccepted(const struct sockaddr_storage& addr, uint32_t checking_flags,uint32_t *check_result=NULL) ; virtual void getBannedIps(std::list& list) ; virtual void getWhiteListedIps(std::list& list) ; virtual bool addIpRange(const struct sockaddr_storage& addr,int masked_bytes,uint32_t list_type,const std::string& comment) ; virtual bool removeIpRange(const sockaddr_storage &addr, int masked_bytes, uint32_t list_type); virtual void enableIPFiltering(bool b) ; virtual bool ipFilteringEnabled() ; virtual bool autoRangeEnabled() { return mAutoRangeIps ; } virtual void enableAutoRange(bool b) ; virtual int autoRangeLimit() { return mAutoRangeLimit ; } virtual void setAutoRangeLimit(int b) ; virtual void enableIPsFromFriends(bool b) ; virtual bool IPsFromFriendsEnabled() { return mIPFriendGatheringEnabled ;} virtual void enableIPsFromDHT(bool b) ; virtual bool iPsFromDHTEnabled() { return mIPDHTGatheringEnabled ;} /***** overloaded from pqiNetAssistPeerShare *****/ 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& itemlist); virtual bool loadList(std::list& load); /***** overloaded from p3Service *****/ /*! * This retrieves all chat msg items and also (important!) * processes chat-status items that are in service item queue. chat msg item requests are also processed and not returned * (important! also) notifications sent to notify base on receipt avatar, immediate status and custom status * : notifyCustomState, notifyChatStatus, notifyPeerHasNewAvatar * @see NotifyBase */ virtual int tick(); virtual int status(); int sendPackets(); bool processIncoming(); bool recvBanItem(RsBanListItem *item); bool addBanEntry(const RsPeerId &peerId, const struct sockaddr_storage &addr, int level, uint32_t reason, time_t time_stamp); void sendBanLists(); int sendBanSet(const RsPeerId& peerid); /*! * Interface stuff. */ /*************** pqiMonitor callback ***********************/ //virtual void statusChange(const std::list &plist); /************* from p3Config *******************/ //virtual RsSerialiser *setupSerialiser() ; //virtual bool saveList(bool& cleanup, std::list&) ; //virtual void saveDone(); //virtual bool loadList(std::list& load) ; private: void getDhtInfo() ; RsMutex mBanMtx; bool acceptedBanSet_locked(const BanListPeer &blp); bool acceptedBanRanges_locked(const BanListPeer &blp); void autoFigureOutBanRanges(); int condenseBanSources_locked(); int printBanSources_locked(std::ostream &out); int printBanSet_locked(std::ostream &out); bool isWhiteListed_locked(const sockaddr_storage &addr); p3ServiceControl *mServiceCtrl; //p3NetMgr *mNetMgr; time_t mSentListTime; std::map mBanSources; std::map mBanSet; std::map mBanRanges; std::map mWhiteListedRanges; time_t mLastDhtInfoRequest ; uint32_t mAutoRangeLimit ; bool mAutoRangeIps ; bool mIPFilteringEnabled ; bool mIPFriendGatheringEnabled ; bool mIPDHTGatheringEnabled ; }; #endif // SERVICE_RSBANLIST_HEADER