Beer fermentation controller
go
Find a file
Søren Rasmussen d36d239697
All checks were successful
continuous-integration/drone/push Build is passing
Add deb package
2022-05-02 22:02:13 +02:00
build/debian Add deb package 2022-05-02 22:02:13 +02:00
cmd Wait on slaves for w1 bus master bulk read 2022-03-18 13:41:47 +01:00
internal Remove debug state change line 2022-03-22 20:53:15 +01:00
pkg Strip whitespace from bulk temperature read 2022-03-18 13:48:33 +01:00
.drone.yml Add deb package 2022-05-02 22:02:13 +02:00
.editorconfig Work since initial 2021-08-30 22:46:38 +02:00
.gitignore Initial import 2021-08-10 23:29:24 +02:00
go.mod Update dependencies 2022-04-29 20:51:19 +02:00
go.sum Update dependencies 2022-04-29 20:51:19 +02:00
Makefile Debian packaging 2022-03-11 20:57:09 +01:00
README.md Update README 2022-03-18 13:41:34 +01:00
states.md Work since initial 2021-08-30 22:46:38 +02:00
wiring.md Add wiring.md 2022-03-13 18:30:35 +01:00

fermentord

Control the temperature of your fermentation process.

Integrations

  • NATS
  • Prometheus
  • Sentry

Epics

Heater/Cooler

Persona Description
Brewer The person responsible for the wort and the fermentation process
Operator The person responsible for the fermentation tank and the system controlling it

As a brewer I need to maintain the wort at a specific temperature so that my fermentation process is predictable As an operator I need an alert if the system can't maintain the temperature, so that I may correct the problem

Ambient temperature

  • Ambient temperature
  • Case temperature
  • Wort temperature
  • Wort gravity

User stories

Acceptance criteria

  • Given the wort is at or above the requested temperature and the heater is running then stop the heater

  • Given the wort is above the requested temperature and the heater is not running then start the cooler

  • Given the wort is above the requested temperature

  • Given the wort is too cold and the cooler is running then stop the cooler

  • Given the wort is too cold and the cooler is not running then start the heater

  • Given the cooler is running

  • Given the cooler is running when then the heater may not start

  • Given the heater is running then the cooler may not start

  • Given the temperature is

Data logging

  • Ambient temperature

  • Case temperature

  • Wort temperature

  • Wort gravity

  • Data is stored in sqlite3

  • Data is scraped and stored in PostgreSQL

  • Data is removed from sqlite3 when confirmed in PostgreSQL

Metrics

Prometheus metrics

  • Ambient temperature
  • Chamber temperature
  • Wort temperature
  • Wort gravity
  • Heater state
  • Cooler state
  • Tank pressure

Drivers

On the Raspberry Pi you'll need to add dtoverlay=w1-gpio (for regular connection) or dtoverlay=w1-gpio,pullup="y" (for parasitic connection) to your /boot/config.txt. The default data pin is GPIO4, but that can be changed from 4 to x with dtoverlay=w1-gpio,gpiopin=x.

echo dtoverlay=w1-gpio,gpiopin=4,pullup=0 >> /boot/config.txt

modprobe wire
modprobe w1-gpio
modprobe w1-therm

Build

A Raspberry Pi 1 is used, so we compile for ARMv6.

cd cmd/fermentord
GOARCH=arm GOARM=6 GOOS=linux go build