Skip to content

Commit

Permalink
Create TransformerContext before executing socket_transformer
Browse files Browse the repository at this point in the history
Signed-off-by: Eval EXEC <[email protected]>
  • Loading branch information
eval-exec committed Dec 23, 2024
1 parent 1eb0f49 commit f620bfe
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 10 deletions.
10 changes: 7 additions & 3 deletions tentacle/src/builder.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use std::{io, sync::Arc, time::Duration};

use crate::service::config::ProxyConfig;
use crate::service::config::TransformerContext;
use nohash_hasher::IntMap;
use tokio_util::codec::LengthDelimitedCodec;

Expand Down Expand Up @@ -218,7 +219,10 @@ where
#[cfg(not(target_family = "wasm"))]
pub fn tcp_config<F>(mut self, f: F) -> Self
where
F: Fn(TcpSocket) -> Result<TcpSocket, std::io::Error> + Send + Sync + 'static,
F: Fn(TcpSocket, TransformerContext) -> Result<TcpSocket, std::io::Error>
+ Send
+ Sync
+ 'static,
{
self.config.tcp_config.tcp.socket_transformer = Arc::new(f);
self
Expand All @@ -236,7 +240,7 @@ where
#[cfg_attr(docsrs, doc(cfg(feature = "ws")))]
pub fn tcp_config_on_ws<F>(mut self, f: F) -> Self
where
F: Fn(TcpSocket) -> Result<TcpSocket, std::io::Error> + Send + Sync + 'static,
F: Fn(TcpSocket, TransformerContext) -> Result<TcpSocket, std::io::Error> + Send + Sync + 'static,
{
self.config.tcp_config.ws.socket_transformer = Arc::new(f);
self
Expand All @@ -260,7 +264,7 @@ where
#[cfg_attr(docsrs, doc(cfg(feature = "tls")))]
pub fn tcp_config_on_tls<F>(mut self, f: F) -> Self
where
F: Fn(TcpSocket) -> Result<TcpSocket, std::io::Error> + Send + Sync + 'static,
F: Fn(TcpSocket, TransformerContext) -> Result<TcpSocket, std::io::Error> + Send + Sync + 'static,
{
self.config.tcp_config.tls.socket_transformer = Arc::new(f);
self
Expand Down
8 changes: 5 additions & 3 deletions tentacle/src/runtime/async_runtime/os/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ mod time;
use crate::{
runtime::{proxy::socks5_config, CompatStream2},
service::{
config::{TcpSocket, TcpSocketConfig, TcpSocketTransformer},
config::{TcpSocket, TcpSocketConfig, TcpSocketTransformer, TransformerContext},
ProxyConfig,
},
};
Expand Down Expand Up @@ -138,7 +138,8 @@ pub(crate) fn listen(addr: SocketAddr, tcp_config: TcpSocketConfig) -> io::Resul
let socket = Socket::new(domain, Type::STREAM, Some(SocketProtocol::TCP))?;

let socket = {
let t = (tcp_config.socket_transformer)(TcpSocket { inner: socket })?;
let transformer_context = TransformerContext::new_listen(addr);
let t = (tcp_config.socket_transformer)(TcpSocket { inner: socket }, transformer_context)?;
t.inner
};
// `bind` twice will return error
Expand Down Expand Up @@ -177,7 +178,8 @@ async fn connect_direct(
// user can disable it on tcp_config
#[cfg(not(windows))]
socket.set_reuse_address(true)?;
let t = socket_transformer(TcpSocket { inner: socket })?;
let transformer_context = TransformerContext::new_dial(addr);
let t = socket_transformer(TcpSocket { inner: socket }, transformer_context)?;
t.inner
};

Expand Down
8 changes: 5 additions & 3 deletions tentacle/src/runtime/tokio_runtime/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ pub use tokio::{
};

use crate::service::{
config::{TcpSocket, TcpSocketConfig, TcpSocketTransformer},
config::{TcpSocket, TcpSocketConfig, TcpSocketTransformer, TransformerContext},
ProxyConfig,
};
use socket2::{Domain, Protocol as SocketProtocol, Socket, Type};
Expand Down Expand Up @@ -93,7 +93,8 @@ pub(crate) fn listen(addr: SocketAddr, tcp_config: TcpSocketConfig) -> io::Resul
// user can disable it on tcp_config
#[cfg(not(windows))]
socket.set_reuse_address(true)?;
let t = (tcp_config.socket_transformer)(TcpSocket { inner: socket })?;
let transformer_context = TransformerContext::new_listen(addr);
let t = (tcp_config.socket_transformer)(TcpSocket { inner: socket }, transformer_context)?;
t.inner.set_nonblocking(true)?;
// safety: fd convert by socket2
unsafe {
Expand Down Expand Up @@ -126,7 +127,8 @@ async fn connect_direct(
let socket = Socket::new(domain, Type::STREAM, Some(SocketProtocol::TCP))?;

let socket = {
let t = socket_transformer(TcpSocket { inner: socket })?;
let transformer_context = TransformerContext::new_dial(addr);
let t = socket_transformer(TcpSocket { inner: socket }, transformer_context)?;
t.inner.set_nonblocking(true)?;
// safety: fd convert by socket2
unsafe {
Expand Down
3 changes: 2 additions & 1 deletion tentacle/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,8 @@ mod helper;

pub use crate::service::{
config::{
HandshakeType, ProtocolHandle, ProtocolMeta, TargetProtocol, TargetSession, TcpSocket,
HandshakeType, ProtocolHandle, ProtocolMeta, SocketState, TargetProtocol, TargetSession,
TcpSocket, TransformerContext,
},
control::{ServiceAsyncControl, ServiceControl},
event::{ServiceError, ServiceEvent},
Expand Down

0 comments on commit f620bfe

Please sign in to comment.