mirror of
https://github.com/nextcloud/all-in-one.git
synced 2025-12-19 14:06:50 +00:00
5.5 KiB
5.5 KiB
Caddy with geoblocking
This container bundles caddy and auto-configures it for you. It also covers vaultwarden by listening on bw.$NC_DOMAIN, if installed. It also covers stalwart by listening on mail.$NC_DOMAIN, if installed. It also covers jellyfin by listening on media.$NC_DOMAIN, if installed. It also covers lldap by listening on ldap.$NC_DOMAIN, if installed. It also covers nocodb by listening on tables.$NC_DOMAIN, if installed. It also covers jellyseerr by listening on requests.$NC_DOMAIN, if installed. It also covers nextcloud-exporter by listening on metrics.$NC_DOMAIN, if installed.
Notes
- This container is incompatible with the npmplus community container. So make sure that you do not enable both at the same time!
- Make sure that no other service is using port 443 on your host as otherwise the containers will fail to start. You can check this with
sudo netstat -tulpn | grep 443before installing AIO. - Starting with AIO v12, the Talk port that was usually exposed on port 3478 is now set to port 443 udp and tcp and reachable via
turn.your-nc-domain.com. So instead of opening port 3478, you need to configure the mentioned subdomain by using a cname record. - Starting with AIO v12, you can also limit vaultwarden, stalwart and lldap to certain ip-addresses. You can do so by creating a
allowed-IPs-vaultwarden.txt,allowed-IPs-stalwart.txt, orallowed-IPs-lldap.txtfile in thenextcloud-aio-caddydirectory of your admin user and adding the ip-addresses in these files. - If you want to use this with vaultwarden, make sure that you point
bw.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for vaultwarden. - If you want to use this with stalwart, make sure that you point
mail.your-nc-domain.comto your server using an A, AAAA or CNAME record so that caddy can get a certificate automatically for stalwart. - If you want to use this with jellyfin, make sure that you point
media.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for jellyfin. - If you want to use this with lldap, make sure that you point
ldap.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for lldap. - If you want to use this with nocodb, make sure that you point
tables.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for nocodb. - If you want to use this with jellyseerr, make sure that you point
requests.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for jellyseerr. - If you want to use this with nextcloud-exporter, make sure that you point
metrics.your-nc-domain.comto your server using a cname record so that caddy can get a certificate automatically for nextcloud-exporter. - After the container was started the first time, you should see a new
nextcloud-aio-caddyfolder and inside there anallowed-countries.txtfile when you open the files app with the defaultadminuser. In there you can adjust the allowed country codes for caddy by adding them to the first line, e.g.IT FRwould allow access from italy and france. Private ip-ranges are always allowed. Additionally, in order to activate this config, you need to get an account at https://dev.maxmind.com/geoip/geolite2-free-geolocation-data and download theGeoLite2-Country.mmdband upload it with this exact name into thenextcloud-aio-caddyfolder. Afterwards restart all containers from the AIO interface and your new config should be active! - You can add your own Caddy configurations in
/data/caddy-imports/inside the Caddy container (sudo docker exec -it nextcloud-aio-caddy bash). These will be imported on container startup. Please note: If you do not have CLI access to the server, you can now run docker commands via a web session by using this community container: https://github.com/nextcloud/all-in-one/tree/main/community-containers/container-management - See https://github.com/nextcloud/all-in-one/tree/main/community-containers#community-containers how to add it to the AIO stack
Repository
https://github.com/szaimen/aio-caddy