I spent AGES trying to get autoconfig/autodiscover to work. It seems like they don't want to make it easy with different methods for each client, and no concensus on how things should work (for example, some people want DNS SRV records, others want autodiscover subdomains/files, others autoconfig... etc etc).
Anyway for my own stuff I wanted a quick way to add autodiscover for my own servers and domains - thus this script for setting up autoconfig/autodiscove email settings for mail servers
- Each domain needs to have mail. and webmail. subdomains for the domain, and SSL setup for the domain in question.
- You are on a Linode server (you can easily modify it for your own server, but a lot of the code is based on linode-cli)
- You have linode-cli installed (https://www.linode.com/docs/products/tools/cli/guides/install/), or are running your own DNS server (with Bind) on the server. If using Bind, be sure to update the .cgi script and set my
$dns_type = "local";
. If using Linode's DNS, then be sure to runlinode-cli
and configure the API credentials (otherwise it'll just hang, and do nothing!) - If you want to modify, a knowledge of Perl is good (that being said - there is nothing stopping someone from converting this into a bash/PHP/etc script, and just using it as a guide!)
- You need to create a folder called /installer at the root level, and put all these files in it
- You need to be logged in as root
- The domain you are adding already has SSL enabled via LetsEncrypt
Ok so running it is pretty simple:
perl /installer/add-autodiscover.cgi domain.com user
You should see some debug.
- It checks to make sure the domain + user combination exist
- It creates an autoconfig and autodiscover folder in the domains public_html folder
- Copies over the demo .xml and .json files, and then runs a
sed
on them to replace the domain name with the actual domain name you are setting up - CHOWN's the new files and folders to the correct user account
- Loads all your DNS records from linode (via linode-cli) and loops through until it finds the domain in question.
- Adds in the CNAME records for autodiscover and autoconfig
- Adds the 2 new subdomains as aliases via
v-add-web-domain-alias
- Runs
v-add-web-domain-ssl-force
and thenv-schedule-letsencrypt-domain
to do the magic and update the SSL records - Restart nginx just to make sure the SSL certificates are updated
Thats pretty much it! I'm sure there are improvements that can be made, but I wanted to put this out there so others can hopefully make use. I would love if it were possible to have a single .xml and .json file in one location and dynamically change the domain name (i.e the <hostname>mail.DOMAINNAME.COM</hostname>
part), but I wouldn't figure out a way to do that.
There are 2 scripts - add-autodiscover.cgi
and add-autodiscover-all.cgi
.
This script is for when you want to just enable autodiscover on a single domain. Invoke it as root
with:
perl /installer/add-autodiscover.cgi domain.com username
This is aimed so you can add all the current accounts with mail domains setup (and at least one email address). It will loop through all of the users, look at their domains; find any that have emails configured, and then assuming it hasn't already been processed it will setup the auto-discover. Call with:
perl /installer/add-autodiscover-all.cgi
I personally have set this up on a cronjob as root
(you could do it as admin
, but be aware you would need to make sure the /installer/ files inside are all owned by admin
, otherwise you will get permission denied errors)
I'd recommend also putting the output into a log file:
@daily perl /installer/add-autodiscover-all.cgi /var/log/hestia/autoconfigure.log