Easy to set up and use reverse proxy for TON Sites. It makes your website accessible inside The Open Network!
Using linux based server:
wget https://github.com/tonutils/reverse-proxy/releases/latest/download/tonutils-reverse-proxy-linux-amd64
chmod +x tonutils-reverse-proxy-linux-amd64Or download a binary for your OS:
Run with domain configuration, and follow the steps:
./tonutils-reverse-proxy-linux-amd64 --domain your-domain.ton Scan QR code from your terminal using Tonkeeper, Tonhub or any other wallet, execute transaction. Your domain will be linked to your site.
If for some reason you cannot scan QR code, add -tx-url flag, so it will be displayed as ton:// url for transaction.
Alternatively, you can run in simple mode, with .adnl domain, if you don't have .ton or .t.me domain:
./tonutils-reverse-proxy-linux-amd64Now anyone can access your TON Site! Using ADNL address or domain.
If you want to change some settings, like proxy pass url - open config.json file, edit and restart proxy. Default proxy pass url is http://127.0.0.1:80/
Proxy adds additional headers:
X-Adnl-Ip - ip of client, and X-Adnl-Id - adnl id of client
Yes! You can run any number of sites within single reverse-proxy, just link all your domains to same ADNL address.
You can run reverse-proxy with -domain flag one by one for all your domains and execute transaction. -domain flag is needed only for linking step, for further launches you are not required to specify it, your domains will remain linked.
It can be due to public liteservers synchronization issues, you can replace global config url in config.json to tonutils liteservers config https://tonutils.com/ls/free-mainnet-config.json, or any other.
It can be because of older protocol data time was cached by Telegram proxy, the fastest way to recover is regenerate ADNL address, just delete config.json and relink your domain to newly generated ADNL ID.
To run TON Site you should have public (white) ip address, and in+out UDP traffic allowed on port from config.json. You could use Tonutils Proxy to check your site.
Build it from sources using make build, and run as in the step 2 for linux. Go environment is required to build.
