Add Tasmota timezone handling and dashboard updates

This commit is contained in:
2026-03-16 12:17:40 +01:00
parent 5ac9cc3892
commit 585378297c
10 changed files with 1223 additions and 1027 deletions
+15 -4
View File
@@ -22,6 +22,14 @@ var tasmotaTimeLayouts = []string{
}
func ParseTasmota(message model.RawMessage) ([]model.Record, error) {
return ParseTasmotaInLocation(message, time.UTC)
}
func ParseTasmotaInLocation(message model.RawMessage, timezoneLessTimeLocation *time.Location) ([]model.Record, error) {
if timezoneLessTimeLocation == nil {
timezoneLessTimeLocation = time.UTC
}
parts := strings.Split(message.Topic, "/")
if len(parts) != 3 {
return nil, fmt.Errorf("unsupported topic shape: %s", message.Topic)
@@ -52,7 +60,7 @@ func ParseTasmota(message model.RawMessage) ([]model.Record, error) {
return nil, fmt.Errorf("no usable fields in payload for topic %s", message.Topic)
}
timestamp := parsePayloadTimestamp(payload, message.ReceivedAt)
timestamp := parsePayloadTimestamp(payload, message.ReceivedAt, timezoneLessTimeLocation)
record := model.Record{
Measurement: measurement,
@@ -77,11 +85,14 @@ func parseLWT(message model.RawMessage, measurement string, tags map[string]stri
}
}
func parsePayloadTimestamp(payload map[string]any, fallback time.Time) time.Time {
func parsePayloadTimestamp(payload map[string]any, fallback time.Time, timezoneLessTimeLocation *time.Location) time.Time {
rawTime, ok := payload["Time"].(string)
if !ok || strings.TrimSpace(rawTime) == "" {
return fallback
}
if timezoneLessTimeLocation == nil {
timezoneLessTimeLocation = time.UTC
}
for _, layout := range tasmotaTimeLayouts {
var (
@@ -90,13 +101,13 @@ func parsePayloadTimestamp(payload map[string]any, fallback time.Time) time.Time
)
if layout == "2006-01-02T15:04:05" {
parsed, err = time.ParseInLocation(layout, rawTime, time.UTC)
parsed, err = time.ParseInLocation(layout, rawTime, timezoneLessTimeLocation)
} else {
parsed, err = time.Parse(layout, rawTime)
}
if err == nil {
return parsed
return parsed.UTC()
}
}