diff options
| author | xengineering <me@xengineering.eu> | 2026-03-23 17:59:33 +0100 |
|---|---|---|
| committer | xengineering <me@xengineering.eu> | 2026-03-25 21:09:01 +0100 |
| commit | 776e6fdd8415edd0daa5743c35cbee029a89c6a7 (patch) | |
| tree | af6ec85cf7da94a8c647c1d87bc78705d6f0ad0e /config.go | |
| parent | 91844eb24c16d7ba768f913597702f8075fe8af2 (diff) | |
| download | sia-server-776e6fdd8415edd0daa5743c35cbee029a89c6a7.tar sia-server-776e6fdd8415edd0daa5743c35cbee029a89c6a7.tar.zst sia-server-776e6fdd8415edd0daa5743c35cbee029a89c6a7.zip | |
Add shelly configuration parsing
This allows to specify Shelly cover devices to be added to the
configuration file with all information required by the Sia server.
Diffstat (limited to 'config.go')
| -rw-r--r-- | config.go | 15 |
1 files changed, 15 insertions, 0 deletions
@@ -45,9 +45,17 @@ type HomematicConfig struct { PollingPeriod string `json:"polling-period"` } +type ShellyConfig struct { + ID string `json:"id"` + IP string `json:"ip"` +} + +type ShellyConfigs []ShellyConfig + type StartupConfig struct { MQTT MQTTConfig `json:"mqtt"` Homematic HomematicConfig `json:"homematic"` + Shelly ShellyConfigs `json:"shelly"` } func (sc StartupConfig) String() string { @@ -117,6 +125,13 @@ func (sc StartupConfig) Validate() error { return fmt.Errorf("homematic/polling-period configuration '%s' could not be parsed to duration: %v", sc.Homematic.PollingPeriod, err) } + for _, shelly := range sc.Shelly { + ip := net.ParseIP(shelly.IP) + if ip == nil { + return fmt.Errorf("Failed to parse IP address '%s'.", shelly.IP) + } + } + return nil } |
