Simple application to sync your Cloudflare DNS records with your local IP address.
This section is under construction.
As of now, you can download the latest release from the releases page.
This section describes how to configure the application.
The configuration file is located at /etc/goflaresync/config.yaml
by default.
While configuring the application, you will be asked to provide your Cloudflare credentials.
These credentials are used to authenticate with the Cloudflare API.
Here is an example of the credentials section:
credentials:
email: [email protected]
token: 1234567890qwerty
While configuring the application, you will be asked to provide your Cloudflare DNS records.
These records are used to identify the DNS records that should be monitored and updated in the case of an IP address change.
Here is an example of the records section:
records:
- name: example.com
type: A
- name: subdomain.example.com
type: A
It is worth noting that all of the existing attributes of the record will be preserved upon the update.
The only attribute that will be changed is the IP address (content).
This section describes the watcher configuration and is optional.
By default, the watcher will check for an IP address change every 5 minutes and will use https://api.ipify.org
to retrieve the IP address.
If you want to change the interval or the IP address provider, you can do so by adding the following section to your configuration file:
watcher:
interval: 5m
address_source: https://api.ipify.org
This section describes the log level configuration and is optional.
By default, the log level is set to info
.
If you want to change the log level, you can do so by adding the following section to your configuration file:
log_level: debug
Supported log levels:
t
|trace
|Trace
|TRACE
- displays all log messagesd
|debug
|Debug
|DEBUG
- displays debug log messagesi
|info
|Info
|INFO
- displays info log messagesw
|warn
|warning
|Warn
|Warning
|WARN
|WARNING
- displays warn log messagese
|err
|error
|Err
|Error
|ERR
|ERROR
- displays error log messagesf
|fatal
|Fatal
|FATAL
- displays fatal log messagesp
|panic
|Panic
|PANIC
- displays panic log messages
Here is a complete configuration example:
credentials:
email: [email protected]
token: 1234567890qwerty
records:
- name: example.com
type: A
- name: subdomain.example.com
type: A
watcher:
interval: 5m
address_source: https://api.ipify.org
log_level: debug
This section describes how to use the application.
The following flags are available:
--configuration-path
- Path to the configuration file. (default:/etc/goflaresync
)--configuration-name
- Name of the configuration file. (default:config
)--configuration-extension
- Extension of the configuration file. (default:yaml
)
The following commands are available:
help
- Help about any commandstart
- Start the applicationversion
- Print the version number of GoFlareSyncconfiguration
- Meta command that provides access to configuration related commandsconfiguration display
- Displays the current configuration (omits the E-Mail and API Key)configuration display-full
- Displays the current configuration (includes the E-Mail and API Key)
service
- Meta command that provides access to service related commandsservice install
- Installs the application as a service (also enables the service to start on boot)service uninstall
- Uninstalls the application as a serviceservice start
- Starts the application as a serviceservice stop
- Stops the application as a serviceservice restart
- Restarts the application as a serviceservice enable
- Enables the service to start on bootservice disable
- Disables the service to start on boot