mirror of
https://github.com/PiBrewing/craftbeerpi4.git
synced 2024-12-31 18:01:46 +01:00
d7c1b64493
Added fermenter type Added fermenter logic (incl. new class) -> will require cbpi4ui -> >= 0.1.a1 Still under development, but fermentation w/o steps should be working
76 lines
No EOL
2.2 KiB
Python
76 lines
No EOL
2.2 KiB
Python
from abc import abstractmethod, ABCMeta
|
|
import asyncio
|
|
from cbpi.api.config import ConfigType
|
|
import time
|
|
|
|
import logging
|
|
|
|
|
|
class CBPiBase(metaclass=ABCMeta):
|
|
|
|
def get_static_config_value(self,name,default):
|
|
return self.cbpi.static_config.get(name, default)
|
|
|
|
def get_config_value(self,name,default):
|
|
return self.cbpi.config.get(name, default=default)
|
|
|
|
async def set_config_value(self,name,value):
|
|
return await self.cbpi.config.set(name,value)
|
|
|
|
async def add_config_value(self, name, value, type: ConfigType, description, options=None):
|
|
await self.cbpi.config.add(name, value, type, description, options=None)
|
|
|
|
def get_kettle(self,id):
|
|
return self.cbpi.kettle.find_by_id(id)
|
|
|
|
def get_kettle_target_temp(self,id):
|
|
return self.cbpi.kettle.find_by_id(id).target_temp
|
|
|
|
async def set_target_temp(self,id, temp):
|
|
await self.cbpi.kettle.set_target_temp(id, temp)
|
|
|
|
def get_fermenter(self,id):
|
|
return self.cbpi.fermenter._find_by_id(id)
|
|
|
|
def get_fermenter_target_temp(self,id):
|
|
return self.cbpi.fermenter._find_by_id(id).target_temp
|
|
|
|
async def set_fermenter_target_temp(self,id, temp):
|
|
await self.cbpi.fermenter.set_target_temp(id, temp)
|
|
|
|
def get_sensor(self,id):
|
|
return self.cbpi.sensor.find_by_id(id)
|
|
|
|
def get_sensor_value(self,id):
|
|
|
|
return self.cbpi.sensor.get_sensor_value(id)
|
|
|
|
def get_actor(self,id):
|
|
return self.cbpi.actor.find_by_id(id)
|
|
|
|
def get_actor_state(self,id):
|
|
try:
|
|
actor = self.cbpi.actor.find_by_id(id)
|
|
return actor.get("instance").get_state()
|
|
except:
|
|
logging.error("Failed to read actor state in step - actor {}".format(id))
|
|
return None
|
|
|
|
async def actor_on(self,id,power=100):
|
|
|
|
try:
|
|
await self.cbpi.actor.on(id,power)
|
|
except Exception as e:
|
|
pass
|
|
|
|
async def actor_off(self,id):
|
|
try:
|
|
await self.cbpi.actor.off(id)
|
|
except Exception as e:
|
|
pass
|
|
|
|
async def actor_set_power(self,id,power):
|
|
try:
|
|
await self.cbpi.actor.set_power(id,power)
|
|
except Exception as e:
|
|
pass |