Skip to content

Energiz3r/HydroTek

Repository files navigation

HydroTek

An IoT Controller for Aquaponics, Hydroponics, and Aeroponics


Visit https://github.com/Energiz3r/hydrotek-react to access the react app which accompanies the hardware.

Status Update:

This project is under development. If you wish to build this you should contact me to see if it's feasible at the time. As of writing, the hardware is mostly complete, but I am designing a new PCB to address quality of life points, such as proper connectors for sensors instead of IDC header pins. Firmware is largely finished and, with an understanding of the format of the web requests, could be made to talk to any API for updating the device configuration or just simply logging of data. Management and reporting software comes in the form of a react / PHP / SQL based web app and is only partially complete. Designs for the casing of the device will not be started until the PCB for the current revision is finalised and tested.


Design:

There are four components to this repository:

  • PCB cad file (created in PCBWeb for early revisions, then KiCad as of rev7)
  • Firmware for the ESP32
  • STL files for a case
  • The webb app for configuration and monitoring of the device

History:

Early revisions used an ESP8266 and an Arduino Nano, which communicated with each other over serial. Since discovering the ESP32 I've changed the design to simplify it greatly, however I suffered a consistent issue with the gerber files produced by PCBWeb which is now abandonware. New revisions are made in KiCAD.


Overview:

This device is designed to control lighting and nutrient delivery in a hydroponics environment. It has been designed for use primarily with my own run-to-waste hydroponic system, however could be applied to just about any setup where the same sensors and control outputs are relevant, such as airponics, aquaponics, or even a simple vegge patch.

It's flexible enough that I've also used this to control the temperature within an enclosed container for making bread dough!


latest hardware revision: 7

(rev6 pictured below) Powered here by USB - barrel jack connector not installed. alt-text alt-text

(rev5 pictured below)

alt-text

(rev4 pictured below)

alt-text

(rev3 pictured below)

alt-text


Device Options Menu (rev5):

https://www.youtube.com/watch?v=8toKR6Uxk_A

Features:

  • Uploads sensor data to cloud via WiFi
  • 128x64 OLED display
  • RTC with battery backup for control of grow light times even while offline or after power outage
  • Online RTC time updates for accurate timekeeping
  • Can monitor:
    • DHT22 temperature / humidity sensor
    • Liquid flow sensor (YF-S201 or any 5V based hall-effect sensor)
    • Float switch to detect either empty nutrient tank or full run-off tank
  • Can control:
    • Grow light
    • Nutrient pump
  • Buzzer / LED to alert user to lost WiFi signal, temperature extremes, nutrient pump faults, or full / empty nutrient / run-off tanks
  • The board can be powered either through the barrel jack as designed or using a USB power source plugged into the ESP32 (Note: some USB power sources may not be sufficient to run both the HydroTek as well as relays connected)

I2C pH sensors could be connected using a kit such as this, however pH meters are supposed to be stored in a pH-neutral storage solution. Since this means they aren't suitable for a constant-monitoring setup, pH monitoring was excluded from the feature set.


Design considerations:

  • The device must be maintenance-free
  • Once assembled, flashed, and configured, the device must be easy to set up and use by non-technical people
  • Compact size desirable. Other off-the-shelf units or open-source setups seem to be quite large

To Do (not started):

  • finish API development to complete the feature of updating the device configuration as changes are made to it through the web interface
  • update the RTC time from online
  • WiFi configuration on the device, using buttons and a menu instead of by editing the sketch
  • Flow sensor calibration on the device, eg. 'pour 1L of water through the sensor then press OK'

PCB Build instructions:

Note: The capacitors, barrel jack, and LM7805 can be omitted if the intention is to only run HydroTek from a reliable USB power source.

(rev5)

  • To manufacture the PCB, upload the gerber files for the current PCB revision to a service such as DirtyPCBs
  • Purchase the components, as desired, outlined in the BOM file
  • Solder the components to the PCB, ensuring the following order is observed (B/S = BOTTOM SIDE):
    • (B/S) Solder the LM7805 linear regulator to the UNDERSIDE of the board, ensuring the tab is soldered to the large square pad for heat dissipation
    • Solder in the 4x capacitors
    • Solder in the piezo buzzer
    • Solder in the IDC headers for the sensor inputs (to the TOP side of the board)
    • Solder in the IDC sockets for the LCD (or alternatively, solder the LCD direct to the board, if clearance above capacitors allows)
    • Solder in the ESP32
    • Solder remaining components
    • Install IDC jumper shunts between the GND and DATA pins for flow sensors that will not be used, else the pin will float and detect erroneous readings
    • If the float sensor logic is to be inverted (normally-closed), a jumper shunt on those pins will be handy to silence the alarm if the power is on and the float sensors are not connected
  • Configure your Arduino IDE according to the section below
  • Edit the WiFi configuration and web username / password combination in 'esp32.ino' to suit your needs, then upload to the ESP32
  • Power on your HydroTek and access the web app to confirm it works
  • Connect your (safe, low-voltage) lamps / pumps to the relay module and connect the relay module inputs to the header pins on the PCB
    • NOTE: If in any doubt at all, use safe, low-voltage LED grow lights and nutrient pumps. Switching of mains voltages may not be at all legal where you live, your relays may not be sufficient, I advise you not to try it, and I accept no responsibility if you do.

Arduino IDE Configuration:

(rev5)

  • Go to 'File' > 'Preferences', then click the icon to the right of the text input for "Additional board manager URLs"

  • Paste the following text into the field (separate existing entries by a comma and a new line):

    https://dl.espressif.com/dl/package_esp32_index.json

  • Go to 'Tools' > 'Board...' > 'Boards Manager'

  • Search for ESP32, and install the 'esp32 by Espressif Systems' package (version 1.0.2 at the time of writing)

  • Go to 'Tools' > 'Board...' and select 'ESP32 Dev Module'

  • Go to 'Sketch' > 'Include Library' > 'Manage Libraries'

  • Search for 'Adafruit GFX' and install the 'Adafruit GFX Library' package by Adafruit

  • Search for 'Adafruit 1306' and install the 'Adafruit SSD1306' package by Adafruit

  • Search for 'dht22' and install the 'DHT sensor library' package by Adafruit

  • Search for 'rtclib' and install the 'RTClib' package by Adafruit

  • Go to 'Tools' > 'Port' and select the port for your connected ESP32

  • Once you have edited the .ino file to suit your desired configuration, click upload to flash the ESP.


Known issues:

(rev5)

  • Have not designed a 3D printable case. Will not do this until satisfied the board design is final
  • The react app is included in the repo for now but is incomplete and may be removed in future. Makers will be able to use my hosted platform or build their own API
  • The nutrient flow values are raw 'ticks' from the flow sensor, not a calculated litres or gallons value

API:

(rev5)

The sketch sends a POST request to the URL supplied in the variable 'webEndpoint'. The POST values are as follows:

POST variable name description data type the ESP will supply
user username for API string
password password for API string
deviceID the ID of the device* int
t1 temperature 1 int or float
t2 temperature 2 int or float
h1 humidity 1 int or float
h2 humidity 2 int or float
f1 float 1 int
f2 float 2 int
l1 flow 1 int or float
l2 flow 2 int or float

The deviceID was only intended to be used if you wanted to have multiple devices use your endpoint.

In future, makers will be able to use my hosted platform once it is complete instead of building their own.

About

IoT Hydroponics Controller

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published