What's new
  • SNBForums Code of Conduct

    SNBForums is a community for everyone, no matter what their level of experience.

    Please be tolerant and patient of others, especially newcomers. We are all here to share and learn!

    The rules are simple: Be patient, be nice, be helpful or be gone!

VPNMON VPNMON-R3 v1.7.0 -Sep 20, 2025- Monitor OpenVPN/Wireguard WAN/Dual-WAN Health & Random Reset Multiple Connections (Available in AMTM!) - v1.8.0 Beta6

Still working well on b4. At least for every site I check outside of the below.

One thing that is semi related to this… but Netflix refuses to resolve DNS when over WG. Always get SERVFAIL.

Curious if others see similar results using WG or OVPN for unbound. I’m using ProtonVPN.
I've had similar issues with Proton and Netflix, whether it was on VPN or WG. I think Proton is being blacklisted somehow. I made an exception for my TV to use an alternate DNS provider.

I'm thinking of switching my Unbound WG connections to AirVPN.
 
I've had similar issues with Proton and Netflix, whether it was on VPN or WG. I think Proton is being blacklisted somehow. I made an exception for my TV to use an alternate DNS provider.

I'm thinking of switching my Unbound WG connections to AirVPN.

Thanks for confirming that behavior.

I’ve reached out to Proton support to see if they have a suggestion.
 
Been playing with AirVPN's implementation of Wireguard, and found that in order to make a successful connection, not only do you need a Public Key, a Private Key, but also a PreShared Key (which is labeled as optional in the UI, and isn't used by either Nord or Proton).

Looks like VPNMON-R3 will be requiring a 6th field entry (optional) for this PreShared Key. Coming to you soon in the very next Beta.

Format: ConnectionName,EndpointIP,EndpointPort,PrivateKey,PublicKey,PreSharedKey(Opt)
Example: City WG,143.32.55.23,34334,fasdkkfj44j38affkasdjfj=,221t949asas42dfj32323kf=,fjfjad4953293fjsfjasdlkfj=
 
Hopefully the last beta before we get this release out the door! Compatibility for AirVPN WG has been added!

What's new?!
v1.6.0b5 - (TBA)
- PATCH:
Added compatibility for AirVPN WG, which not only requires a Public Key, a Private Key, but also a Preshared Key. A 6th field is now an optional requirement for AirVPN or vpn providers like them who require this field. Both the Update/Maintain WG server lists and Run Server List Automation screens have updated language, while code in charge of resetting the WG connection will insert this Preshared Key into the appropriate NVRAM value for the WGC slot.

Download link:
Code:
curl --retry 3 "https://raw.githubusercontent.com/ViktorJp/VPNMON-R3/develop/vpnmon-r3.sh" -o "/jffs/scripts/vpnmon-r3.sh" && chmod 755 "/jffs/scripts/vpnmon-r3.sh"

Significant Screenshots:

Showing both screens that have the new info included about the 6th optional Preshared Key field:

1755737732019.png


1755737766469.png
 
Happy to announce the next version of VPNMON-R3 v1.6.0! Super excited to offer "Unbound over Wireguard" with many thanks to @ZebMcKayhan for his awesome guidance and incredible expertise on the subject! I truly appreciate your contributions to this! Also, huge thanks to all of you beta testers! Wouldn't have gotten this far without you - thank you @CaptainSTX , @fourty6and2 , @iTyPsIDg , @Stephen Harrington, and @ZebMcKayhan (and anyone else I may have forgotten)! :)

