Skip to main content

A web connected local internet speed and connectivity monitor

Project description

pi_internet_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 pi_internet_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 pi_internet_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.

Alternatively to the listen command, you can 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

pi_internet_webthing-0.0.19.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pi_internet_webthing-0.0.19-py3-none-any.whl (13.9 kB view details)

Uploaded Python 3

File details

Details for the file pi_internet_webthing-0.0.19.tar.gz.

File metadata

  • Download URL: pi_internet_webthing-0.0.19.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for pi_internet_webthing-0.0.19.tar.gz
Algorithm Hash digest
SHA256 9cf0d7aba8f10e58e9e8bdc037c5d039d5c7564a71ecbd3a74e51168d2a6dbb1
MD5 1759b3f590281dafe2d33eb885a86cd2
BLAKE2b-256 a52fd7676caa57994220e6b04a9ad45f30bf98ac1b10f48d229829f8dec665e8

See more details on using hashes here.

File details

Details for the file pi_internet_webthing-0.0.19-py3-none-any.whl.

File metadata

  • Download URL: pi_internet_webthing-0.0.19-py3-none-any.whl
  • Upload date:
  • Size: 13.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for pi_internet_webthing-0.0.19-py3-none-any.whl
Algorithm Hash digest
SHA256 e25229137ad62ea9ce929d61f70339bf3d1f3e30caf77bbea479c97b6baa2e71
MD5 52cd1c9deae8e99b05a8208b1b0f81f0
BLAKE2b-256 b96c6b6318bf68f6f2149091dc7c2ac14dc3e25f72b5549ad53d485987410610

See more details on using hashes here.

Supported by

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