Skip to content

Commit

Permalink
Merge pull request craftbeerpi#97 from PiBrewing/development
Browse files Browse the repository at this point in the history
Merge changes from Development
  • Loading branch information
avollkopf authored Mar 10, 2023
2 parents 2aae389 + 8dae245 commit 10fa86b
Show file tree
Hide file tree
Showing 10 changed files with 167 additions and 25 deletions.
37 changes: 23 additions & 14 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,16 @@ on:
pull_request:

env:
image-name: ghcr.io/${{ github.repository_owner }}/craftbeerpi4
IMAGE_NAME: ghcr.io/${{ github.repository_owner }}/craftbeerpi4

jobs:
build:
runs-on: ubuntu-latest
permissions:
packages: write
name: Builds the source distribution package
steps:

- name: Checkout source
uses: actions/checkout@v2

Expand Down Expand Up @@ -54,8 +57,11 @@ jobs:
id: prep
run: |
IMAGE_NAME_LOWERCASE=${IMAGE_NAME,,}
echo "Using image name $IMAGE_NAME_LOWERCASE"
PUBLISH_IMAGE=false
TAGS="${{ env.image-name }}:dev"
TAGS="$IMAGE_NAME_LOWERCASE:dev"
# Define the image that will be used as a cached image
# to speed up the build process
Expand All @@ -65,18 +71,21 @@ jobs:
# when building master/main use :latest tag and the version number
# from the cbpi/__init__.py file
VERSION=$(grep -o -E "(([0-9]{1,2}[.]?){2,3}[0-9]+)" cbpi/__init__.py)
LATEST_IMAGE=${{ env.image-name }}:latest
LATEST_IMAGE=$IMAGE_NAME_LOWERCASE:latest
BUILD_CACHE_IMAGE_NAME=${LATEST_IMAGE}
TAGS="${LATEST_IMAGE},${{ env.image-name }}:v${VERSION}"
PUBLISH_IMAGE=true
TAGS="${LATEST_IMAGE},$IMAGE_NAME_LOWERCASE:v${VERSION}"
PUBLISH_IMAGE="true"
elif [[ $GITHUB_REF_NAME == development ]]; then
PUBLISH_IMAGE=true
PUBLISH_IMAGE="true"
fi
# Set output parameters.
echo ::set-output name=tags::${TAGS}
echo ::set-output name=publish_image::${PUBLISH_IMAGE}
echo ::set-output name=build_cache_image_name::${BUILD_CACHE_IMAGE_NAME}
echo "tags: $TAGS"
echo "publish_image: $PUBLISH_IMAGE"
echo "cache_name: $BUILD_CACHE_IMAGE_NAME"
echo "tags=$TAGS" >> $GITHUB_OUTPUT
echo "publish_image=$PUBLISH_IMAGE" >> $GITHUB_OUTPUT
echo "cache_name=$BUILD_CACHE_IMAGE_NAME" >> $GITHUB_OUTPUT
- name: Set up QEMU
uses: docker/setup-qemu-action@master
Expand All @@ -88,23 +97,23 @@ jobs:
uses: docker/setup-buildx-action@master

- name: Login to GitHub Container Registry
uses: docker/login-action@v1
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Build
uses: docker/build-push-action@v2
uses: docker/build-push-action@v4
with:
builder: ${{ steps.buildx.outputs.name }}
context: .
file: ./Dockerfile
platforms: linux/amd64,linux/arm64
target: deploy
push: ${{ steps.prep.outputs.publish_image }}
push: ${{ steps.prep.outputs.publish_image == 'true' }}
tags: ${{ steps.prep.outputs.tags }}
cache-from: type=registry,ref=${{ steps.prep.outputs.build_cache_image_name }}
cache-from: type=registry,ref=${{ steps.prep.outputs.cache_name }}
cache-to: type=inline
labels: |
org.opencontainers.image.title=${{ github.event.repository.name }}
Expand Down
2 changes: 1 addition & 1 deletion cbpi/__init__.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
__version__ = "4.1.5"
__version__ = "4.1.6"
__codename__ = "Groundhog Day"

5 changes: 5 additions & 0 deletions cbpi/api/dataclasses.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,10 @@ def __str__(self):
def to_dict(self):
return dict(id=self.id, name=self.name, type=self.type, props=self.props.to_dict(), state=self.instance.get_state(), power=self.power)