What's new!
v1.6.0 - (August 21, 2025)
- MINOR:
Very happy to announce that "Unbound-over-Wireguard" has actually become a reality! With huge help and guidance from @ZebMcKayhan, a methodology was developed that is easier, simpler and much more elegant than it's Unbound-over-VPN twin. In essence, VPNMON-R3 creates a new virtual br0 interface, ties that to the WG client of your choice, and assigns that virtual br0 IP as the designated outgoing interface. Should the Wireguard client happen to go down or stop, Unbound will continue to resolve DNS directly over the WAN.
- PATCH: Based on a recommendation from @JGrana, the RL (Email Rate Limiting) indicators will no longer show up on the main UI (or in the config display) when AMTM email functionality is turned off.
- PATCH: Thanks to the keen eye of @ZebMcKayhan, important failsafe's for Unbound were not yet being addressed. This version adds those failsafes. If you're coming from Beta 1, please make sure you (1) update your script to Beta 2, (2) Disable Unbound over WG, (3) Re-enable Unbound over WG. This process will then write the appropriate commands to your init-start and nat-start files.
- PATCH: Implemented Recovery Timeout Opportunities, they're kind of like second chances to allow your connection to recover before issuing a restart. By default, connections will restart after your timer loop finishes (default: 60 sec). The Recovery Timeout would extend the number of loops before it would issue a reset, and hopefully within that time, would recover the connection on its own. For example, your timer loop = 60 seconds. Your Recovery Timeout is set to 3x. This would mean if your connection doesn't recover in 3 minutes, then it will issue a reset. This option might help bring down the amount of times your connection resets throughout the day, but then there's also a greater chance your connection might become unusable for a slightly longer amount of time. This was inspired by @CaptainSTX! Thank you!
- PATCH: Added the router uptime value under the WAN monitoring section, some visual enhancements to the main UI, and providing content values in the logs when you get "invalid ping response received" messages, showing exactly what it was coming back with.
- PATCH: Added compatibility for AirVPN WG, which not only requires a Public Key, a Private Key, but also a Preshared Key. A 6th field is now an optional requirement for AirVPN or vpn providers like them who require this field. Both the Update/Maintain WG server lists and Run Server List Automation screens have updated language, while code in charge of resetting the WG connection will insert this Preshared Key into the appropriate NVRAM value for the WGC slot.

Download link (or update directly through AMTM/VPNMON-R3):
Code:
curl --retry 3 "https://raw.githubusercontent.com/ViktorJp/VPNMON-R3/main/vpnmon-r3.sh" -o "/jffs/scripts/vpnmon-r3.sh" && chmod 755 "/jffs/scripts/vpnmon-r3.sh"

Significant Screenshots:

Too many changes to mention... but here's a few newly added: (1) Email Rate Limiting, (2) Recovery Timeout Opportunities and (3) Unbound over Wireguard! If you have questions about usage or anything, please don't hesitate to drop a note below and I (or the rest of this great community) will help out the best we can. :)

1755822205791.png
 
Last edited:
I'm interested in the dual WAN monitoring of this script.
My primary WAN connection is via Ethernet, while the secondary (backup) WAN is an LTE USB stick, intended to take over in case the primary WAN connection fails.
Currently, I'm using the built-in Asus dual WAN failover and failback functionality.
While it generally works, I've noticed that it occasionally fails to revert to the primary WAN once it's back online.
Would this script be capable of reliably switching back to the primary WAN, once it detects that the connection has been restored?
Thanks in advance.
Edit:
I’ve chosen not to use the dual WAN failover script, as it too has proven unreliable in consistently switching back to the primary WAN once it's available.
 
Last edited:
I'm interested in the dual WAN monitoring of this script.
My primary WAN connection is via Ethernet, while the secondary (backup) WAN is an LTE USB stick, intended to take over in case the primary WAN connection fails.
Currently, I'm using the built-in Asus Dual WAN failover and failback functionality.
While it generally works, I've noticed that it occasionally fails to revert to the primary WAN once it's back online.
Would this script be capable of reliably switching back to the primary WAN, once it detects that the connection has been restored?
Thanks in advance.
No, unfortunately not. It just tells you the status of the WAN. If the WAN goes down, it will clean up all connections and wait around until it comes back up by testing it every few minutes. Once it does come back up, it reestablishes the VPN/WG connections.

If you're looking for a great dual WAN script, look no further than @Ranger802004's. It's excellent.
 
Just installed VPNMON-R3 using AMTM. I am wondering why there are constant WG pings in the log
when I have no WG Slots with monitoring enabled. I realize the the log is trimmed automatically so should not
be a problem. Just curious if something isn't right.

Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5771 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5772 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5773 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5774 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5775 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5776 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5777 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5778 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5779 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
 

Attachments

  • Screenshot 2025-08-22 102350.png
    Screenshot 2025-08-22 102350.png
    260.3 KB · Views: 25
