## setmycfdns - DNS updates for Cloudflare
The scenerio exists where a servers public (external) IP address can change over time. This is especially true with cloud computing.
As instances are stopped or hibernated and then restarted - their public IPs change, leaving public DNS records out of date.
This program can be used to update CloudFlare zone records when a server reboots or returns from hibernation. This gives CloudFlare users the same benifit as a cloud-native DNS solutions.
### Limitations
`setmycfdns` will update ***existing*** DNS records - the records must ***already exist*** in your CloudFlare zone.
`setmycfdns` doesn't create or remove records (well... look at the undocumented options --create-record and --delete-record)
This is by design to prevent things from going wrong.
`setmycfdns` updates **A** and **AAAA** DNS records; other records are not supported.
## setmycfdns Command Usage and Options
After configuring `setmycfdns` is simple to use and in most instances does not require any special switchs.
```bash
% setmycfdns
```
This will **automatically** find your public IP address and update the dns zone record based on the *fully qualifed domain name* (fqdn) of your computer.
In a more complex configuration you can use a different name or multiple ip address.
```bash
% setmycfdns --fqdn first.example.com
% setmycfdns --fqdn second.example.com -ip 100.100.22.23
```
A list of all availabe options:
```
% setmycfdns --help
usage: setmycfdns [-h] [-v] [-ip IP] [-fqdn FQDN] [-q] [-z ZONE] [-6]
Update CloudFlare IP record
optional arguments:
-h, --help show this help message and exit
-v, --version show program's version number and exit
-ip IP, --ip IP set specific IP address to use
-fqdn FQDN, --fqdn FQDN
Fully Qualified Domain Name (rkmbp.sunyocc.edu)
-q, --query Query only - no updates are made
-z ZONE, --zone ZONE Cloudflare Zone to update (optional)
-6 Update AAAA record (default is A record)
setmycfdns gunville 2024 v2
#### Automatic IP detection:
By default `setmyip` automatically detects the public IP address by sending an HTTP request to [ipv4.icanhazip.com](http://ipv4.icanhazip.com). This site returns the IPv4 address of the sender.
You can optionally use a different site to autodetect the public ip by setting the environment variable `IPAPIURL` to that URL:
```bash
% IPAPIURL='http://api.ipify.org'
% setmycfdns
````
You can do the same for IPv6 using `IPV6APIURL`.
When ipv6 is selected with the `-6` switch automatic detection uses the ipv6 stack. [ipv6.icanhazip.com](http://ipv6.icanhazip.com).
If your host has multiple ip addresses or uses a proxy for web requests you will need to provide the ip address to use with the `--ip IP` command line switch.
```bash
% setmycfdns -ip 100.123.4.56
% setmycfdns -6 -ip 2600:1f16:a44:1701:1be3:f8b7:aa51:410b
```
#### Automatic Hostname Determination:
The fqdn of the host is acquired with the Python `socket.gethostname()` function. (Several solutions were tried, none worked perfect, but this one seems to work best.)
There are some limitations to hostname determination:
* Some systems are not configured to provide the fqdn (*web01.example.com*) and provide only the short hostname (*web01*). There is no elegant and simple solution that works on all platforms and configurations.
* In some environments the hostname on the private side (e.g. web01.local) is not the same one used on the public side (web01.example.com).
* Likewise, cloud VPCs by default provide hostnames in a similar fashion (e.g. *ip-172-31-84-22.ec2.internal*)
In these cases you will be required to provide the full fqdn with the `--fqdn FQDN` switch.
```bash
% setmycfdns --fqdn web01.example.com
```
#### CloudFlare Zone selection:
The cloudflare zone is selected from the FQDN, but can also explicity provided with the `--zone ZONE` switch.
If the `--zone` switch is used the the zone does not match the hostname determined above, the fqdn is constructed by appending the zone.
```bash
% hostname
server1
% setmycfdns --fqdn server1.example.com # server1.example.com
% setmycfdns --fqdn server1 --zone example.com # server1.example.com
% setmycfdns --zone eample.com # server1.example.com
```
The above are identical. Note that the `fqdn` does not have to be 'fully qualified' when the `--zone` switch is used.
#### IPv6 Support
Both ipv4 **A** and ipv6 **AAAA** DNS records are supported by `setmycfdns`. To update ipv6 records the `-6` switch is used - and required.
```bash
% setmycfdns -6
```
# Installation and Configuration
`setmycfdns` is easily installed using `pip`
```bash
% pip install setmycfdns
```
#### CloudFlare API Keys
CloudFlare credentials (API keys) are required. You will need to generate these in your CloudFlare account.
Generally a `.cloudflare.cf` file in the users home directory or the current working directory, but there are several options. The format is dictated by the `python-cloudflare` API library and [details can be found here.](https://github.com/cloudflare/python-cloudflare/blob/master/README.md)
***Remember to always protect these API keys.***
#### Configuring `setmycfdns` to Run On Reboots (optional)
The following `crontab` entry will run `setmycfdns` each time the server reboots.
```
@reboot /usr/local/bin/setmycfdns
```
The actual path depends on where you install `setmycfdns`
#### Configuring `setmycfdns` To Run Post Hibernation (optional)
This may differ some depending on the operating system. This example here works with RedHat flavors.
* Create the following file in `/lib/systemd/system-sleep/`
* Add these contents of the file
* Set the file to be excutable
```bash
% sudo touch /lib/systemd/system-sleep/20_cfdns
% sudo chomd +x /lib/systemd/system-sleep/20_cfdns
% cat > /lib/systemd/system-sleep/20_cfdns <<EOF
#!/usr/bin/env bash
action="$1/$2"
case "$action" in
pre/hibernate)
;;
post/hibernate)
/usr/local/bin/setmycfdns
;;
esac
>>
```
The actual path depends on where you install `setmycfdns`
Raw data
{
"_id": null,
"home_page": "https://github.com/Glocktober/setmycfdns",
"name": "setmycfdns",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.6",
"maintainer_email": null,
"keywords": "'cloudflare cloud dns'",
"author": "gunville",
"author_email": "rk13088@yahoo.com",
"download_url": "https://files.pythonhosted.org/packages/86/07/043be173097bf09ffba05533548036d5c79e5672d45c502a0ebe7f5907be/setmycfdns-24.12.25.tar.gz",
"platform": null,
"description": "\n## setmycfdns - DNS updates for Cloudflare\n\nThe scenerio exists where a servers public (external) IP address can change over time. This is especially true with cloud computing. \n\nAs instances are stopped or hibernated and then restarted - their public IPs change, leaving public DNS records out of date.\n\nThis program can be used to update CloudFlare zone records when a server reboots or returns from hibernation. This gives CloudFlare users the same benifit as a cloud-native DNS solutions.\n\n### Limitations\n`setmycfdns` will update ***existing*** DNS records - the records must ***already exist*** in your CloudFlare zone. \n\n`setmycfdns` doesn't create or remove records (well... look at the undocumented options --create-record and --delete-record)\n\nThis is by design to prevent things from going wrong.\n\n`setmycfdns` updates **A** and **AAAA** DNS records; other records are not supported.\n\n## setmycfdns Command Usage and Options\nAfter configuring `setmycfdns` is simple to use and in most instances does not require any special switchs.\n```bash\n % setmycfdns \n```\nThis will **automatically** find your public IP address and update the dns zone record based on the *fully qualifed domain name* (fqdn) of your computer.\n\nIn a more complex configuration you can use a different name or multiple ip address.\n```bash\n % setmycfdns --fqdn first.example.com\n % setmycfdns --fqdn second.example.com -ip 100.100.22.23\n```\nA list of all availabe options:\n```\n% setmycfdns --help\nusage: setmycfdns [-h] [-v] [-ip IP] [-fqdn FQDN] [-q] [-z ZONE] [-6]\n\nUpdate CloudFlare IP record\n\noptional arguments:\n -h, --help show this help message and exit\n -v, --version show program's version number and exit\n -ip IP, --ip IP set specific IP address to use\n -fqdn FQDN, --fqdn FQDN\n Fully Qualified Domain Name (rkmbp.sunyocc.edu)\n -q, --query Query only - no updates are made\n -z ZONE, --zone ZONE Cloudflare Zone to update (optional)\n -6 Update AAAA record (default is A record)\n\nsetmycfdns gunville 2024 v2\n\n#### Automatic IP detection:\n\nBy default `setmyip` automatically detects the public IP address by sending an HTTP request to [ipv4.icanhazip.com](http://ipv4.icanhazip.com). This site returns the IPv4 address of the sender.\n\nYou can optionally use a different site to autodetect the public ip by setting the environment variable `IPAPIURL` to that URL:\n```bash\n% IPAPIURL='http://api.ipify.org'\n% setmycfdns\n````\nYou can do the same for IPv6 using `IPV6APIURL`.\n\nWhen ipv6 is selected with the `-6` switch automatic detection uses the ipv6 stack. [ipv6.icanhazip.com](http://ipv6.icanhazip.com).\n\nIf your host has multiple ip addresses or uses a proxy for web requests you will need to provide the ip address to use with the `--ip IP` command line switch.\n\n```bash\n% setmycfdns -ip 100.123.4.56\n% setmycfdns -6 -ip 2600:1f16:a44:1701:1be3:f8b7:aa51:410b \n```\n\n#### Automatic Hostname Determination:\n\nThe fqdn of the host is acquired with the Python `socket.gethostname()` function. (Several solutions were tried, none worked perfect, but this one seems to work best.)\n\nThere are some limitations to hostname determination:\n* Some systems are not configured to provide the fqdn (*web01.example.com*) and provide only the short hostname (*web01*). There is no elegant and simple solution that works on all platforms and configurations. \n\n* In some environments the hostname on the private side (e.g. web01.local) is not the same one used on the public side (web01.example.com).\n\n* Likewise, cloud VPCs by default provide hostnames in a similar fashion (e.g. *ip-172-31-84-22.ec2.internal*)\n\nIn these cases you will be required to provide the full fqdn with the `--fqdn FQDN` switch.\n```bash\n% setmycfdns --fqdn web01.example.com \n```\n\n#### CloudFlare Zone selection:\n\nThe cloudflare zone is selected from the FQDN, but can also explicity provided with the `--zone ZONE` switch.\n\nIf the `--zone` switch is used the the zone does not match the hostname determined above, the fqdn is constructed by appending the zone.\n```bash\n% hostname\nserver1\n% setmycfdns --fqdn server1.example.com # server1.example.com\n% setmycfdns --fqdn server1 --zone example.com # server1.example.com\n% setmycfdns --zone eample.com # server1.example.com\n```\n\nThe above are identical. Note that the `fqdn` does not have to be 'fully qualified' when the `--zone` switch is used.\n\n#### IPv6 Support\n\nBoth ipv4 **A** and ipv6 **AAAA** DNS records are supported by `setmycfdns`. To update ipv6 records the `-6` switch is used - and required.\n\n```bash\n% setmycfdns -6\n```\n\n# Installation and Configuration\n`setmycfdns` is easily installed using `pip`\n```bash\n% pip install setmycfdns\n```\n\n#### CloudFlare API Keys\n\nCloudFlare credentials (API keys) are required. You will need to generate these in your CloudFlare account.\n\nGenerally a `.cloudflare.cf` file in the users home directory or the current working directory, but there are several options. The format is dictated by the `python-cloudflare` API library and [details can be found here.](https://github.com/cloudflare/python-cloudflare/blob/master/README.md)\n\n***Remember to always protect these API keys.***\n\n#### Configuring `setmycfdns` to Run On Reboots (optional)\n\nThe following `crontab` entry will run `setmycfdns` each time the server reboots. \n```\n@reboot /usr/local/bin/setmycfdns\n```\nThe actual path depends on where you install `setmycfdns`\n\n#### Configuring `setmycfdns` To Run Post Hibernation (optional)\nThis may differ some depending on the operating system. This example here works with RedHat flavors.\n* Create the following file in `/lib/systemd/system-sleep/`\n* Add these contents of the file \n* Set the file to be excutable\n\n```bash\n% sudo touch /lib/systemd/system-sleep/20_cfdns\n% sudo chomd +x /lib/systemd/system-sleep/20_cfdns\n% cat > /lib/systemd/system-sleep/20_cfdns <<EOF\n#!/usr/bin/env bash\naction=\"$1/$2\"\ncase \"$action\" in\n pre/hibernate)\n ;;\n post/hibernate)\n\t/usr/local/bin/setmycfdns\n ;;\nesac\n>>\n```\nThe actual path depends on where you install `setmycfdns`\n",
"bugtrack_url": null,
"license": null,
"summary": "Updates a hosts cloudflare record",
"version": "24.12.25",
"project_urls": {
"Homepage": "https://github.com/Glocktober/setmycfdns",
"overview": "https://github.com/Glocktober/setmycfdns/blob/master/README.md",
"repo": "https://github.com/Glocktober/setmycfdns.git"
},
"split_keywords": [
"'cloudflare",
"cloud",
"dns'"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "c2065e0cd65554b361aa4ba3b348fd892df29eef6ea393b31103b4c512d79027",
"md5": "480dbf49f8d9ce91bc8a910b92a88402",
"sha256": "d25cce983476d2a606c1f1e305a6506cfc3cb71e2009f081f91aaab668ec8f67"
},
"downloads": -1,
"filename": "setmycfdns-24.12.25-py3-none-any.whl",
"has_sig": false,
"md5_digest": "480dbf49f8d9ce91bc8a910b92a88402",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.6",
"size": 9194,
"upload_time": "2024-12-26T03:11:58",
"upload_time_iso_8601": "2024-12-26T03:11:58.537347Z",
"url": "https://files.pythonhosted.org/packages/c2/06/5e0cd65554b361aa4ba3b348fd892df29eef6ea393b31103b4c512d79027/setmycfdns-24.12.25-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8607043be173097bf09ffba05533548036d5c79e5672d45c502a0ebe7f5907be",
"md5": "ca1d68206378f2c04e10abcb544d44ca",
"sha256": "f5ba84c85456f5299af66605504fe57d4288b44c5b3d95c02660d81e5a221b7d"
},
"downloads": -1,
"filename": "setmycfdns-24.12.25.tar.gz",
"has_sig": false,
"md5_digest": "ca1d68206378f2c04e10abcb544d44ca",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.6",
"size": 10643,
"upload_time": "2024-12-26T03:11:59",
"upload_time_iso_8601": "2024-12-26T03:11:59.603441Z",
"url": "https://files.pythonhosted.org/packages/86/07/043be173097bf09ffba05533548036d5c79e5672d45c502a0ebe7f5907be/setmycfdns-24.12.25.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-26 03:11:59",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "Glocktober",
"github_project": "setmycfdns",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [
{
"name": "cloudflare",
"specs": [
[
">=",
"3.1.1"
]
]
},
{
"name": "requests",
"specs": [
[
">=",
"2.32.1"
]
]
}
],
"lcname": "setmycfdns"
}