class DataType(Enum):
VALUE="value"
DATETIME="datetime"
STRING="string"

@dataclass
class Sensor:
Expand All @@ -73,6 +77,7 @@ class Sensor:
state: bool = False
type: str = None
instance: str = None
datatype: DataType = DataType.VALUE

def __str__(self):
return "name={} props={}, state={}".format(self.name, self.props, self.state)
Expand Down
9 changes: 6 additions & 3 deletions cbpi/api/sensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import logging
from abc import abstractmethod, ABCMeta
from cbpi.api.extension import CBPiExtension
from cbpi.api.dataclasses import DataType


from cbpi.api.base import CBPiBase
Expand All @@ -16,6 +17,7 @@ def __init__(self, cbpi, id, props):
self.data_logger = None
self.state = False
self.running = False
self.datatype=DataType.VALUE

def init(self):
pass
Expand All @@ -33,13 +35,14 @@ def get_unit(self):
pass

def push_update(self, value, mqtt = True):

try:
self.cbpi.ws.send(dict(topic="sensorstate", id=self.id, value=value))
self.cbpi.ws.send(dict(topic="sensorstate", id=self.id, value=value, datatype=self.datatype.value))
if mqtt:
self.cbpi.push_update("cbpi/sensordata/{}".format(self.id), dict(id=self.id, value=value), retain=True)
self.cbpi.push_update("cbpi/sensordata/{}".format(self.id), dict(id=self.id, value=value, datatype=self.datatype.value), retain=True)
# self.cbpi.push_update("cbpi/sensor/{}/udpate".format(self.id), dict(id=self.id, value=value), retain=True)
except:
logging.error("Failed to push sensor update")
logging.error("Failed to push sensor update for sensor {}".format(self.id))

async def start(self):
pass
Expand Down
13 changes: 8 additions & 5 deletions cbpi/controller/log_file_controller.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,11 +158,14 @@ async def get_data2(self, ids) -> dict:
dateparse = lambda dates: [datetime.datetime.strptime(d, '%Y-%m-%d %H:%M:%S') for d in dates]
result = dict()
for id in ids:
all_filenames = glob.glob(os.path.join(self.logsFolderPath,f"sensor_{id}.log*"))
df = pd.concat([pd.read_csv(f, parse_dates=['DateTime'], date_parser=dateparse, index_col='DateTime', names=['DateTime', 'Values'], header=None) for f in all_filenames])
df = df.resample('60s').max()
df = df.dropna()
result[id] = {"time": df.index.astype(str).tolist(), "value":df.Values.tolist()}
try:
all_filenames = glob.glob(os.path.join(self.logsFolderPath,f"sensor_{id}.log*"))
df = pd.concat([pd.read_csv(f, parse_dates=['DateTime'], date_parser=dateparse, index_col='DateTime', names=['DateTime', 'Values'], header=None) for f in all_filenames])
df = df.resample('60s').max()
df = df.dropna()
result[id] = {"time": df.index.astype(str).tolist(), "value":df.Values.tolist()}
except:
pass
return result


Expand Down
3 changes: 2 additions & 1 deletion cbpi/extension/dummysensor/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@
import logging
from cbpi.api import *
from cbpi.api.base import CBPiBase
from cbpi.api.dataclasses import Kettle, Props, Fermenter
from cbpi.api.dataclasses import Kettle, Props, Fermenter, DataType
import time

@parameters([])
class CustomSensor(CBPiSensor):
Expand Down
93 changes: 93 additions & 0 deletions cbpi/extension/timer/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
# -*- coding: utf-8 -*-
from aiohttp import web
import logging
import asyncio
from cbpi.api import *
from cbpi.api import base
from time import strftime, gmtime
from cbpi.api.timer import Timer
from cbpi.api.dataclasses import DataType
from cbpi.api.dataclasses import NotificationAction, NotificationType

logger = logging.getLogger(__name__)
@parameters([])
class AlarmTimer(CBPiSensor):

def __init__(self, cbpi, id, props):
super(AlarmTimer, self).__init__(cbpi, id, props)
self.value = "00:00:00"
self.datatype=DataType.STRING
self.timer = None
self.time=0
self.stopped=False
self.sensor=self.get_sensor(self.id)