Just installed VPNMON-R3 using AMTM. I am wondering why there are constant WG pings in the log
when I have no WG Slots with monitoring enabled. I realize the the log is trimmed automatically so should not
be a problem. Just curious if something isn't right.

Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5771 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5772 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5773 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5774 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5775 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5776 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5777 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5778 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5779 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
Interesting catch! Thanks for letting me know. Yeah, you shouldn't be seeing any WG pings if you have no WG connections. Let me see if I can get that fixed. ;)
 
Just installed VPNMON-R3 using AMTM. I am wondering why there are constant WG pings in the log
when I have no WG Slots with monitoring enabled. I realize the the log is trimmed automatically so should not
be a problem. Just curious if something isn't right.

Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5771 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5772 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5773 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5774 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5775 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5776 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5777 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5778 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5779 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
AH HA, this is due to your monitoring if WG is in use. Saw the answer when I when to get the VPNMON-R3 config to add
to the post.

useovpn=1
usewg=1

When into the configuration option and disabled WG monitoring.
No more WG pings.
Now if I can somehow remember I did this when I set-up WG in the future !!!
 
Last edited:
AH HA, this is due to your monitoring if WG is in use. Saw the answer when I when to get the VPNMON-R3 config to add
to the post.

useovpn=1
usewg=1

When into the configuration option and disabled WG monitoring.
No more WG pings.
Now if I can somehow remember I did this when I set-up WG in the future !!!
Good info... Still shouldn't give you weird ping results if there's no WG connection. I have a feeling it's borrowing something from the VPN side. I'll get it fixed. ;)
 
Been playing with AirVPN's implementation of Wireguard, and found that in order to make a successful connection, not only do you need a Public Key, a Private Key, but also a PreShared Key (which is labeled as optional in the UI, and isn't used by either Nord or Proton).

Looks like VPNMON-R3 will be requiring a 6th field entry (optional) for this PreShared Key. Coming to you soon in the very next Beta.

Format: ConnectionName,EndpointIP,EndpointPort,PrivateKey,PublicKey,PreSharedKey(Opt)
Example: City WG,143.32.55.23,34334,fasdkkfj44j38affkasdjfj=,221t949asas42dfj32323kf=,fjfjad4953293fjsfjasdlkfj=
What happens if the list is still only five values? Will it ignore or throw an error?
 
Small patch update to v1.6.1 thanks to a bug report from @scootertramp! Much appreciated! :)

What's new?
v1.6.1 - (August 23, 2025)
- PATCH:
Small bug fix to prevent "Invalid WG PING Information" log errors from coming through even if WG functionality was not enabled. Thanks much to @scootertramp for reporting this issue!

Download link (or update directly within AMTM or VPNMON-R3 itself):
Code:
curl --retry 3 "https://raw.githubusercontent.com/ViktorJp/VPNMON-R3/main/vpnmon-r3.sh" -o "/jffs/scripts/vpnmon-r3.sh" && chmod 755 "/jffs/scripts/vpnmon-r3.sh"

Significant Screenshots:

Just preventing these from coming through even if WG is disabled:

Code:
5770 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5771 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5772 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5773 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5774 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5775 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5776 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5777 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5778 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5779 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
 
Small patch update to v1.6.1 thanks to a bug report from @scootertramp! Much appreciated! :)

What's new?
v1.6.1 - (August 23, 2025)
- PATCH:
Small bug fix to prevent "Invalid WG PING Information" log errors from coming through even if WG functionality was not enabled. Thanks much to @scootertramp for reporting this issue!

Download link (or update directly within AMTM or VPNMON-R3 itself):
Code:
curl --retry 3 "https://raw.githubusercontent.com/ViktorJp/VPNMON-R3/main/vpnmon-r3.sh" -o "/jffs/scripts/vpnmon-r3.sh" && chmod 755 "/jffs/scripts/vpnmon-r3.sh"

Significant Screenshots:

Just preventing these from coming through even if WG is disabled:

Code:
5770 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5771 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5772 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5773 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5774 Aug 22 2025 10:24:10 rt-ax92u VPNMON-R3[1146] - WARNING: Invalid WG PING information received. Contents: Null
5775 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5776 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5777 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5778 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
5779 Aug 22 2025 10:25:06 rt-ax92u VPNMON-R3[30389] - WARNING: Invalid WG PING information received. Contents: Null
Thanks for the update.
Re-enabled WG monitoring and now have a nice quiet log file.
 
