Skip to content

Selectively proxy traffic via sshuttle to AWS regions.

Notifications You must be signed in to change notification settings

alexandernicholson/intercontinental

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Intercontinental

Selectively proxy traffic via sshuttle to AWS regions.

Use Cases

  • CI/CD environments where you need to proxy your traffic to AWS via another machine due to bad peering or network congestion.
  • Connecting to AWS resources when you are using security groups to restrict access to a particular IP address.
  • Working with AWS resources in regions where your ISP has restrictions, or AWS is restricting your access.

Installation

  1. Ensure you have the following installed:
    • Ruby (version 3.2 or higher recommended)
    • Bundler
    • SSHuttle
  2. Clone this repository.
  3. Run bundle install to install dependencies.

Usage

Run the script with the following command:

ruby app.rb --region <region> --ssh-host <ssh-host> [--options <additional-options>] [--aws-ip-url <custom-url>]

Options:

  • -r, --region REGION: AWS region (required, use 'all' for all regions)
  • -s, --ssh-host HOST: SSH host to connect through (required)
  • -o, --options OPTIONS: Additional sshuttle options (optional)
  • -u, --aws-ip-url URL: Custom URL for AWS IP ranges JSON (optional)

Examples:

# Proxy traffic to a single AWS region.
ruby app.rb -r us-west-2 -s [email protected] -o "--verbose"

# Proxy traffic to all AWS regions.
ruby app.rb -r all -s [email protected] -o "--verbose"

# Proxy traffic to all AWS regions with sshuttle listening on all interfaces.
# This is useful when nesting sshuttle by running it on both the host and container.
ruby app.rb -r all -s [email protected] -o "-l 0.0.0.0 --verbose"

# Proxy traffic to all AWS regions with a custom URL for the AWS IP ranges JSON.
ruby app.rb -r all -s [email protected] -o "--verbose" -u "https://ip-ranges.notamazonaws.com/ip-ranges.json"

Usage within Docker

See the docker-compose.yml file for an example of how to use Intercontinental with Docker networks.

A use-case for this is when you need to MITM all traffic to AWS within Docker Compose by forwarding it over a SOCKS5 proxy to the container running Intercontinental. The proxy container running Intercontinental (& sshuttle) is also running dante-server, which is a highly stable and performant SOCKS5 proxy.

The way this has been implemented leaves it hot-pluggable, so you can switch from dante-server to another proxy by editing the Dockerfile.

flowchart
    subgraph Docker[Docker]
        A[Example Service] -->|"http_proxy=socks5://172.28.0.2:12345"| F[Proxy] -->|"aws-region subnet"| B[Intercontinental & sshuttle]
    end
    subgraph Internet[Internet]
        subgraph sshuttle[sshuttle]
        direction LR
            B -->|"ssh://your_ssh_host:22"| C[Your remote host] --> D[AWS Resources]
        end
        F -->|"0.0.0.0/0"| E["Everything else"]
    end
Loading

Notes

  • All other traffic will continue to use your current connection, which allows you to use the proxy selectively in environments such as a CI where you need to proxy your traffic to AWS via another machine.

  • This script automatically caches the AWS IP ranges JSON using the ETag header to avoid downloading the large JSON file from the AWS API on every run.

  • It's totally possible to create and host a custom IP JSON which forwards specific subnets to use this script for other purposes.

# Example of a custom IP JSON.
{
    "prefixes": [
        {"ip_prefix": "10.0.0.0/8", "region": "us-east-1"}
    ]
}
  • Note: Press CTRL+C to stop the proxy.

About

Selectively proxy traffic via sshuttle to AWS regions.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published