mirror of
				https://github.com/PurpleI2P/i2pd.git
				synced 2025-10-24 20:49:03 +01:00 
			
		
		
		
	reference counter for destinations
This commit is contained in:
		
							parent
							
								
									1b97f9b6c9
								
							
						
					
					
						commit
						c287fb58bd
					
				
					 5 changed files with 19 additions and 3 deletions
				
			
		|  | @ -694,7 +694,7 @@ namespace client | |||
| 
 | ||||
| 	ClientDestination::ClientDestination (const i2p::data::PrivateKeys& keys, bool isPublic, const std::map<std::string, std::string> * params): | ||||
| 		LeaseSetDestination (isPublic, params), | ||||
| 		m_Keys (keys), m_DatagramDestination (nullptr), | ||||
| 		m_Keys (keys), m_DatagramDestination (nullptr), m_RefCounter (0), | ||||
| 		m_ReadyChecker(GetService()) | ||||
| 	{ | ||||
| 		if (isPublic)	 | ||||
|  |  | |||
|  | @ -181,6 +181,11 @@ namespace client | |||
| 			const i2p::data::PrivateKeys& GetPrivateKeys () const { return m_Keys; }; | ||||
| 			void Sign (const uint8_t * buf, int len, uint8_t * signature) const { m_Keys.Sign (buf, len, signature); }; | ||||
| 
 | ||||
| 			// ref counter
 | ||||
| 			int Acquire () { return ++m_RefCounter; };  | ||||
| 			int Release () { return --m_RefCounter; }; | ||||
| 			int GetRefCounter () const { return m_RefCounter; };  | ||||
| 
 | ||||
| 			// streaming
 | ||||
| 			std::shared_ptr<i2p::stream::StreamingDestination> CreateStreamingDestination (int port, bool gzip = true); // additional
 | ||||
| 			std::shared_ptr<i2p::stream::StreamingDestination> GetStreamingDestination (int port = 0) const; | ||||
|  | @ -223,7 +228,8 @@ namespace client | |||
| 
 | ||||
| 			std::shared_ptr<i2p::stream::StreamingDestination> m_StreamingDestination; // default
 | ||||
| 			std::map<uint16_t, std::shared_ptr<i2p::stream::StreamingDestination> > m_StreamingDestinationsByPorts; | ||||
|       i2p::datagram::DatagramDestination * m_DatagramDestination; | ||||
|       		i2p::datagram::DatagramDestination * m_DatagramDestination; | ||||
| 			int m_RefCounter; // how many clients(tunnels) use this destination
 | ||||
| 
 | ||||
| 			boost::asio::deadline_timer m_ReadyChecker; | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,13 +13,21 @@ namespace client | |||
| 		m_LocalDestination (localDestination ? localDestination : | ||||
| 					i2p::client::context.CreateNewLocalDestination (false, I2P_SERVICE_DEFAULT_KEY_TYPE)) | ||||
| 	{ | ||||
| 		m_LocalDestination->Acquire ();	 | ||||
| 	} | ||||
| 	 | ||||
| 	I2PService::I2PService (i2p::data::SigningKeyType kt): | ||||
| 		m_LocalDestination (i2p::client::context.CreateNewLocalDestination (false, kt)) | ||||
| 	{ | ||||
| 		m_LocalDestination->Acquire (); | ||||
| 	} | ||||
| 	 | ||||
| 	I2PService::~I2PService ()  | ||||
| 	{  | ||||
| 		ClearHandlers ();  | ||||
| 		if (m_LocalDestination) m_LocalDestination->Release ();  | ||||
| 	} | ||||
| 
 | ||||
| 	void I2PService::CreateStream (StreamRequestComplete streamRequestComplete, const std::string& dest, int port) { | ||||
| 		assert(streamRequestComplete); | ||||
| 		i2p::data::IdentHash identHash; | ||||
|  |  | |||
|  | @ -19,7 +19,7 @@ namespace client | |||
| 		public: | ||||
| 			I2PService (std::shared_ptr<ClientDestination> localDestination  = nullptr); | ||||
| 			I2PService (i2p::data::SigningKeyType kt); | ||||
| 			virtual ~I2PService () { ClearHandlers (); } | ||||
| 			virtual ~I2PService (); | ||||
| 
 | ||||
| 			inline void AddHandler (std::shared_ptr<I2PServiceHandler> conn) | ||||
| 			{ | ||||
|  |  | |||
|  | @ -921,6 +921,7 @@ namespace client | |||
| 		} | ||||
| 		if (localDestination) | ||||
| 		{ | ||||
| 			localDestination->Acquire (); | ||||
| 			auto session = std::make_shared<SAMSession>(localDestination); | ||||
| 			std::unique_lock<std::mutex> l(m_SessionsMutex); | ||||
| 			auto ret = m_Sessions.insert (std::make_pair(id, session)); | ||||
|  | @ -945,6 +946,7 @@ namespace client | |||
| 		} | ||||
| 		if (session) | ||||
| 		{ | ||||
| 			session->localDestination->Release (); | ||||
| 			session->localDestination->StopAcceptingStreams (); | ||||
| 			session->CloseStreams (); | ||||
| 		} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue