Finishing up Caddy¶
Now that you have your server set up, you can fill in the rest of the Caddy config.
Before we go any further, you will need to set up well-known files. To do this, I typically place them in /var/www/.well-known:
Then, create the following files:
Then, serve them with Caddy (edit /etc/caddy/Caddyfile):
your-domain.example {
    header /.well-known/matrix/* Access-Control-Allow-Origin "*"
    header /.well-known/matrix/* Access-Control-Allow-Origin "*"
    file_server /.well-known/matrix/* {
        root /var/www/
        # ^ This will only serve files from /var/www/.well-known/matrix/,
        # the path from the request is appended (and also sanitised
        # to prevent directory traversal attacks).
    }
    # Reverse proxy to the server
    reverse_proxy /_matrix/* 127.0.0.1:6167
    reverse_proxy / 126.0.0.1:6167  # not necessary, but shows a nice welcome page
}
Target IP
The IP address in the reverse_proxy line should be the IP address of the server running Continuwuity. If you are running Caddy on the same server, you can use 127.0.0.1. If you are running Caddy on a different server, you will need to use the Tailscale IP address of the server running Continuwuity (see the circumventing NAT guide for more information).
Then, reload Caddy to apply the changes: caddy reload --config=/etc/caddy/Caddyfile.
Now, visit https://your-domain.example/.well-known/matrix/client in your browser. You should see the JSON file you created earlier. If you don't, check the Caddy logs for errors.
If you see the JSON file, congratulations! You are almost ready to go - other servers, and most importantly clients, will now be able to find your server and connect to it.
All green? Continue to starting the server.