Collection of utilities for extracting Jäspi heating system metrics through their rebranded Nibe Uplink service called myUpway. The metrics can be ingested into InfluxDB.
- Python 3.8 (may work with older versions)
pip3 install -r requirements.txt
Fetches all available metrics from myUpway and outputs them as JSON.
Usage:
$ python3 get_metrics.py --help
usage: get_metrics.py [-h] [-s SYSTEM_ID]
optional arguments:
-h, --help show this help message and exit
-s SYSTEM_ID, --system_id SYSTEM_ID
The system/heat pump ID
Example:
EMAIL=user@example.com PASSWORD=password python3 get_metrics.py --system_id 123456
Example output can be found in examples/metrics.json.
Stores metrics in InfluxDB.
Usage:
$ python3 store_influxdb.py --help
usage: store_influxdb.py [-h] [--host HOST] [--port PORT] [--database DATABASE]
optional arguments:
-h, --help show this help message and exit
--host HOST defaults to localhost
--port PORT defaults to 8086
--database DATABASE defaults to "myupway"
Example:
cat examples/metrics.json | INFLUX_USERNAME=myupway INFLUX_PASSWORD=myupway python3 store_influxdb.py --host 10.110.1.6
Field keys and data types:
fieldKey fieldType
-------- ---------
addition temperature BT63 float
avg. outdoor temp. BT1 float
blocked boolean
calculated flow temp. S1 float
comfort mode string
compressor operating time EB101 float
compressor operating time hot water EB101 float
compressor run time cooling EB101 float
compressor starts EB101 string
condenser out EB101-BT12 float
cooling, compr. only. float
cpr. protection mode EB101 boolean
current BE1 float
current BE2 float
current BE3 float
current compr. frequency EB101 integer
defrosting EB101 boolean
degree minutes integer
electrical addition power float
evaporator EB101-BT16 float
external adjustment S1 boolean
floor drying function boolean
flow BF1 float
fuse size float
heat medium flow BT2 float
heating, compr. only. float
heating, int. add. incl. float
high pressure sensor EB101 float
hot gas EB101-BT14 float
hot water charging BT6 float
hot water top BT7 float
hotwater, compr. only. float
hw, incl. int. add float
liquid line EB101-BT15 float
low pressure sensor EB101 float
outdoor temp. BT1 float
outdoor temp. EB101-BT28 float
pool, compr. only. float
pump speed heating medium GP1 integer
requested compressor freq EB101 integer
return temp. BT3 float
return temp. EB101-BT3 float
set max electrical add. float
suction gas EB101-BT17 float
temporary lux boolean
time factor float
Stores metrics in a postgresql database.
It only inserts those metrics whose name is found to be a column of the measurement
table and prints a warning for any other metrics found in the data. For metrics with duplicate names (e.g. "blocked"), a mapping can be applied, see the script for more details.
Usage:
usage: store_psql.py [-h] [--host HOST] [--port PORT] [--database DATABASE]
options:
-h, --help show this help message and exit
--host HOST defaults to localhost
--port PORT defaults to 5432
--database DATABASE defaults to "myupway"
Example:
cat examples/metrics.json | PSQL_USERNAME=myupway PSQL_PASSWORD=myupway python3 store_psql.py --host 10.110.1.6
Table schema of the measurement
table:
CREATE TABLE measurement(
id serial not null primary key,
timestamp timestamp with time zone not null default now(),
system_id bigint not null,
"addition temperature BT63" float,
"avg. outdoor temp. BT1" float,
"blocked" boolean,
"calculated flow temp. S1" float,
"comfort mode" text,
"compressor operating time EB101" float,
"compressor operating time hot water EB101" float,
"compressor run time cooling EB101" float,
"compressor starts EB101" text,
"condenser out EB101-BT12" float,
"cooling, compr. only." float,
"cpr. protection mode EB101" boolean,
"current BE1" float,
"current BE2" float,
"current BE3" float,
"current compr. frequency EB101" integer,
"defrosting EB101" boolean,
"degree minutes" integer,
"electrical addition power" float,
"evaporator EB101-BT16" float,
"external adjustment S1" boolean,
"floor drying function" boolean,
"flow BF1" float,
"fuse size" float,
"heat medium flow BT2" float,
"heating, compr. only." float,
"heating, int. add. incl." float,
"high pressure sensor EB101" float,
"hot gas EB101-BT14" float,
"hot water charging BT6" float,
"hot water top BT7" float,
"hotwater, compr. only." float,
"hw, incl. int. add" float,
"liquid line EB101-BT15" float,
"low pressure sensor EB101" float,
"outdoor temp. BT1" float,
"outdoor temp. EB101-BT28" float,
"pool, compr. only." float,
"pump speed heating medium GP1" integer,
"requested compressor freq EB101" integer,
"return temp. BT3" float,
"return temp. EB101-BT3" float,
"set max electrical add." float,
"suction gas EB101-BT17" float,
"temporary lux" boolean,
"time factor" float,
"external flow temp. BT25" float,
"room temperature BT50" float,
"tehowatti addition blocked" boolean,
"inverter m8 compressor module blocked" boolean,
"test" integer
)