Skip to content
This repository has been archived by the owner on Jun 15, 2023. It is now read-only.

ReverseProxy

Preston edited this page Jul 14, 2021 · 14 revisions

It's a common usage that running Simple Torrent behind a proxy server.

Nginx

Full Example: Nginx with dedicated domain


map $http_upgrade $connection_upgrade {
    default upgrade;
    '' 	    keep-alive;
}

server {
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name your.domain.tld;
    ssl_certificate /usr/local/nginx/ssl/wildcard.crt;
    ssl_certificate_key /usr/local/nginx/ssl/wildcard.key;

    location / {                                                                    
        proxy_pass http://127.0.0.1:3000;                                          
        #proxy_pass http://unix:/run/cloud-torrent/cloud.sock; # use if listening on unixsocket                  
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection $connection_upgrade;
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_http_version 1.1;                                                     
        chunked_transfer_encoding off;                                              
        proxy_buffering off;                                                        
        proxy_cache off;                                                                                                              
    }    
}

Full Example: Nginx with shared domain, under a directory /ctorrent/

map $http_upgrade $connection_upgrade {
    default upgrade;
    '' 	    keep-alive;
}
server {
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name your.domain.tld;
    ssl_certificate /usr/local/nginx/ssl/wildcard.crt;
    ssl_certificate_key /usr/local/nginx/ssl/wildcard.key;

    location / {
        # your default site config
    }

    location /ctorrent/ {                                                                    
        proxy_pass http://127.0.0.1:3000/; # note the trailing slash here, it matters!
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection $connection_upgrade;
        proxy_http_version 1.1;                                                     
        chunked_transfer_encoding off;                                              
        proxy_buffering off;                                                        
        proxy_cache off;                                                            
    }
}

Caddy2

Everything gets easy when it comes with caddy!

Full Example: Simple reverse proxy

https://your.domain.tld {
  reverse_proxy * localhost:1300
}

Full Example: Exclude the /dl/ path, allowing to download files without authentication.

https://your.domain.tld {
  @cld not path /dl/*
  reverse_proxy @cld localhost:1300

  file_server * {
    root /srv/http/  #the upper path of the download dir
    browse
  }
}

Full Example: shared domain with other application, under a directory

https://your.domain.tld {
  #... other path config

  handle_path /cloud/* {
    rewrite * {path}
    reverse_proxy localhost:1300
  }
}

Caddy1 (caddy reached it's end of life)

Full Example: Caddy with dedicated domain

https://your.domain.tld {
  proxy / http://127.0.0.1:3000 {
    transparent
  }
}

Full Example: Caddy with shared domain, under directory

https://your.domain.tld {

  #default site config
  root /srv/http
  browse

  proxy /ctorrent http://127.0.0.1:3000 {
    transparent
    without /ctorrent
  }
}
Clone this wiki locally