mirror of
				https://github.com/RetroShare/RetroShare.git
				synced 2025-10-26 12:26:14 -04:00 
			
		
		
		
	 fb28284be3
			
		
	
	
		fb28284be3
		
	
	
	
	
		
			
			git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@8355 b45a01b8-16f6-495d-af2f-9b41ad6348cc
		
			
				
	
	
		
			122 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * 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".
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include "util/rsnet.h"
 | |
| 
 | |
| class RsBanList;
 | |
| extern RsBanList *rsBanList ;
 | |
| 
 | |
| #define RSBANLIST_ORIGIN_UNKNOWN	0
 | |
| #define RSBANLIST_ORIGIN_SELF		1
 | |
| #define RSBANLIST_ORIGIN_FRIEND		2
 | |
| #define RSBANLIST_ORIGIN_FOF		3
 | |
| 
 | |
| #define RSBANLIST_REASON_UNKNOWN	0
 | |
| #define RSBANLIST_REASON_USER		1
 | |
| #define RSBANLIST_REASON_DHT		2
 | |
| #define RSBANLIST_REASON_AUTO_RANGE     3
 | |
| 
 | |
| // These are flags. Can be combined.
 | |
| 
 | |
| #define RSBANLIST_CHECKING_FLAGS_NONE   	0x00
 | |
| #define RSBANLIST_CHECKING_FLAGS_BLACKLIST   	0x01
 | |
| #define RSBANLIST_CHECKING_FLAGS_WHITELIST   	0x02
 | |
| 
 | |
| // These are not flags. Cannot be combined. Used to give the reson for acceptance/denial of connections.
 | |
| 
 | |
| #define RSBANLIST_CHECK_RESULT_UNKNOWN  	0x00
 | |
| #define RSBANLIST_CHECK_RESULT_NOCHECK  	0x01
 | |
| #define RSBANLIST_CHECK_RESULT_BLACKLISTED  	0x02
 | |
| #define RSBANLIST_CHECK_RESULT_NOT_WHITELISTED  0x03
 | |
| #define RSBANLIST_CHECK_RESULT_ACCEPTED     	0x04
 | |
| 
 | |
| #define RSBANLIST_TYPE_PEERLIST	  		1
 | |
| #define RSBANLIST_TYPE_BLACKLIST		2
 | |
| #define RSBANLIST_TYPE_WHITELIST		3
 | |
| 
 | |
| class RsTlvBanListEntry ;
 | |
| 
 | |
| class BanListPeer
 | |
| {
 | |
| public:
 | |
|     BanListPeer() ;
 | |
| 
 | |
|     void toRsTlvBanListEntry(RsTlvBanListEntry& e) const ;
 | |
|     void fromRsTlvBanListEntry(const RsTlvBanListEntry& e) ;
 | |
| 
 | |
|     struct sockaddr_storage addr;
 | |
|     uint8_t masked_bytes ;		// 0 = []/32. 1=[]/24, 2=[]/16
 | |
|     uint32_t reason; 			 // User, DHT
 | |
|     uint32_t level; 			 // LOCAL, FRIEND, FoF.
 | |
|     bool state ; 			// true=>active, false=>just stored but inactive
 | |
|     int  connect_attempts ; 	// recorded by the BanList service
 | |
|     time_t mTs;
 | |
|     std::string comment ;		//
 | |
| };
 | |
| 
 | |
| class RsBanList
 | |
| {
 | |
| public:
 | |
|     virtual void enableIPFiltering(bool b) =0;
 | |
|     virtual bool ipFilteringEnabled() =0;
 | |
| 
 | |
|     // addIpRange()/removeIpRange()
 | |
|     // 	addr: 		full IPv4 address. Port is ignored.
 | |
|     // 	masked_bytes: 	0=full IP, 1="/24", 2="/16"
 | |
|     // 	list_type: 	RSBANLIST_TYPE_WHITELIST or RSBANLIST_TYPE_BLACKLIST
 | |
|     // 	comment: 	anything, user-based.
 | |
| 
 | |
|     virtual bool addIpRange(const struct sockaddr_storage& addr,int masked_bytes,uint32_t list_type,const std::string& comment) =0;
 | |
|     virtual bool removeIpRange(const struct sockaddr_storage& addr,int masked_bytes,uint32_t list_type) =0;
 | |
| 
 | |
|     // isAddressAccepted()
 | |
|     // 	addr: 		full IPv4 address. Port is ignored.
 | |
|     // 	checking flags: any combination of  RSBANLIST_CHECKING_FLAGS_BLACKLIST and RSBANLIST_CHECKING_FLAGS_WHITELIST
 | |
|     // 	check_result: 	returned result of the check in RSBANLIST_CHECK_RESULT_*
 | |
|     // 	returned value: true=address is accepted, false=address is rejected.
 | |
| 
 | |
|     virtual bool isAddressAccepted(const struct sockaddr_storage& addr,uint32_t checking_flags,uint32_t *check_result=NULL) =0;
 | |
| 
 | |
|     virtual void getBannedIps(std::list<BanListPeer>& list) =0;
 | |
|     virtual void getWhiteListedIps(std::list<BanListPeer>& list) =0;
 | |
| 
 | |
|     virtual bool autoRangeEnabled() =0;
 | |
|     virtual void enableAutoRange(bool b) =0 ;
 | |
| 
 | |
|     virtual int  autoRangeLimit() =0;
 | |
|     virtual void setAutoRangeLimit(int n)=0;
 | |
| 
 | |
|     virtual void enableIPsFromFriends(bool b) =0;
 | |
|     virtual bool IPsFromFriendsEnabled() =0;
 | |
| 
 | |
|     virtual void enableIPsFromDHT(bool b) =0;
 | |
|     virtual bool iPsFromDHTEnabled() =0;
 | |
| 
 | |
| };
 | |
| 
 | |
| 
 | |
| 
 |