Currently being run on a Raspberry Pi 3 Model A+.
Tested on a Pi Zero W but didn't have adequate specs.
- Clone the repository
npm i
npm run make
(note: for this to work correctly, it needs to be built in arm64 architecture). The .deb file can be founded in out/make/deb/arm64.- Install pigpio on the Raspberry PI
sudo apt-get install <pool-ctrl.deb>
npm run start
File location: ~/.config/pool-ctrl/modules.config.json
The system has been designed to provide different types of devices/sensors for each of the available modules, however, only the ones used by my own pool controller are currently supported.
{
"pump":{
"switch":{
"type":"tuya",
"configuration":{
"ipAddress":"127.0.0.1",
"deviceId":"<device id>",
"localKey":"<local key>"
}
}
},
"chlorinator":{
"cell":{
"in1":23,
"in2":24,
"descaleCycleDays": 14
},
powerConsumption: {
"address": 64,
"rShunt": 0.1,
"maxMa": 10
}
},
"water":{
"temperature":{
"type":"ds18b20",
"configuration":{
"deviceId":"28-3c46e381ef0a",
"units":"C",
"precision":1
}
}
},
"ambient":{
"temperature":{
"type":"dht",
"configuration":{
"gpio":25,
"type":11
}
}
}
}
File location: ~/.config/pool-ctrl/mqtt.config.json
For integrating with other systems e.g. Home Assistant.
{
"host": "127.0.0.1",
"port": 1883,
"username": "<username>",
"password": "<password>",
"topicPrefix": "pool-controller"
}
Channel names will be prefixed with the topicPrefix
setting provided in the configuration. e.g. chlorinator/output becomes pool-controller/chlorinator/output.