Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 4 additions & 6 deletions packages/control/chargelog/chargelog.py
Original file line number Diff line number Diff line change
Expand Up @@ -414,9 +414,7 @@ def calculate_charge_cost(cp, create_log_entry: bool = False):
raise TypeError(f"Unbekannter Referenz-Zeitpunkt {reference}")
log.debug(f'power source {energy_source_entry["energy_source"]}')
log.debug(f"charged_energy {charged_energy}")
costs = _calc(energy_source_entry["energy_source"],
charged_energy,
(data.data.optional_data.et_module is not None))
costs = _calc(energy_source_entry["energy_source"], charged_energy)
cp.data.set.log.costs += costs
log.debug(f"current costs {costs}, total costs {cp.data.set.log.costs}")
Pub().pub(f"openWB/set/chargepoint/{cp.num}/set/log", asdict(cp.data.set.log))
Expand Down Expand Up @@ -492,14 +490,14 @@ def get_daily_log(day):
return []


def _calc(energy_source: Dict[str, float], charged_energy_last_hour: float, et_active: bool) -> float:
def _calc(energy_source: Dict[str, float], charged_energy_last_hour: float) -> float:
prices = data.data.general_data.data.prices

bat_costs = prices.bat * charged_energy_last_hour * energy_source["bat"]
cp_costs = prices.cp * charged_energy_last_hour * energy_source["cp"]
if et_active:
try:
grid_costs = data.data.optional_data.et_get_current_price() * charged_energy_last_hour * energy_source["grid"]
else:
except Exception:
grid_costs = prices.grid * charged_energy_last_hour * energy_source["grid"]
pv_costs = prices.pv * charged_energy_last_hour * energy_source["pv"]

Expand Down
55 changes: 35 additions & 20 deletions packages/helpermodules/measurement_logging/write_log.py
Original file line number Diff line number Diff line change
Expand Up @@ -196,29 +196,32 @@ def create_entry(log_type: LogType, sh_log_data: LegacySmartHomeLogData, previou
date = timecheck.create_timestamp_YYYYMMDD()
current_timestamp = int(timecheck.create_timestamp())

prices = data.data.general_data.data.prices
if data.data.optional_data.et_module is not None:
grid_price = data.data.optional_data.et_get_current_price()
else:
grid_price = prices.grid
prices_dict = {"grid": grid_price,
"pv": prices.pv,
"bat": prices.bat}
try:
prices = data.data.general_data.data.prices
try:
grid_price = data.data.optional_data.et_get_current_price()
except Exception:
grid_price = prices.grid
prices_dict = {"grid": grid_price,
"pv": prices.pv,
"bat": prices.bat}
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Preise")
prices_dict = {}

cp_dict = {}
try:
cp_dict = {"all": {"imported": data.data.cp_all_data.data.get.imported,
"exported": data.data.cp_all_data.data.get.exported}}
except Exception:
log.exception("Fehler im Werte-Logging-Modul")
cp_dict = {}
for cp in data.data.cp_data:
try:
if "cp" in cp:
cp_dict.update({cp: {"imported": data.data.cp_data[cp].data.get.imported,
"exported": data.data.cp_data[cp].data.get.exported}})
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Ladepunkt "+str(cp))
try:
cp_dict.update(
{"all": {"imported": data.data.cp_all_data.data.get.imported,
"exported": data.data.cp_all_data.data.get.exported}})
except Exception:
log.exception("Fehler im Werte-Logging-Modul")

ev_dict = {}
for ev in data.data.ev_data:
Expand All @@ -242,7 +245,11 @@ def create_entry(log_type: LogType, sh_log_data: LegacySmartHomeLogData, previou
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Zähler "+str(counter))

pv_dict = {"all": {"exported": data.data.pv_all_data.data.get.exported}}
try:
pv_dict = {"all": {"exported": data.data.pv_all_data.data.get.exported}}
except Exception:
log.exception("Fehler im Werte-Logging-Modul für PV-Daten")
pv_dict = {}
if data.data.pv_all_data.data.config.configured:
for pv in data.data.pv_data:
try:
Expand All @@ -251,9 +258,13 @@ def create_entry(log_type: LogType, sh_log_data: LegacySmartHomeLogData, previou
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Wechselrichter "+str(pv))

bat_dict = {"all": {"imported": data.data.bat_all_data.data.get.imported,
"exported": data.data.bat_all_data.data.get.exported,
"soc": data.data.bat_all_data.data.get.soc}}
try:
bat_dict = {"all": {"imported": data.data.bat_all_data.data.get.imported,
"exported": data.data.bat_all_data.data.get.exported,
"soc": data.data.bat_all_data.data.get.soc}}
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Batteriespeicher-Daten")
bat_dict = {}
if data.data.bat_all_data.data.config.configured:
for bat in data.data.bat_data:
try:
Expand All @@ -263,7 +274,11 @@ def create_entry(log_type: LogType, sh_log_data: LegacySmartHomeLogData, previou
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Speicher "+str(bat))

hc_dict = {"all": {"imported": data.data.counter_all_data.data.set.imported_home_consumption}}
try:
hc_dict = {"all": {"imported": data.data.counter_all_data.data.set.imported_home_consumption}}
except Exception:
log.exception("Fehler im Werte-Logging-Modul für Hausverbrauch")
hc_dict = {}
new_entry = {
"timestamp": current_timestamp,
"date": date,
Expand Down