openhab-addons/bundles/org.openhab.binding.dominoswiss
Holger Friedrich 639a1cb263
Prepare for OH 5.0.0 (#17906)
* Switch to 5.0.0-SNAPSHOT
* Fix spotless after unleash
* resolve itest runbundles

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>
2024-12-15 20:30:05 +01:00
..
src/main Use diamond operator and remove redundant type arguments (#16249) 2024-01-09 23:46:15 +01:00
NOTICE
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00
README.md Multiple binding markdown fixes (#17422) 2024-09-28 17:46:53 +02:00

Dominoswiss Binding

This binding allows the control of rollershutters, using an eGate as gateway and Dominoswiss radio receivers. The eGate-gateway is connected via ethernet to openHAB and sends its commands via radio to all rollershutters. See https://www.brelag.com/ for more information.

Supported Things

eGate: Dominoswiss eGate Server. The eGate is the gateway which sends the commands to the connected rollershutters. The bridge-type ID is egate. Blind: represents one rollershutter, that can be controlled via eGate. The thing-type ID is blind.

Discovery

Unfortunately no automatic discovery is possible due to protocol restrictions. Every rollershutter must be known by eGate and can be called by it's number of storage-place on eGate gateway.

Thing Configuration

The bridge "eGate" has one channel "getconfig" which returns the config of this bridge. The eGate is configured with both an ipAddress and a port.

Property Default Required Description
ipAddress none Yes The IP or host name of the Dominoswiss EGate Serve
port 1318 Yes Port interface of the Dominoswiss EGate Server
Bridge dominoswiss:egate:myeGate "My eGate Server" @ "Home" [ ipAddres="localhost", port=5700 ]

The thing blind represents one blind on the eGate. Each blind is represented by an id set on your eGate.

Thing blind officeBlind "Office" @ "1stFloor" [ id="1"]

The blind-Thing has the following channels:

Channel Type ID Item Type Description
pulseUp Rollershutter sends one pulse up to this blind.
pulseDown Rollershutter sends one pulse down to this blind
continuousUp Rollershutter sends a continuous up to this blind. The blind will automatically stop as it is fully up.
continuousDown Rollershutter send a continous down to this blind. The blind will automatically stop as it is fully down.
stop Rollershutter stop the action of the blind. The command will be imadiatly sent to the blind.
shutter Rollershutter this is used to bind the channel to the shutter item. There are no further rules needed this channel will handel the up/down/stop commands. See example for usage.
tilt Rollershutter same as shutter, this will handel all up/down/stop - tilt commands to be used with the shutter-item.
tiltUp Rollershutter sends 3 pulse-up commands to this blind to tilt the blind. If your blind needs more than 3 pulse-up, create a rule yourself with three pluse-up commands. Between each pulse-up you should wait 150ms to let the command be processed.
tiltDown Rollershutter sends 3 pulse-down commands to this blind to tilt the blind. If your blind needs more than 3 pulse-down, create a rule yourself with three pluse-down commands. Between each pulse-down you should wait 150ms to let the command be processed.

Full Example

Sample things file:

Bridge dominoswiss:egate:myeGate "My eGate Server" @ "Home" [ ipAddres="localhost", port="5500" ]
{
    Thing blind officeBlind "Office" @ "1stFloor" [ id="1"]
    Thing blind diningRoomBlind "Dining Room" @ "EG" [id="2"]
    Thing blind kitchenBlind "Kitchen" @ "EG" [id="12"]
}

Sample items file:

Rollershutter OfficeBlindShutter "Office blind" <rollershutter>  (g_blinds) { channel="dominoswiss:blind:myeGate:officeBlind:shutter"}

Rollershutter OfficeBlindShutterTilt "Tilt Office" <rollershutter>  (g_blinds_tilt) { channel="dominoswiss:blind:meGgate:bueroBlind:tilt"}

Sample sitemap file

Switch  item=OfficeBlindShutter
Switch  item=OfficeBlindShutterTilt

Sample rule file

This example moves the blind of the office up as the sun passed 110 azimuth (so the sun is no longer shining directly into the office).

rule "OneSide up"
when
    Item Azimuth changed
then
    val azimuth = Math::round((Azimuth.state as DecimalType).intValue)
    if (azimuth == 110)
    {
        OfficeBlindShutter.sendCommand(UP)
    }
end