mirror of
				https://github.com/PurpleI2P/i2pd.git
				synced 2025-10-20 18:50:20 +01:00 
			
		
		
		
	fixed zero-hops tunnels
This commit is contained in:
		
							parent
							
								
									f6e988d6fd
								
							
						
					
					
						commit
						c50105493a
					
				
					 3 changed files with 24 additions and 10 deletions
				
			
		|  | @ -31,7 +31,7 @@ namespace client | ||||||
| 			{ | 			{ | ||||||
| 
 | 
 | ||||||
| 				int len = i2p::util::lexical_cast<int>(it->second, inboundTunnelLen); | 				int len = i2p::util::lexical_cast<int>(it->second, inboundTunnelLen); | ||||||
| 				if (len > 0) | 				if (len >= 0) | ||||||
| 				{ | 				{ | ||||||
| 						inboundTunnelLen = len; | 						inboundTunnelLen = len; | ||||||
| 				} | 				} | ||||||
|  | @ -42,7 +42,7 @@ namespace client | ||||||
| 			{ | 			{ | ||||||
| 
 | 
 | ||||||
| 				int len = i2p::util::lexical_cast<int>(it->second, outboundTunnelLen); | 				int len = i2p::util::lexical_cast<int>(it->second, outboundTunnelLen); | ||||||
| 				if (len > 0) | 				if (len >= 0) | ||||||
| 				{ | 				{ | ||||||
| 						outboundTunnelLen = len; | 						outboundTunnelLen = len; | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
|  | @ -217,6 +217,7 @@ namespace tunnel | ||||||
| 		if (msg) | 		if (msg) | ||||||
| 		{	 | 		{	 | ||||||
| 			m_NumReceivedBytes += msg->GetLength (); | 			m_NumReceivedBytes += msg->GetLength (); | ||||||
|  | 			msg->from = shared_from_this (); | ||||||
| 			HandleI2NPMessage (msg); | 			HandleI2NPMessage (msg); | ||||||
| 		}	 | 		}	 | ||||||
| 	}	 | 	}	 | ||||||
|  |  | ||||||
|  | @ -390,8 +390,15 @@ namespace tunnel | ||||||
| 		std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers; | 		std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers; | ||||||
| 		if (SelectPeers (peers, true)) | 		if (SelectPeers (peers, true)) | ||||||
| 		{ | 		{ | ||||||
| 			std::reverse (peers.begin (), peers.end ());	 | 			std::shared_ptr<TunnelConfig> config; | ||||||
| 			auto tunnel = tunnels.CreateInboundTunnel (std::make_shared<TunnelConfig> (peers), outboundTunnel); | 			if (m_NumInboundHops > 0) | ||||||
|  | 			{	 | ||||||
|  | 				std::reverse (peers.begin (), peers.end ());	 | ||||||
|  | 				config = std::make_shared<TunnelConfig> (peers); | ||||||
|  | 			}	 | ||||||
|  | 			else | ||||||
|  | 				config = std::make_shared<ZeroHopsTunnelConfig> (); | ||||||
|  | 			auto tunnel = tunnels.CreateInboundTunnel (config, outboundTunnel); | ||||||
| 			tunnel->SetTunnelPool (shared_from_this ()); | 			tunnel->SetTunnelPool (shared_from_this ()); | ||||||
| 			if (tunnel->IsEstablished ()) // zero hops
 | 			if (tunnel->IsEstablished ()) // zero hops
 | ||||||
| 				TunnelCreated (tunnel); | 				TunnelCreated (tunnel); | ||||||
|  | @ -406,7 +413,9 @@ namespace tunnel | ||||||
| 		if (!outboundTunnel) | 		if (!outboundTunnel) | ||||||
| 			outboundTunnel = tunnels.GetNextOutboundTunnel (); | 			outboundTunnel = tunnels.GetNextOutboundTunnel (); | ||||||
| 		LogPrint (eLogDebug, "Tunnels: Re-creating destination inbound tunnel..."); | 		LogPrint (eLogDebug, "Tunnels: Re-creating destination inbound tunnel..."); | ||||||
| 		auto newTunnel = tunnels.CreateInboundTunnel (std::make_shared<TunnelConfig>(tunnel->GetPeers ()), outboundTunnel); | 		std::shared_ptr<TunnelConfig> config = m_NumInboundHops > 0 ?  | ||||||
|  | 			std::make_shared<TunnelConfig>(tunnel->GetPeers ()) : std::make_shared<ZeroHopsTunnelConfig> (); | ||||||
|  | 		auto newTunnel = tunnels.CreateInboundTunnel (config, outboundTunnel); | ||||||
| 		newTunnel->SetTunnelPool (shared_from_this()); | 		newTunnel->SetTunnelPool (shared_from_this()); | ||||||
| 		if (newTunnel->IsEstablished ()) // zero hops
 | 		if (newTunnel->IsEstablished ()) // zero hops
 | ||||||
| 			TunnelCreated (newTunnel); | 			TunnelCreated (newTunnel); | ||||||
|  | @ -423,8 +432,11 @@ namespace tunnel | ||||||
| 			std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers; | 			std::vector<std::shared_ptr<const i2p::data::IdentityEx> > peers; | ||||||
| 			if (SelectPeers (peers, false)) | 			if (SelectPeers (peers, false)) | ||||||
| 			{	 | 			{	 | ||||||
| 				auto tunnel = tunnels.CreateOutboundTunnel ( | 				std::shared_ptr<TunnelConfig> config = m_NumOutboundHops > 0 ?  | ||||||
| 					std::make_shared<TunnelConfig> (peers, inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ())); | 					std::make_shared<TunnelConfig>(peers, inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()) :  | ||||||
|  | 					std::make_shared<ZeroHopsTunnelConfig> (); | ||||||
|  | 
 | ||||||
|  | 				auto tunnel = tunnels.CreateOutboundTunnel (config); | ||||||
| 				tunnel->SetTunnelPool (shared_from_this ()); | 				tunnel->SetTunnelPool (shared_from_this ()); | ||||||
| 				if (tunnel->IsEstablished ()) // zero hops
 | 				if (tunnel->IsEstablished ()) // zero hops
 | ||||||
| 					TunnelCreated (tunnel); | 					TunnelCreated (tunnel); | ||||||
|  | @ -444,9 +456,10 @@ namespace tunnel | ||||||
| 		if (inboundTunnel) | 		if (inboundTunnel) | ||||||
| 		{	 | 		{	 | ||||||
| 			LogPrint (eLogDebug, "Tunnels: Re-creating destination outbound tunnel..."); | 			LogPrint (eLogDebug, "Tunnels: Re-creating destination outbound tunnel..."); | ||||||
| 			auto newTunnel = tunnels.CreateOutboundTunnel ( | 			std::shared_ptr<TunnelConfig> config = m_NumOutboundHops > 0 ?  | ||||||
| 				std::make_shared<TunnelConfig> (tunnel->GetPeers (), | 					std::make_shared<TunnelConfig>(tunnel->GetPeers (), inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ()) :  | ||||||
| 					inboundTunnel->GetNextTunnelID (), inboundTunnel->GetNextIdentHash ())); | 					std::make_shared<ZeroHopsTunnelConfig> (); | ||||||
|  | 			auto newTunnel = tunnels.CreateOutboundTunnel (config); | ||||||
| 			newTunnel->SetTunnelPool (shared_from_this ()); | 			newTunnel->SetTunnelPool (shared_from_this ()); | ||||||
| 			if (newTunnel->IsEstablished ()) // zero hops
 | 			if (newTunnel->IsEstablished ()) // zero hops
 | ||||||
| 				TunnelCreated (newTunnel); | 				TunnelCreated (newTunnel); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue