NAME
upsstats.cgi - Web-based UPS status viewer
SYNOPSIS
upsstats.cgi
|
Note
|
As a CGI program, this should be invoked through your web server. If you run it from the command line, it will either complain about unauthorized access or spew a bunch of HTML at you. |
DESCRIPTION
upsstats.cgi uses template files to build web pages containing status information from UPS hardware. It can repeat sections of those template files to monitor several devices simultaneously, or focus on a single UPS.
These templates can also include references to upsimage.cgi(8) for graphical displays of battery charge levels, voltage readings, and the UPS load.
ACCESS CONTROL
upsstats will only talk to upsd(8) servers that have been defined in your hosts.conf(5). If it complains that "Access to that host is not authorized", check that file first.
TEMPLATES
The web page that is displayed is actually a template containing
commands to upsstats which are replaced by status information.
The default file used for the overview of devices is upsstats.html.
When monitoring a single UPS, the file displayed is
upsstats-single.html.
The format of these files, including the possible commands, is documented in upsstats.html(5).
JSON OUTPUT
In addition to processing HTML templates, upsstats.cgi can be invoked as a JSON API by adding the json parameter to the query string (e.g., ?json or &json).
When this parameter is present, the CGI script bypasses all HTML template parsing and instead returns a JSON object.
The structure of the JSON output depends on whether the host parameter is also provided:
-
Multi-host (Default): If no host parameter is specified, the script returns a single JSON object containing an "devices" key. This key holds an array, with each element in the array being a JSON object representing a monitored UPS.
-
Single-host Mode: If a host parameter is provided (e.g., ?host=myups@localhost&json), the script returns a single JSON object for that UPS (it will not be wrapped in an "devices" array).
In both modes, each UPS object includes:
-
host: The UPS identifier (e.g., "myups@localhost")
-
desc: The host description from ``hosts.conf``
-
status_raw: The raw status string (e.g., "OL")
-
status_parsed: An array of human-readable status strings (e.g., ["Online"])
-
vars: An object containing the full tree of all available variables for that UPS (e.g., "battery.charge": "100", "ups.model": "…")
FILES
hosts.conf(5), upsstats.html(5), upsstats-single.html
SEE ALSO
Internet resources:
The NUT (Network UPS Tools) home page: https://www.networkupstools.org/