Sorry for the successive bug fix updates, but came across another one today dealing with Unbound.

What's new?
v1.6.2 - (August 24, 2025)
- PATCH:
Apologies for the successive bug fix patches, but found another one stemming from an Unbound variable that was not being reset, and causing the [UB] indicator to show up on slots that weren't designated as Unbound slots.

Download link (or update directly within AMTM or VPNMON-R3 itself):
Code:
curl --retry 3 "https://raw.githubusercontent.com/ViktorJp/VPNMON-R3/main/vpnmon-r3.sh" -o "/jffs/scripts/vpnmon-r3.sh" && chmod 755 "/jffs/scripts/vpnmon-r3.sh"

Significant Screenshots:

These were the excessive [UB] indicators that were showing up due to a variable not getting reset in certain scenarios. Fixed!

1756048334997.png
 
A quick question on the viability of the method I am using for Server List Automation since my VPN client provider
does not seem to provide an API accessible to use curl. All the documentation points only to using curl in VNPMON-R3.

I am currently using dig to get a list of IP's available for the host provided in the opvn config file.

dig us-boston-ca-version-2.expressnetw.com | grep -v ';' | awk -v RS='([0-9]+\\.){3}[0-9]+' 'RT{print RT}'

From the log.
Aug 25 2025 14:47:36 rt-ax92u VPNMON-R3[16213] - INFO: New Custom VPN Server List Command entered for VPN Slot 1
Aug 25 2025 14:47:36 rt-ax92u VPNMON-R3[16213] - INFO: New vpnmon-r3.cfg File Saved
Aug 25 2025 14:47:39 rt-ax92u VPNMON-R3[16213] - INFO: Custom VPN Server List Command executed for VPN Slot 1

So is this method something I can expect to be around for sometime?
At least long enough for me to cobble something together that stores this information in a location that can be accessed using curl.
 
A quick question on the viability of the method I am using for Server List Automation since my VPN client provider
does not seem to provide an API accessible to use curl. All the documentation points only to using curl in VNPMON-R3.

I am currently using dig to get a list of IP's available for the host provided in the opvn config file.

dig us-boston-ca-version-2.expressnetw.com | grep -v ';' | awk -v RS='([0-9]+\\.){3}[0-9]+' 'RT{print RT}'

From the log.
Aug 25 2025 14:47:36 rt-ax92u VPNMON-R3[16213] - INFO: New Custom VPN Server List Command entered for VPN Slot 1
Aug 25 2025 14:47:36 rt-ax92u VPNMON-R3[16213] - INFO: New vpnmon-r3.cfg File Saved
Aug 25 2025 14:47:39 rt-ax92u VPNMON-R3[16213] - INFO: Custom VPN Server List Command executed for VPN Slot 1

So is this method something I can expect to be around for sometime?
At least long enough for me to cobble something together that stores this information in a location that can be accessed using curl.
Absolutely! The dig command works just as well as curl in this case, as long as it generates a single list of IPs. Feel free to continue using this method. Nice use case! :)
 
Last edited:
Thanks for confirming that behavior.

I’ve reached out to Proton support to see if they have a suggestion.
Support replied saying that they do something special for Netflix DNS. So suggested to use the primary VPN DNS for Netflix, and all others to do Unbound over VPN.

Guessing the solution is like what you mentioned and just have the AppleTV use dns over wan, and others to do Unbound over VPN. As I don’t see a way to do domain-level dns setting.

Bummer.
 
Support replied saying that they do something special for Netflix DNS. So suggested to use the primary VPN DNS for Netflix, and all others to do Unbound over VPN.

Guessing the solution is like what you mentioned and just have the AppleTV use dns over wan, and others to do Unbound over VPN. As I don’t see a way to do domain-level dns setting.

Bummer.
Yeah, it was a solid fix to ensure the TV could always get to any of the streaming services without having to rip my hair out. 😋
 

Similar threads

Support SNBForums w/ Amazon

If you'd like to support SNBForums, just use this link and buy anything on Amazon. Thanks!

Sign Up For SNBForums Daily Digest

Get an update of what's new every day delivered to your mailbox. Sign up here!
Back
Top