The Heating Manager is a Go-based program designed for monitoring and controlling a heating system using Shelly devices. It continuously checks the temperature and activates the heating if needed to prevent exceeding a predefined temperature threshold. Additionally, it conducts weekly checks to ensure the system's proper functionality.
- Temperature Monitoring: Monitors the temperature via a Shelly device and logs the status.
- Automatic Heating Control: Turns on the heating when the set temperature threshold is exceeded.
- Weekly System Check: Performs automatic weekly checks to ensure the system's operability.
The program reads its configuration from a file named config.json
, which should be placed in the same directory as the program. The configuration file should include the following settings:
{
"shellyTempURL": "http://[Shelly-IP-Address]/rpc/Temperature.GetConfig?id=[ID of the temperature sensor]",
"shellyHeatingOnURL": "http://[Shelly-IP-Address]/rpc/Switch.Set?id=0&on=true",
"temperatureThreshold": 55
}
Ensure Go is installed on your system. Clone the repository or download the source files. Run go build in the project directory to create the executable file.
After configuring config.json appropriately and compiling the program, you can start the Heating Manager by running the generated executable:
./heating_manager
The program will continue to run in the background, monitoring the temperature and controlling the heating as needed.
This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.