Monitor and observe Online Reachability, and react to status changes as necessary.
Project description
Reachability
Reachability is a Python 3 package which allows you to monitor and observe online reachability, and react to these status changes as necessary.
This is done by periodically pinging the Cloudflare DNS IP (1.1.1.1). Reachability is customisable, so you can change the interval and host to ping as necessary.
To start with, we can easily check the current status from an instance of the reachability class:
from reachability import Reachability
reachability = Reachability()
print(reachability.isonline())
The above show True
if connected to the internet, or False
if not.
To set up Reachability, instead you can use:
reachability = Reachability(host='8.8.4.4', port=53, timeout=3, status_check_interval=4)
The above will instead ping 8.8.4.4 (Google's DNS Service), on port 53 with a timeout of 3 seconds. status_check_interval is used in more advanced use cases to monitor any status changes as shown below.
Observing changes
Functions and Lambdas
reachability.attach_func(lambda x: print(x))
reachability.start_notify()
This will print True
or False
on each status change. If for example, we are initially connected to the internet, True
will be printed. If the Internet connection is then interrupted, the lambda will be executed again this time printing False
.
This will continue until
reachability.stop_notify()
is called. Note however that the lambda will still be attached. To detach it, we must call
reachability.detach_func(x)
where x is a reference to the lambda or function.
Obviously, you can also use something like
def f(isonline):
if isonline:
print("FunctionA: We are online")
else:
print("FunctionA: We are offline")
reachability.attach_func(f)
Observers
Another option is to use an Observer Class as demonstrated below:
from reachability import ReachabilityObserver, Reachability
class ObserverA(ReachabilityObserver):
def reachability_update(self, isonline: bool) -> None:
if isonline:
print("ObserverA: We are online")
else:
print("ObserverA: We are offline")
reachability = Reachability()
observer_a = ObserverA()
reachability.attach(observer_a)
reachability.start_notify()
ReachabiltyObserver
is a simple interface. Classes which use it will implement
def reachability_update(self, is_online: bool) -> None
This method will then be called on Online Reachability changes.
You can have multiple observers attached to a reachability instance. To detach them, simply call
reachability.attach(observer_a) #Detach ObserverA
reachability.stop_notify() #Stop any further notifications
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file reachability-0.1.2.tar.gz
.
File metadata
- Download URL: reachability-0.1.2.tar.gz
- Upload date:
- Size: 3.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.1 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 393df11ac8e3e8c1909e65243dc9d561fb67a12a0011855bdcb91b0b7db8362d |
|
MD5 | e1f3c65b2ed00cd5f53e37c29b7e96ef |
|
BLAKE2b-256 | 9993ae35506933e6a0368ae4bbe41b57e51bf23f0ee673dafd10df9eaada98df |
File details
Details for the file reachability-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: reachability-0.1.2-py3-none-any.whl
- Upload date:
- Size: 4.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.1 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3be4751ce4d170e8a9fd62eb60e0228ce96ce47b5ce2fb55a361fe8eaf28e7dc |
|
MD5 | c3fc496df975367eec83ef33245e707f |
|
BLAKE2b-256 | 4e9eccaf9b5563a66a46389e338019676bc5f4cbad925f0d01950c5854800247 |