Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/astro/socksify-ruby
Redirect any TCP connection initiated by a Ruby script through a SOCKS5 proxy
https://github.com/astro/socksify-ruby
ruby rubygem socks socks5
Last synced: about 14 hours ago
JSON representation
Redirect any TCP connection initiated by a Ruby script through a SOCKS5 proxy
- Host: GitHub
- URL: https://github.com/astro/socksify-ruby
- Owner: astro
- License: other
- Created: 2009-03-19T15:48:55.000Z (over 15 years ago)
- Default Branch: master
- Last Pushed: 2024-08-09T13:56:51.000Z (3 months ago)
- Last Synced: 2024-11-05T20:10:41.433Z (1 day ago)
- Topics: ruby, rubygem, socks, socks5
- Language: Ruby
- Homepage: http://socksify.rubyforge.org/
- Size: 109 KB
- Stars: 164
- Watchers: 10
- Forks: 79
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- License: COPYING
Awesome Lists containing this project
README
[![Gem Version](https://badge.fury.io/rb/socksify.svg)](https://badge.fury.io/rb/socksify)
[![Actions Status](https://github.com/astro/socksify-ruby/workflows/CI/badge.svg?branch=master)](https://github.com/astro/socksify-ruby/actions?query=workflow%3ACI)SOCKSify Ruby
=============What is it?
-----------**SOCKSify Ruby** redirects any TCP connection initiated by a Ruby script through a SOCKS5 proxy. It serves as a small drop-in alternative to [tsocks](http://tsocks.sourceforge.net/), except that it handles Ruby programs only and doesn't leak DNS queries.
### How does it work?
```rb
require 'socksify/http'
```
This adds a new class method `Net::HTTP.socks_proxy` which takes the host and port address of a socks proxy. Once set, all requests will be routed via socks. This is acheived by patching a private method in `Net::HTTP`, as sadly Ruby no longer has native socks proxy support out of the box.Additionally, `Socksify.resolve` can be used to resolve hostnames to IPv4 addresses via SOCKS.
Installation
------------`$ gem install socksify`
Usage
-----### Redirect all TCP connections of a Ruby program
Run a Ruby script with redirected TCP through a local [Tor](https://www.torproject.org/) anonymizer:
`$ socksify_ruby localhost 9050 script.rb`
### Explicit SOCKS usage in a Ruby program (Deprecated in Ruby 3.1 onwards)
Set up SOCKS connections for a local [Tor](https://www.torproject.org/) anonymizer, TCPSockets can be used as usual:
```rb
require 'socksify'TCPSocket.socks_server = "127.0.0.1"
TCPSocket.socks_port = 9050
rubyforge_www = TCPSocket.new("rubyforge.org", 80)
# => #
```### Use Net::HTTP explicitly via SOCKS
Require the additional library `socksify/http` and use the `Net::HTTP.socks_proxy` method. It is similar to `Net::HTTP.Proxy` from the Ruby standard library:
```rb
require 'socksify/http'uri = URI.parse('http://ipecho.net/plain')
Net::HTTP.socks_proxy('127.0.0.1', 9050).start(uri.host, uri.port) do |http|
req = Net::HTTP::Get.new uri
resp = http.request(req)
puts resp.inspect
puts resp.body
end
# => #
# =>
```
Note that `Net::HTTP.socks_proxy` never relies on `TCPSocket.socks_server`/`socks_port`. You should either set `socks_proxy` arguments explicitly or use `Net::HTTP` directly.### Resolve addresses via SOCKS
```rb
Socksify.resolve("spaceboyz.net")
# => "87.106.131.203"
```
### Testing and DebuggingA tor proxy is required before running the tests. Install tor from your usual package manager, check it is running with `pidof tor` then run the tests with:
`bundle exec rake`
Colorful diagnostic messages are enabled by default via:
```rb
Socksify::debug = true`
```
Development
-----------The [repository](https://github.com/astro/socksify-ruby/) can be checked out with:
`$ git-clone [email protected]:astro/socksify-ruby.git`
Send patches via pull requests.
### Further ideas
* `Resolv` replacement code, so that programs which resolve by themselves don't leak DNS queries
* IPv6 address support
* UDP as soon as [Tor](https://www.torproject.org/) supports it
* Perhaps using standard exceptions for better compatibility when acting as a drop-in?Author
------* [Stephan Maka](mailto:[email protected])
License
-------SOCKSify Ruby is distributed under the terms of the GNU General Public License version 3 (see file `COPYING`) or the Ruby License (see file `LICENSE`) at your option.