Merge pull request #916 from tfwiii/main

More robust identification of changes to public IPs
This commit is contained in:
tobi-wan-kenobi 2022-08-31 19:08:34 +02:00 committed by GitHub
commit 05f0e08493
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -6,8 +6,8 @@ Displays information about the public IP address associated with the default rou
* City Name * City Name
* Geographic Coordinates * Geographic Coordinates
Left mouse click on the widget forces immediate update Left mouse click on the widget forces immediate update.
Any change to the default route will cause the widget to update Any change to the default route will cause the widget to update.
Requirements: Requirements:
* netifaces * netifaces
@ -21,7 +21,7 @@ Examples:
* bumblebee-status -m publicip -p publicip.format="{ip} which is in {city_name}" * bumblebee-status -m publicip -p publicip.format="{ip} which is in {city_name}"
* bumblebee-status -m publicip -p publicip.format="Your packets are right here: {coordinates}" * bumblebee-status -m publicip -p publicip.format="Your packets are right here: {coordinates}"
contributed by `tfwiii <https://github.com/tfwiii>`_ - many thanks! contributed by `tfwiii <https://github.com/tfwiii>` - many thanks!
""" """
import re import re
@ -57,9 +57,15 @@ class Module(core.module.Module):
self.__monitor.start() self.__monitor.start()
def monitor(self): def monitor(self):
current_default_route = None
default_route = None default_route = None
interfaces = None
# Initially set to True to force an info update on first pass
information_changed = True
self.update()
while threading.main_thread().is_alive(): while threading.main_thread().is_alive():
# Look for any changes in the netifaces default route information
try: try:
current_default_route = netifaces.gateways()["default"][2] current_default_route = netifaces.gateways()["default"][2]
except: except:
@ -67,11 +73,32 @@ class Module(core.module.Module):
current_default_route = None current_default_route = None
if current_default_route != default_route: if current_default_route != default_route:
default_route = current_default_route default_route = current_default_route
information_changed = True
# netifaces does not check ALL routing tables which might lead to false negatives
# (ref: http://linux-ip.net/html/routing-tables.html) so additionally... look for
# any changes in the netifaces interfaces information which might also be an inticator
# of a change of route/external IP
if not information_changed: # Only check if no routing table change found
try:
current_interfaces = netifaces.interfaces()
except:
# error reading interfaces information -> assume none exists
current_interfaces = None
if current_interfaces != interfaces:
interfaces = current_interfaces
information_changed = True
# Update either routing or interface information has changed
if information_changed:
information_changed = False
self.update() self.update()
# Throttle the calls to netifaces
time.sleep(1) time.sleep(1)
def publicip(self, widget): def publicip(self, widget):
if widget.get("public_ip") == None: if widget.get("public_ip") is None:
return "n/a" return "n/a"
return self._format.format( return self._format.format(
ip=widget.get("public_ip", "-"), ip=widget.get("public_ip", "-"),
@ -83,12 +110,17 @@ class Module(core.module.Module):
def __click_update(self, event): def __click_update(self, event):
util.location.reset() util.location.reset()
# pause to allow reset time to complete
time.sleep(2)
def update(self): def update(self):
widget = self.widget() widget = self.widget()
try: try:
util.location.reset() util.location.reset()
# pause to allow reset time to complete
time.sleep(2)
# Fetch fresh location information # Fetch fresh location information
__info = util.location.location_info() __info = util.location.location_info()
@ -106,8 +138,9 @@ class Module(core.module.Module):
# Update widget values # Update widget values
core.event.trigger("update", [widget.module.id], redraw_only=True) core.event.trigger("update", [widget.module.id], redraw_only=True)
except: except Exception as ex:
widget.set("public_ip", None) widget.set("public_ip", None)
print(ex)
def state(self, widget): def state(self, widget):
return widget.get("state", None) return widget.get("state", None)