-
-
Save zgover/6c9347612773b26567feeca366043326 to your computer and use it in GitHub Desktop.
Automatic script for Mikrotik RouterOS updating record on CloudFlare.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
######################################################################### | |
# ================================================== # | |
# $ Mikrotik RouterOS update script for CloudFlare $ # | |
# ================================================== # | |
# # | |
# - You need a CloudFlare account & api key (look under settings), # | |
# a zone and A record in it # | |
# - All variables in first section are obvious, except CFid, # | |
# To obtain CFzoneid use following command in any unix shell: # | |
# curl -X GET "https://api.cloudflare.com/client/v4/zones" -H "X-Auth-Email: YOUR_EMAIL" -H "X-Auth-Key: YOUR_API_KEY" -H "Content-Type: application/json" | python -mjson.tool | |
# To obtain CFid use following command in any unix shell: # | |
# curl -X GET "https://api.cloudflare.com/client/v4/zones/YOUR_ZONE_ID/dns_records" -H "X-Auth-Email: YOUR_EMAIL" -H "X-Auth-Key: YOUR_API_KEY" -H "Content-Type: application/json" | python -mjson.tool | |
# - Enable CFDebug if needed - it'll print some info to logs # | |
# - Put script under /system scripts giving "read,write,ftp" policy access. # | |
# For 6.29 and older "test" policy is also needed. # | |
# - Add script to /system scheduler using it's name in "on-event" # | |
# - Requires at least RouterOS 6.44beta75 for multiple header support # | |
# # | |
# Credits for Samuel Tegenfeldt, CC BY-SA 3.0 # | |
# Modified by kiler129 # | |
# Modified by viritt # | |
# Modified by asuna # | |
######################################################################### | |
################# CloudFlare variables ################# | |
:local CFDebug "true" | |
:global WANInterface "ether1-gateway" | |
:local CFdomain "sub.domain.com" | |
:local CFzone "domain.com" | |
:local CFemail "[email protected]" | |
:local CFtkn "YOUR_API_KEY" | |
:local CFzoneid "YOUR_ZONE_ID" | |
:local CFid "YOUR_ID" | |
:local CFrecordType "" | |
:set CFrecordType "A" | |
:local CFrecordTTL "" | |
:set CFrecordTTL "120" | |
######################################################################### | |
######################## DO NOT EDIT BELOW ############################ | |
######################################################################### | |
################# Internal variables ################# | |
:local previousIP "" | |
:global WANip "" | |
################# Get or set previous IP-variables ################# | |
:local currentIP [/ip address get [/ip address find interface=$WANInterface ] address]; | |
:set WANip [:pick $currentIP 0 [:find $currentIP "/"]]; | |
:if ([/file find name=ddns.tmp.txt] = "") do={ | |
:log error "No previous ip address file found, createing..." | |
:set previousIP $WANip; | |
:execute script=":put $WANip" file="ddns.tmp"; | |
:log info ("CF: Updating CF, setting $CFDomain = $WANip") | |
/tool fetch http-method=put mode=https output=none url="$CFurl" http-header-field="X-Auth-Email:$CFemail,X-Auth-Key:$CFtkn,content-type:application/json" http-data="{\"type\":\"$CFrecordType\",\"name\":\"$CFdomain\",\"ttl\":$CFrecordTTL,\"content\":\"$WANip\"}" | |
:error message="No previous ip address file found." | |
} else={ | |
:if ( [/file get [/file find name=ddns.tmp.txt] size] > 0 ) do={ | |
:global content [/file get [/file find name="ddns.tmp.txt"] contents] ; | |
:global contentLen [ :len $content ] ; | |
:global lineEnd 0; | |
:global line ""; | |
:global lastEnd 0; | |
:set lineEnd [:find $content "\n" $lastEnd ] ; | |
:set line [:pick $content $lastEnd $lineEnd] ; | |
:set lastEnd ( $lineEnd + 1 ) ; | |
:if ( [:pick $line 0 1] != "#" ) do={ | |
#:local previousIP [:pick $line 0 $lineEnd ] | |
:set previousIP [:pick $line 0 $lineEnd ]; | |
:set previousIP [:pick $previousIP 0 [:find $previousIP "\r"]]; | |
} | |
} | |
} | |
################# Build CF API Url (v4) ################# | |
:local CFurl "https://api.cloudflare.com/client/v4/zones/" | |
:set CFurl ($CFurl . "$CFzoneid/dns_records/$CFid"); | |
######## Write debug info to log ################# | |
:if ($CFDebug = "true") do={ | |
:log info ("CF: hostname = $CFdomain") | |
:log info ("CF: previousIP = $previousIP") | |
:log info ("CF: currentIP = $currentIP") | |
:log info ("CF: WANip = $WANip") | |
:log info ("CF: CFurl = $CFurl&content=$WANip") | |
:log info ("CF: Command = \"/tool fetch http-method=put mode=https url=\"$CFurl\" http-header-field=\"X-Auth-Email:$CFemail,X-Auth-Key:$CFtkn,content-type:application/json\" output=none http-data=\"{\"type\":\"$CFrecordType\",\"name\":\"$CFdomain\",\"ttl\":$CFrecordTTL,\"content\":\"$WANip\"}\"") | |
}; | |
######## Compare and update CF if necessary ##### | |
:if ($previousIP != $WANip) do={ | |
:log info ("CF: Updating CF, setting $CFDomain = $WANip") | |
/tool fetch http-method=put mode=https url="$CFurl" http-header-field="X-Auth-Email:$CFemail,X-Auth-Key:$CFtkn,content-type:application/json" output=none http-data="{\"type\":\"$CFrecordType\",\"name\":\"$CFdomain\",\"ttl\":$CFrecordTTL,\"content\":\"$WANip\"}" | |
/ip dns cache flush | |
:if ( [/file get [/file find name=ddns.tmp.txt] size] > 0 ) do={ | |
/file remove ddns.tmp.txt | |
:execute script=":put $WANip" file="ddns.tmp" | |
} | |
} else={ | |
:log info "CF: No Update Needed!" | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment