Skip to main content

A web connected local internet speed and connectivity monitor

Project description

internet_monitor_webthing

A web connected local internet speed and connectivity monitor

This project implements an internet monitor agent providing a speed monitor webthing API as well as a connectivity monitor webthing API.

The internet_monitor_webthing package exposes an http webthing endpoint which supports reading the internet speed results as well as an endpoint to read the internet connectivity results via http E.g.

# webthing has been started on host 192.168.0.23

# internet speed
curl http://192.168.0.23:8433/0/properties
{
   "test_period": 900,
   "downloadspeed": 215.2,
   "uploadspeed": 11,
   "ping": 17.763,
   "testdate": "2020-10-11T13:44:51.346706",
   "speedtest_server": "Mobile Breitbandnetze GmbH/Freisbach",
   "speedtest_report_uri": "http://www.speedtest.net/result/10231336474.png"
}

# connectivity 
curl http://192.168.0.23:8433/1/properties
{
   "test_url": "http://google.com",
   "test_period": 5,
   "connected": true,
   "ip_address": "95.88.57.72"
}

To install this software you may use PIP package manager such as shown below

sudo pip install internet_monitor_webthing

After this installation you may start the webthing http endpoint inside your python code or via command line using

sudo netmonitor --command listen --hostname 192.168.0.23 --port 8433 --speedtest_period 900 --connecttest_period 5 

Here, the webthing API will be bind to hostname 192.168.0.23 running on port 8433. The internet speed monitor as well as the connectivity monitor will be started by performing the listen command above. The speed test will be executed each 15 min (900 sec), the connectivity test will be executed each 5 sec. THe WebThing server provides mDNS to enable clients discovering the WebThing interfaces.

By running a systemd-based Linux distribution you may use the register command to register and start the webthing service as systemd unit. By doing this the webthing service will be started automatically on boot. Starting the server manually using the listen command is no longer necessary.

sudo netmonitor --command register --hostname 192.168.0.23 --port 8433 --speedtest_period 900 --connecttest_period 5 

To start the speedtest monitor only just omit the --connecttest_period parameter

sudo netmonitor --command listen --hostname 192.168.0.23 --port 8433 --speedtest_period 900

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

internet_monitor_webthing-0.0.55.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

internet_monitor_webthing-0.0.55-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file internet_monitor_webthing-0.0.55.tar.gz.

File metadata

  • Download URL: internet_monitor_webthing-0.0.55.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.7

File hashes

Hashes for internet_monitor_webthing-0.0.55.tar.gz
Algorithm Hash digest
SHA256 4f191bafe63f2720239411c2a43c9c9c3c69d8785c5a4f76ac44cfa5224f1cac
MD5 2767eb9af7beda356bc920e3ea0d5c4e
BLAKE2b-256 8b0b4905312bc61518659b6112afa3f90837740ef454e91bb0c9a80fc0c88b30

See more details on using hashes here.

File details

Details for the file internet_monitor_webthing-0.0.55-py3-none-any.whl.

File metadata

  • Download URL: internet_monitor_webthing-0.0.55-py3-none-any.whl
  • Upload date:
  • Size: 15.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.7

File hashes

Hashes for internet_monitor_webthing-0.0.55-py3-none-any.whl
Algorithm Hash digest
SHA256 6fc21d1859e2b2ba74b2fb5eecfd6e6739431cef1d3a865d28d4e8d4ce1e8126
MD5 7f51c17e0b4eb0ef37ae9a28bede01ac
BLAKE2b-256 52a59790b17f4c56902e46f907ad9e9e4c48a81a8a9456d0304452521b4ea185

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page