Network Data Usage Monitor

UUID: netusagemonitor@pdcurtis
Last edited:
1 week ago 2024-04-09, 13:50
Last commit: [591f8222] Translation files cleanup (#5676)

A Comprehensive Data Usage Monitor with alerts and cumulative data functions

README

Close

The Network Usage Monitor Applet (NUMA)

Summary

The Network Usage Monitor Applet (NUMA) enables one to continuously display the speed and data usage on a selected interface. It is intended to make monitoring of mobile connections by USB Mobile Internet Dongles, through phones by bluetooth and by Mobile Wifi (MiFi) units easy to accomplish. To this end, a maximum data and easily changed Alert level can be set for the current connection. There are also a number of cumulative data monitors to track total usage with offsets and corrections as required. It builds on the Network Speed Monitor Applet project by adreadec.

Special Requirements:

  • For the basic facilities the gir1.2-gtop-2.0 library must be installed or the applet will not load and a notification will be displayed. It can be installed by the synaptic package manager or with the terminal command: sudo apt-get install gir1.2-gtop-2.0

  • For full facilities including use of notifications, audible alerts and statistics the gir1.2-gtop-2.0 vnstat vnstati zenity sox libsox-fmt-mp3 libraries must be installed. They can be installed by the synaptic package manager or with the terminal command: `sudo apt-get install gir1.2-gtop-2.0 vnstat vnstati zenity sox libsox-fmt-mp3
  • Cinnamon Version 2.2 or higher ie. It can be used with all supported versions of Mint.
  • Version 3.2.4 requires the NMClient and NetworkManager libraries to be in use as was the case in Mint versions up to 18.3 and most other current distro versions at that time.
  • The applet will switch to the more recent NM library from the NetworkManager Library under Cinnamon versions up to 3.8.
  • Only the new NM libraries can be used when Cinnamon 4.0 or higher is in use to avoid potential segfaults in Cinnamon 4.0. This should support all current Linux Distributions which support Cinnamon 4.0.

Features:

  • The Applet:
    • Continuously displays Upload and Download rate in a fixed width 'steady' display
    • The Applet Background color and rounding varies slightly with Cinnamon Version:
      • Black or Light Gray with Dark Gray edge when Current Interface not active
      • Green or Green edge when Current connection and interface has provided data
      • Orange when the Alert level (as percentage of the Data Limit) has been exceeded
      • Red when the Data Limit for the current connection has been exceeded
        • Hover over Applet:
    • Displays continuously updated Upload and Downloaded data usage for the current connection
      • The Context Menu (Right Click):
    • Displays all the interfaces managed by the Network Manager Applet
    • Identifies any Active interfaces within Network Manager
    • Allows the selection of the interface to be monitored from those manged by Network Manager.
    • Allows the selection of an interfaces not managed by properly by Network Manager and/or interfaces for a connection initiated outside Network manager (ppp0 and bnep0). (bnep0 needs v20_2.6.0 or higher)
    • Identifies the interface which has been selected for monitoring.
    • Allows updating of the list of Network Manager Interfaces (e.g. after a dongle has been inserted or a bluetooth connection made)
    • Enables the Cumulative Usage Monitors to be reset and the date and time of reset displayed.
    • Provides links to:
      • The NUMA Settings screen.
      • The Gnome System Monitor
        • Left Click Menu:
    • Displays continuously updated Uploaded and Downloaded Data for the Monitored Interface.
    • If Alerts are enabled:
      • A slider to adjust the Alert level as a percentage of the Data Limit
      • A display of the exact Alert level percentage and the Data Limit
    • For each Interface where cumulative monitoring is enabled:
      • The interface and Cumulative Usage
      • A comment (entered in Settings) to remind one of when it was set/reset and the value when set/reset.
        • The Settings Screen allows:
        • Setting the Update Frequency (1 to 5 seconds)
        • The Resolution of displayed upload and downloads (0 to 2 decimal places)
        • Change the units for Data Limits and Cumulative Offsets between Mbytes or Gbytes
        • Setting an interface to use as Default if no other interface is active at start-up - for Wifi hotspots and Mobile Broadband where the connection is manual.
        • Enabling Alerts on the current monitored interface and setting the Data Limit for the current connection on that interface and
      • setting the Alert Level as a percentage of the Data Limit by a slider (duplicated in the left click menu as it is frequently used.
      • Enabling each of three Cumulative Usage Monitors Setting an offset for each Cumulative Usage Monitors (v20_2.6.0 or higher)
    • Switching on a Long Term Statistics Display (Requires vnstat and vnstati to be installed)
    • Enabling Actions when the Current Data Usage Limit is exceeded:
      • Do nothing other than put up a standard Cinnamon Notification - this displays for 5 seconds or so and ends up in the notification tray - very easy to miss.
      • Display a high priority Notification - this displays on to of other windows until you clear it but does not go into the notification tray - still easy to miss from a distance.
      • Display a full screen Modal Dialog - this is techie term (look it up on Wikipedia) and the result is the whole screen is blacked out with an information box and button to clear it in the middle and uses the internal capabilities of Cinnamon. It is impossible to miss if you are at or close to the machine.
      • Run a shell script which lives in the applet folder and is called alertScript - this can be customised by the user and the example plays a system sound file for 6 seconds (using Sox) , puts up a warning box using Zenity and sends a standard notification so you have a record in the notification tray.
      • Suspend the Machine after a brief period during which you can abort. This is also implemented by a script (suspendScript) so the user can fine tune it but the version provided uses Zenity for the warning message which has a 30 second timeout to allow you to abort. Another message is put up before suspending which should be on display when you wake up the machine.
        • Disable Networking for all connections managed by the Network Manager. This puts up a warning message and you can abort for a short period by clicking the Applet - not the OK button on the warning screen.
        • Set a delay before disabling Network Connections
    • Enable a warning sound
    • Set the sound file to be played
      • Add or hide the Advanced functions from Housekeeping drop down menu

Additional Configuration

Styling

The display width, justification and font details are set using an external Cascading Style Sheet (.css) file which is in the main folder (usually ~/.local/share/cinnamon/netusagemonitor@pdcurtis/stylesheet.css).

The settings in this css file govern the width of the Applet and the font. Changes may be required with some themes to avoid the display width being exceeded which leads to jitter with high network speeds and resolutions or to allow a reduced size width to save panel space. The latest version also allow the backgrounds to be configured using this css file to optimize to a particular theme although the defaults work well on most popular themes.

Note: These settings will be overwritten if the applet is reloaded.

The optional vnstat display.

The vnstat daemon runs in the background and collects info about your Internet usage all the time the machine is running and maintains a data set from once it is initially activated. It is automatically set up on installation to monitor the network devices/interfaces installed in the machine at the time. It is possible to add additional USB network devices and possibly bluetooth devices to the list of monitored interface man vnstat in a terminal will give details.

Once vnstat is set up, tThe applet detects which device you're currently using, and exports a graph using vnstati. The latest version allows you to select the type of graph although for most users the default summary will be the most useful.

Status

The author is committed to maintaining and developing the applet. The applet is based on a well tried core from the netspeed applet and has been tested on various systems initially running under Mint 15 with a variety of themes. The current Version has been tested with Cinnamon 2.2 - 4.0 under Mint 17 - 19.1.

Translations and other Contributions

The internal changes required in the applet to allow translations are being implemented but no translations are available at this time. Translations are usually contributed by people fluent in the language and will be very much appreciated. Users please note I am unable to take responsibility for the accuracy of translations!

Although comments and suggestions are always welcome any contributions which are contemplated should follow discussion. Changes can have many unintended consequences and the integrity of the applet is paramount. Unsolicited Pull Requests will never be authorised other than for urgent and critical bug fixes or from the Cinnamon Team.

Thanks are given for the very useful contributions from @collinss and @Odyseus to help harmonise the menus with other applets and @jaszhix for the code selection for the Network manager changes.

Manual Installation:

  • Download from Cinnamon Spices
  • Unzip and extract folder netusagemonitor@pdcurtis to ~/.local/share/cinnamon/applets/
  • Install the additional programs required.
  • Enable the applet in Cinnamon Settings -> Applets
  • You can also access the Settings Screen from Cinnamon Settings -> Applets

Contact

The author can be contacted via the comments on the Cinnamon Spices Web Site, however that does not automatically notify me so if you want a rapid response please also alert me via the Form at www.pcurtis.com. On github, mentioning @pdcurtis in any conversation will cause it to be emailed to me.

CHANGELOG

Open

Log In To Comment!

10 Comments

Alex T. Grecu
Alex T. Grecu-10 months ago
Patch for Linux Mint 21 in file applet.js - comment lines 477-487 - add following block of code: let file = Gio.File.new_for_path(this.displayImage); let tt = St.TextureCache.get_default().load_file_async(file, -1, -1, 1, 1); this.imageWidget.set_child(tt); - reload applet and enjoy as before with graphical report.
Rai
Rai-1 year ago
Thanks for creating this wonderful aplication, but as of now I am facing issue with Linux Mint 21 Cinnamon and it is not working properly with Linux Mint 21 Cinnamon, please fix this applet
Peter Curtis
Peter Curtis-4 years ago
Updated ready for Cinnamon 4.4
denispr
denispr-4 years ago
Great applet, thanks ! Just one thing, it would be nice if the active interface could be automatically selected to be displayed : depending on where I work, I often switch between wlan0, eth0, ppp0, usb0. Not a big matter, just a comfort improvement, but I would like it !
sokoban
sokoban-4 years ago
Not working after update to Cinnamon 4.2.0
Peter Curtis
Peter Curtis-4 years ago
Updated for Cinnamon 4.2
blueray453
blueray453-5 years ago
How to show the output in Mbit instead of Mbyte?
Peter Curtis
Peter Curtis-4 years ago
It could be added as an option if sufficient interest.
buggyRogers
buggyRogers-6 years ago
Thank you for the great applet! Keep up the good work!
Peter Curtis
Peter Curtis-6 years ago
As the author I am committed to maintaining and developing this and all my other applets. I can be contacted here however posting a comment does not automatically cause me to be notified so if you want a rapid response please also alert me via http://www.pcurtis.com/contact_form.htm?applets . On github, @pdcurtis in any conversation should cause a copy to be emailed to me. Please take the time to 'like' applets you find useful even if you do not comment, it is a great motivator for the authors.