# tokio-socks
[](https://github.com/sticnarf/tokio-socks/actions)
[](https://crates.io/crates/tokio-socks)
[](https://docs.rs/tokio-socks)
Asynchronous SOCKS proxy support for Rust.
## Features
- [x] `CONNECT` command
- [x] `BIND` command
- [ ] `ASSOCIATE` command
- [x] Username/password authentication
- [ ] GSSAPI authentication
- [ ] Asynchronous DNS resolution
- [X] Chain proxies ([see example](examples/chainproxy.rs))
- [X] SOCKS4
## Compatibility with Other Async Runtimes
By default, the `tokio` feature is enabled, as the crate name suggests.
Users can opt out `tokio` by setting `default-features = false`. The `*_with_socket` functions accept types implementing the `AsyncSocket` trait.
The crate provides `io::Compat` that implements `AsyncSocket` for `futures-io` types (requiring the `futures-io` feature).
## License
This project is licensed under the MIT License - see the [LICENSE](/LICENSE) file for details.
## Acknowledgments
* [sfackler/rust-socks](https://github.com/sfackler/rust-socks)