Strongly type the device FriendlyName

This commit is contained in:
Sven van Heugten 2026-01-05 17:51:57 +01:00
parent 8cc59c4738
commit 89a8c599c7
4 changed files with 23 additions and 12 deletions

View file

@ -59,7 +59,11 @@ type FakeHome() =
option { option {
let! friendlyName = let! friendlyName =
let m = Regex.Match(command.Topic, "^zigbee2mqtt/(.+)/set$") let m = Regex.Match(command.Topic, "^zigbee2mqtt/(.+)/set$")
if m.Success then Some m.Groups.[1].Value else None
if m.Success then
Some(DeviceFriendlyName m.Groups.[1].Value)
else
None
let! fakeLight = Map.tryFind friendlyName friendlyNameToFakeLight let! fakeLight = Map.tryFind friendlyName friendlyNameToFakeLight
@ -94,7 +98,7 @@ type FakeHome() =
Payload = Payload =
$@"{{ $@"{{
""type"": ""device_announce"", ""type"": ""device_announce"",
""data"": {{ ""friendly_name"": ""{light.FriendlyName}"" }} ""data"": {{ ""friendly_name"": ""{light.FriendlyName.Get}"" }}
}}" } }}" }
|> ReceivedZigbeeEvent |> ReceivedZigbeeEvent
|> onEventPublished.Trigger |> onEventPublished.Trigger

View file

@ -30,24 +30,31 @@ type Bulb =
| IkeaBulb | IkeaBulb
| PaulmannBulb | PaulmannBulb
type DeviceFriendlyName =
| DeviceFriendlyName of string
member this.Get =
match this with
| DeviceFriendlyName deviceFriendlyName -> deviceFriendlyName
type Light = type Light =
{ FriendlyName: string { FriendlyName: DeviceFriendlyName
Room: Room Room: Room
Bulb: Bulb } Bulb: Bulb }
let lights = let lights =
[ { FriendlyName = "Vardagsrum - Fönsterlampa" [ { FriendlyName = DeviceFriendlyName "Vardagsrum - Fönsterlampa"
Room = LivingRoom Room = LivingRoom
Bulb = IkeaBulb } Bulb = IkeaBulb }
{ FriendlyName = "Vardagsrum - Vägglampa" { FriendlyName = DeviceFriendlyName "Vardagsrum - Vägglampa"
Room = LivingRoom Room = LivingRoom
Bulb = PaulmannBulb } Bulb = PaulmannBulb }
{ FriendlyName = "Vardagsrum - Golvlampa" { FriendlyName = DeviceFriendlyName "Vardagsrum - Golvlampa"
Room = LivingRoom Room = LivingRoom
Bulb = PaulmannBulb } Bulb = PaulmannBulb }
{ FriendlyName = "Badrum - Taklampa" { FriendlyName = DeviceFriendlyName "Badrum - Taklampa"
Room = Bathroom Room = Bathroom
Bulb = IkeaBulb } Bulb = IkeaBulb }
{ FriendlyName = "Sovrum - Nattduksbordlampa" { FriendlyName = DeviceFriendlyName "Sovrum - Nattduksbordlampa"
Room = Bedroom Room = Bedroom
Bulb = IkeaBulb } ] Bulb = IkeaBulb } ]

View file

@ -4,7 +4,7 @@ open System.Text.Json.Nodes
open NightLight.Core.Models open NightLight.Core.Models
open NightLight.Core.Moods open NightLight.Core.Moods
let generateZigbeeCommand friendlyName targetColor targetBrightness = let generateZigbeeCommand (friendlyName: DeviceFriendlyName) targetColor targetBrightness =
let commandObj = JsonObject() let commandObj = JsonObject()
match targetColor with match targetColor with
@ -19,7 +19,7 @@ let generateZigbeeCommand friendlyName targetColor targetBrightness =
match targetBrightness with match targetBrightness with
| Brightness b -> b | Brightness b -> b
let topic = $"zigbee2mqtt/{friendlyName}/set" let topic = $"zigbee2mqtt/{friendlyName.Get}/set"
let payload = commandObj.ToJsonString() let payload = commandObj.ToJsonString()
{ Topic = topic; Payload = payload } { Topic = topic; Payload = payload }

View file

@ -4,7 +4,7 @@ open NightLight.Core.Models
open FsToolkit.ErrorHandling open FsToolkit.ErrorHandling
open FSharp.Data open FSharp.Data
type ZigbeeEvent = DeviceAnnounce of FriendlyName: string type ZigbeeEvent = DeviceAnnounce of DeviceFriendlyName
let parseZigbeeEvent (message: Message) = let parseZigbeeEvent (message: Message) =
result { result {
@ -17,7 +17,7 @@ let parseZigbeeEvent (message: Message) =
match messageType with match messageType with
| JsonValue.String "device_announce" -> | JsonValue.String "device_announce" ->
match messageData.TryGetProperty "friendly_name" with match messageData.TryGetProperty "friendly_name" with
| Some(JsonValue.String friendlyName) -> Ok(DeviceAnnounce friendlyName) | Some(JsonValue.String friendlyName) -> Ok <| DeviceAnnounce(DeviceFriendlyName friendlyName)
| Some _ -> Error InvalidFriendlyNameField | Some _ -> Error InvalidFriendlyNameField
| None -> Error MissingFriendlyNameField | None -> Error MissingFriendlyNameField
| JsonValue.String _ -> Error UnknownType | JsonValue.String _ -> Error UnknownType