Compare commits
2 Commits
4d2083c9a4
...
220fefc1ad
| Author | SHA1 | Date | |
|---|---|---|---|
| 220fefc1ad | |||
| ebd6172329 |
@ -3,6 +3,9 @@
|
|||||||
# EcoDevice (not the RT one) can be ip address or FQDN
|
# EcoDevice (not the RT one) can be ip address or FQDN
|
||||||
ecodevice = "192.0.2.1"
|
ecodevice = "192.0.2.1"
|
||||||
|
|
||||||
|
# Use EcoDevice or EDF "API"
|
||||||
|
use_eco = True
|
||||||
|
|
||||||
# MQTT Broker (or GX with MQTT enabled)
|
# MQTT Broker (or GX with MQTT enabled)
|
||||||
gx = "192.0.2.2"
|
gx = "192.0.2.2"
|
||||||
|
|
||||||
|
|||||||
@ -7,8 +7,10 @@ import time
|
|||||||
import pyprowl
|
import pyprowl
|
||||||
#import syslog
|
#import syslog
|
||||||
|
|
||||||
|
from datetime import date,datetime
|
||||||
|
|
||||||
# Settings
|
# Settings
|
||||||
from secret import ecodevice,gx,gxsn,chgbleu,chgblanc,chgrouge,minbleu,minblanc,minrouge,prowlkey
|
from secret import ecodevice,use_eco,gx,gxsn,chgbleu,chgblanc,chgrouge,minbleu,minblanc,minrouge,prowlkey
|
||||||
|
|
||||||
# Lancer ceci du 01 Oct au 31 mai
|
# Lancer ceci du 01 Oct au 31 mai
|
||||||
# une fois avant 22h / une fois apres 22h
|
# une fois avant 22h / une fois apres 22h
|
||||||
@ -115,11 +117,13 @@ except Exception as e:
|
|||||||
print("Error verifying Prowl API key: {}".format(e))
|
print("Error verifying Prowl API key: {}".format(e))
|
||||||
exit()
|
exit()
|
||||||
|
|
||||||
# Setup EcoDevice
|
|
||||||
http = urllib3.PoolManager()
|
|
||||||
resp = http.request("GET", "http://"+ecodevice+"/api/xdevices.json?cmd=10")
|
|
||||||
|
|
||||||
if resp.status == 200:
|
http = urllib3.PoolManager()
|
||||||
|
if use_eco:
|
||||||
|
# Setup EcoDevice
|
||||||
|
resp = http.request("GET", "http://"+ecodevice+"/api/xdevices.json?cmd=10")
|
||||||
|
|
||||||
|
if resp.status == 200:
|
||||||
teleinfo = json.loads(resp.data)
|
teleinfo = json.loads(resp.data)
|
||||||
|
|
||||||
# Value of var today daynight
|
# Value of var today daynight
|
||||||
@ -152,6 +156,7 @@ if resp.status == 200:
|
|||||||
today = 0
|
today = 0
|
||||||
daynight = 0
|
daynight = 0
|
||||||
|
|
||||||
|
|
||||||
# Value of var tomorrow
|
# Value of var tomorrow
|
||||||
# ---- = Bleu 0
|
# ---- = Bleu 0
|
||||||
# BLEU = Bleu 0
|
# BLEU = Bleu 0
|
||||||
@ -169,10 +174,53 @@ if resp.status == 200:
|
|||||||
else:
|
else:
|
||||||
tomorrow=0
|
tomorrow=0
|
||||||
|
|
||||||
|
|
||||||
loggerinfo("Current tarif: " + curtarif + " ("+str(today)+" / "+str(daynight) + ")")
|
loggerinfo("Current tarif: " + curtarif + " ("+str(today)+" / "+str(daynight) + ")")
|
||||||
loggerinfo("Demain tarif: " + demaintarif + " ("+str(tomorrow)+")")
|
loggerinfo("Demain tarif: " + demaintarif + " ("+str(tomorrow)+")")
|
||||||
|
|
||||||
|
else:
|
||||||
|
# Use EDF "API"
|
||||||
|
# TODO:
|
||||||
|
today=date.today()
|
||||||
|
resp = http.request("GET", "https://particulier.edf.fr/services/rest/referentiel/searchTempoStore?dateRelevant="+str(today.strftime("%Y-%m-%d")))
|
||||||
|
if resp.status == 200:
|
||||||
|
edfapi = json.loads(resp.data)
|
||||||
|
curcouleur = edfapi['couleurJourJ']
|
||||||
|
demaincouleur = edfapi['couleurJourJ1']
|
||||||
|
|
||||||
|
if curcouleur == "TEMPO_BLEU":
|
||||||
|
today = 0
|
||||||
|
elif curcouleur == "TEMPO_BLANC":
|
||||||
|
today = 1
|
||||||
|
elif curcouleur == "TEMPO_ROUGE":
|
||||||
|
today = 2
|
||||||
|
else:
|
||||||
|
today = -1
|
||||||
|
|
||||||
|
if demaincouleur == "TEMPO_BLEU":
|
||||||
|
tomorrow = 0
|
||||||
|
elif domaincouleur == "TEMPO_BLANC":
|
||||||
|
tomorrow = 1
|
||||||
|
elif demaincouleur == "TEMPO_ROUGE":
|
||||||
|
tomorrow = 2
|
||||||
|
elif demaincouleur == "NON_DEFINI":
|
||||||
|
tomorrow = -1
|
||||||
|
else:
|
||||||
|
tomorrow = -1 # trop tot.
|
||||||
|
|
||||||
|
now = datetime.now()
|
||||||
|
#Heures creuses: 22h00 -> 06h00
|
||||||
|
if now.hour >= 6 and now.hour <=22:
|
||||||
|
daynight = 1
|
||||||
|
else:
|
||||||
|
daynight = 0
|
||||||
|
|
||||||
|
loggerinfo("La couleur aujourd'hui "+str(curcouleur))
|
||||||
|
loggerinfo("La couleur demain "+str(demaincouleur))
|
||||||
|
if tomorrow == -1:
|
||||||
|
loggerinfo("La couleur de demain n'est pas definie -> exit")
|
||||||
|
quit()
|
||||||
|
|
||||||
|
|
||||||
# daynight : 1 = jour / 0 nuit
|
# daynight : 1 = jour / 0 nuit
|
||||||
# Today Tomorrow Daynight Action
|
# Today Tomorrow Daynight Action
|
||||||
# 0 0 O Rien
|
# 0 0 O Rien
|
||||||
|
|||||||
Reference in New Issue
Block a user