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 provides a webthing API to a internet monitor agent.

The pi_internet_webthing package exposes an http webthing endpoint which supports reading the internet speed results as well as 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 --port 8433 --speedtest_period 900 --connecttest_period 5 

Here, the webthing API will be bind to the local port 8433. The internet speed montior as well as the connectivity monitor will be started. The speed test will be executed each 15 min (900 sec), the connectivity test will be executed each 5 sec.

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 --port 8433 --speedtest_period 900 --connecttest_period 5 

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

sudo netmonitor --command listen --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.10.tar.gz (7.2 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.10-py3-none-any.whl (13.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pi_internet_webthing-0.0.10.tar.gz
  • Upload date:
  • Size: 7.2 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.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.6

File hashes

Hashes for pi_internet_webthing-0.0.10.tar.gz
Algorithm Hash digest
SHA256 40e9d5b7c5f14304c03ef1d63cffa8bc3d36852a274d5830f0bab45c6745aee0
MD5 0b91bf96ac643e9009e5c03518e5dd0d
BLAKE2b-256 1ffe5f240d5c95ea0ab314b9516be196d243a7e995eceade0beca6ffa2ebd8c1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pi_internet_webthing-0.0.10-py3-none-any.whl
  • Upload date:
  • Size: 13.0 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.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.6

File hashes

Hashes for pi_internet_webthing-0.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 4b230aade1c2bd3d5dd118fcedf1dbc37f38989d74351994b59970efdc842ee7
MD5 d7fda0c7674967fca096a78ec9765caa
BLAKE2b-256 0127bcc9323873740ccdbf4c250d37e7a3da10b7d4b43fcf5eec5cc99f9dbdb0

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