Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/deg0nz/inwx-mailcow-dns-configurator
Little program that automatically sets the needed DNS entries for running mailcow at the INWX domain registrar
https://github.com/deg0nz/inwx-mailcow-dns-configurator
dns inwx mailcow
Last synced: 2 months ago
JSON representation
Little program that automatically sets the needed DNS entries for running mailcow at the INWX domain registrar
- Host: GitHub
- URL: https://github.com/deg0nz/inwx-mailcow-dns-configurator
- Owner: deg0nz
- License: mit
- Created: 2019-01-22T21:20:44.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2020-09-16T19:42:40.000Z (over 4 years ago)
- Last Synced: 2024-07-31T14:09:05.878Z (5 months ago)
- Topics: dns, inwx, mailcow
- Language: JavaScript
- Size: 14.6 KB
- Stars: 1
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# inwx-mailcow-dns-configurator
Unfortunately the INWX web interface only lets you enter one DNS entry at a time and adding multiple domains to your mail server can get really annoying there.
So I wrote this for quickly adding new domains to my mailserver. It is also possible to add a new mail server (add A and AAAA records as well).This is more a tool that automates entering the needed DNS records and assumes that you know what you are doing.
## TODO
* Implement CLI
* Cleanup
* Make SPF, DKIM and DMARC entries more configurable (via config)
* Save entered DNS-entry-IDs for deleteing them *(maybe)*## Prerequisites
* NodeJS >= 8.x.x
## Installation
``` bash
git clone https://github.com/deg0nz/inwx-mailcow-dns-configurator
cd inwx-mailcow-dns-configurator
npm install
```## Configure
Please refer to [https://mailcow.github.io/mailcow-dockerized-docs/prerequisite-dns/](https://mailcow.github.io/mailcow-dockerized-docs/prerequisite-dns/) for DNS configuration options.
The testing API is for INWX's testing instance [https://ote.inwx.de](https://ote.inwx.de), the production API is for the normal inwx.de. You can make an account on the OTE instance and test your configuration at first use.
The `dns_records` object defines whether certain DNS entries should be created or not.
Rename `config.example.json` to `config.json` and adjust it to your needs:
``` json
{
"login": {
"api": "testing",
"user": "",
"password": ""
},
"domains": {
"dns_entry_domain": "123qwe.eu",
"mailserver": "mail.123qwe.eu"
},
"dkim_public_key": "",
"mailauth_reports_address": "[email protected]",
"mail_records": {
"a": "192.168.0.1",
"aaaa": "fe80::1"
},
"dns_records" : {
"mail_a": false,
"mail_aaaa": false,
"dmarc_txt": false,
"dkim_txt": true,
"autodiscover_cname":true,
"autoconfig_cname": true,
"mx": true,
"pop3_srv": true,
"pop3s_srv": true,
"imap_srv": true,
"imaps_srv": true,
"smtps_srv": true,
"submission_srv": true,
"autodiscover_srv": true,
"spf_txt": true,
"caldav_srv": true,
"caldav_txt": true,
"carddav_srv": true,
"carddav_txt": true
}
}
```## Run
Until the real Command Line Interface is not ready, you need to run the `index.js` directly:
``` bash
node index.js
```