@action(key="Set Timer", parameters=[Property.Number(label="time", description="Time in Minutes", configurable=True)])
async def set(self, time = 0,**kwargs):
self.stopped=False
self.time = float(time)
self.value=self.calculate_time(self.time)
if self.timer is not None:
await self.timer.stop()
self.timer = Timer(int(self.time * 60), on_update=self.on_timer_update, on_done=self.on_timer_done)
await self.timer.stop()
self.timer.is_running = False
logging.info("Set Timer")

@action(key="Start Timer", parameters=[])
async def start(self , **kwargs):
if self.timer is None:
self.timer = Timer(int(self.time * 60), on_update=self.on_timer_update, on_done=self.on_timer_done)

if self.timer.is_running is not True:
self.timer.start()
self.stopped=False
self.timer.is_running = True
else:
self.cbpi.notify(self.sensor.name,'Timer is already running', NotificationType.WARNING)

@action(key="Stop Timer", parameters=[])
async def stop(self , **kwargs):
self.stopped=False
await self.timer.stop()
self.timer.is_running = False
logging.info("Stop Timer")

@action(key="Reset Timer", parameters=[])
async def Reset(self , **kwargs):
self.stopped=False
if self.timer is not None:
await self.timer.stop()
self.value=self.calculate_time(self.time)
self.timer = Timer(int(self.time * 60), on_update=self.on_timer_update, on_done=self.on_timer_done)
await self.timer.stop()
self.timer.is_running = False
logging.info("Reset Timer")

async def on_timer_done(self, timer):
#self.value = "Stopped"
if self.stopped is True:
self.cbpi.notify(self.sensor.name,'Timer done', NotificationType.SUCCESS)

self.timer.is_running = False
pass

async def on_timer_update(self, timer, seconds):
self.stopped=True
self.value = Timer.format_time(seconds)

async def run(self):
while self.running is True:
self.push_update(self.value)
await asyncio.sleep(1)
pass

def get_state(self):
return dict(value=self.value)

def calculate_time(self, time):
return strftime("%H:%M:%S", gmtime(time*60))

def setup(cbpi):
cbpi.plugin.register("AlarmTimer", AlarmTimer)
pass
3 changes: 3 additions & 0 deletions cbpi/extension/timer/config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
name: timer
version: 4
active: true
4 changes: 3 additions & 1 deletion cbpi/http_endpoints/http_log.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
from cbpi.api import request_mapping
import os
import json
import logging
class LogHttpEndpoints:

def __init__(self,cbpi):
Expand Down Expand Up @@ -189,7 +190,8 @@ async def get_log2(self, request):
description: successful operation.
"""
data = await request.json()
return web.json_response(await self.cbpi.log.get_data2(data), dumps=json_dumps)
values = await self.cbpi.log.get_data2(data)
return web.json_response(values, dumps=json_dumps)


@request_mapping(path="/{name}", method="DELETE", auth_required=False)
Expand Down
23 changes: 23 additions & 0 deletions tests/cbpi-test-config/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,22 @@
"type": "string",
"value": "Some New Brewery Name"
},
"BoilAutoTimer": {
"description": "Start Boil timer automatically if Temp does not change for 5 Minutes and is above 95C/203F",
"name": "BoilAutoTimer",
"options": [
{
"label": "Yes",
"value": "Yes"
},
{
"label": "No",
"value": "No"
}
],
"type": "select",
"value": "No"
},
"BoilKettle": {
"description": "Define Kettle that is used for Boil, Whirlpool and Cooldown. If not selected, MASH_TUN will be used",
"name": "BoilKettle",
Expand Down Expand Up @@ -107,6 +123,13 @@
"type": "select",
"value": "No"
},
"INFLUXDBMEASUREMENT": {
"description": "Name of the measurement in your INFLUXDB database (default: measurement)",
"name": "INFLUXDBMEASUREMENT",
"options": null,
"type": "string",
"value": "measurement"
},
"INFLUXDBNAME": {
"description": "Name of your influxdb database name (If INFLUXDBCLOUD set to Yes use bucket of your influxdb cloud database)",
"name": "INFLUXDBNAME",
Expand Down

0 comments on commit 10fa86b

Please sign in to comment.