aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--README.md7
-rw-r--r--env.sample9
-rwxr-xr-xneohub2pgsql.py40
-rw-r--r--requirements.txt4
-rwxr-xr-xrun.sh8
-rw-r--r--schema.sql95
6 files changed, 133 insertions, 30 deletions
diff --git a/README.md b/README.md
index 9c2881e..9913fa6 100644
--- a/README.md
+++ b/README.md
@@ -2,3 +2,10 @@
This is a small collection of scripts I use to collect information about my
energyconsumption.
+
+
+
+schema.sql created with:
+```
+pg_dump --schema-only --no-owner --no-privileges el
+```
diff --git a/env.sample b/env.sample
index 4eb41ab..e40aa42 100644
--- a/env.sample
+++ b/env.sample
@@ -2,8 +2,10 @@ export el_metringPointId=XXX
export el_elvia_token=XXX
export el_elvia_grid_api_key=XXX
-export el_pg_db=XXX
-export el_pg_host=XXX
+export el_pg_db=el
+export el_pg_host=/var/run/postgresql/
+#export el_pg_user=XXX
+#export el_pg_pass=XXX
export el_tibber_token=XXX
@@ -11,3 +13,6 @@ export el_yr_lat=0.0
export el_yr_lon=0.0
export el_entsoe_token=XXX
+
+export el_neohub_ip=XXX
+export el_neohub_port=4242
diff --git a/neohub2pgsql.py b/neohub2pgsql.py
new file mode 100755
index 0000000..0c760e5
--- /dev/null
+++ b/neohub2pgsql.py
@@ -0,0 +1,40 @@
+#!/usr/bin/python3
+
+import os
+import asyncio
+import neohubapi.neohub as neohub
+
+import psycopg2
+
+neohub_ip = os.environ['el_neohub_ip']
+neohub_port = os.environ['el_neohub_port']
+pg_db = os.environ['el_pg_db']
+pg_host = os.environ['el_pg_host']
+pg_user = os.environ['el_pg_user']
+pg_pass = os.environ['el_pg_pass']
+pg_table = "neohub"
+
+values = []
+
+async def run():
+ # Legacy connection
+ hub = neohub.NeoHub(neohub_ip, int(neohub_port))
+ # Or, for a websocket connection:
+ # hub = neohub.Neohub(port=4243, token='xxx-xxxxxxx')
+ system = await hub.get_system()
+ hub_data, devices = await hub.get_live_data()
+ for device in devices['thermostats']:
+ print(f"Temperature in zone {device.name}: {device}")
+ values.append((device.time, device.device_id, device.away, device.heat_mode, device.heat_on, device.current_floor_temperature, device.target_temperature, device.temperature))
+
+asyncio.run(run())
+
+conn = psycopg2.connect(database=pg_db, host=pg_host, user=pg_user, password=pg_pass)
+cur = conn.cursor()
+
+try:
+ cur.executemany("INSERT INTO " + pg_table + " (time, device_id, away, heat_mode, heat_on, current_floor_temperature, target_temperature, temperature) VALUES(%s,%s,%s,%s,%s,%s,%s,%s)", values)
+ conn.commit()
+except Exception as e:
+ conn.rollback()
+ raise e
diff --git a/requirements.txt b/requirements.txt
new file mode 100644
index 0000000..7ee1262
--- /dev/null
+++ b/requirements.txt
@@ -0,0 +1,4 @@
+async-property==0.2.1
+neohubapi==1.0
+psycopg2-binary==2.9.5
+websockets==10.4
diff --git a/run.sh b/run.sh
new file mode 100755
index 0000000..bca78be
--- /dev/null
+++ b/run.sh
@@ -0,0 +1,8 @@
+#!/usr/bin/env zsh
+0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}"
+0="${${(M)0:#/*}:-$PWD/$0}"
+
+
+source ${0:h}/.env
+source ${0:h}/venv/bin/activate
+python3 ${0:h}/$1
diff --git a/schema.sql b/schema.sql
index e1ac14c..84301dd 100644
--- a/schema.sql
+++ b/schema.sql
@@ -2,8 +2,8 @@
-- PostgreSQL database dump
--
--- Dumped from database version 14.5 (Ubuntu 14.5-0ubuntu0.22.04.1)
--- Dumped by pg_dump version 14.5 (Ubuntu 14.5-0ubuntu0.22.04.1)
+-- Dumped from database version 14.6 (Ubuntu 14.6-0ubuntu0.22.04.1)
+-- Dumped by pg_dump version 14.6 (Ubuntu 14.6-0ubuntu0.22.04.1)
SET statement_timeout = 0;
SET lock_timeout = 0;
@@ -21,7 +21,7 @@ SET default_tablespace = '';
SET default_table_access_method = heap;
--
--- Name: elvia; Type: TABLE; Schema: public; Owner: dennis
+-- Name: elvia; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.elvia (
@@ -35,10 +35,8 @@ CREATE TABLE public.elvia (
);
-ALTER TABLE public.elvia OWNER TO dennis;
-
--
--- Name: elvia_gridtariff; Type: TABLE; Schema: public; Owner: dennis
+-- Name: elvia_gridtariff; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.elvia_gridtariff (
@@ -53,10 +51,8 @@ CREATE TABLE public.elvia_gridtariff (
);
-ALTER TABLE public.elvia_gridtariff OWNER TO dennis;
-
--
--- Name: entsoe; Type: TABLE; Schema: public; Owner: dennis
+-- Name: entsoe; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.entsoe (
@@ -69,10 +65,8 @@ CREATE TABLE public.entsoe (
);
-ALTER TABLE public.entsoe OWNER TO dennis;
-
--
--- Name: nbex; Type: TABLE; Schema: public; Owner: dennis
+-- Name: nbex; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.nbex (
@@ -84,10 +78,46 @@ CREATE TABLE public.nbex (
);
-ALTER TABLE public.nbex OWNER TO dennis;
+--
+-- Name: neohub; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.neohub (
+ id integer NOT NULL,
+ "timestamp" timestamp with time zone DEFAULT now() NOT NULL,
+ "time" time without time zone,
+ device_id smallint,
+ away boolean,
+ heat_mode boolean,
+ heat_on boolean NOT NULL,
+ current_floor_temperature real,
+ target_temperature real,
+ temperature real
+);
+
--
--- Name: tibber_consumption; Type: TABLE; Schema: public; Owner: dennis
+-- Name: neohub_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+CREATE SEQUENCE public.neohub_id_seq
+ AS integer
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1;
+
+
+--
+-- Name: neohub_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+--
+
+ALTER SEQUENCE public.neohub_id_seq OWNED BY public.neohub.id;
+
+
+--
+-- Name: tibber_consumption; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.tibber_consumption (
@@ -102,10 +132,8 @@ CREATE TABLE public.tibber_consumption (
);
-ALTER TABLE public.tibber_consumption OWNER TO dennis;
-
--
--- Name: tibber_prices; Type: TABLE; Schema: public; Owner: dennis
+-- Name: tibber_prices; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.tibber_prices (
@@ -118,10 +146,8 @@ CREATE TABLE public.tibber_prices (
);
-ALTER TABLE public.tibber_prices OWNER TO dennis;
-
--
--- Name: yr; Type: TABLE; Schema: public; Owner: dennis
+-- Name: yr; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.yr (
@@ -137,10 +163,15 @@ CREATE TABLE public.yr (
);
-ALTER TABLE public.yr OWNER TO dennis;
+--
+-- Name: neohub id; Type: DEFAULT; Schema: public; Owner: -
+--
+
+ALTER TABLE ONLY public.neohub ALTER COLUMN id SET DEFAULT nextval('public.neohub_id_seq'::regclass);
+
--
--- Name: elvia el_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: elvia el_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.elvia
@@ -148,7 +179,7 @@ ALTER TABLE ONLY public.elvia
--
--- Name: elvia_gridtariff elvia_gridtariff_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: elvia_gridtariff elvia_gridtariff_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.elvia_gridtariff
@@ -156,7 +187,7 @@ ALTER TABLE ONLY public.elvia_gridtariff
--
--- Name: entsoe entsoe_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: entsoe entsoe_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.entsoe
@@ -164,7 +195,7 @@ ALTER TABLE ONLY public.entsoe
--
--- Name: nbex nbexchange_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: nbex nbexchange_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.nbex
@@ -172,7 +203,15 @@ ALTER TABLE ONLY public.nbex
--
--- Name: tibber_consumption tibber_consumption_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: neohub neohub_pkey; Type: CONSTRAINT; Schema: public; Owner: -
+--
+
+ALTER TABLE ONLY public.neohub
+ ADD CONSTRAINT neohub_pkey PRIMARY KEY (id);
+
+
+--
+-- Name: tibber_consumption tibber_consumption_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.tibber_consumption
@@ -180,7 +219,7 @@ ALTER TABLE ONLY public.tibber_consumption
--
--- Name: tibber_prices tibber_prices_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: tibber_prices tibber_prices_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.tibber_prices
@@ -188,7 +227,7 @@ ALTER TABLE ONLY public.tibber_prices
--
--- Name: yr yr_pkey; Type: CONSTRAINT; Schema: public; Owner: dennis
+-- Name: yr yr_pkey; Type: CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY public.yr