openhab-addons/bundles/org.openhab.binding.plugwise
Wouter Born 8672ed0208
Start license headers with `/*` instead of `/**` (#18061)
Prevents JavaDoc tooling issues because these tools check comments starting with `/**`.

Signed-off-by: Wouter Born <github@maindrain.net>
2025-01-07 22:33:03 +01:00
..
src/main Start license headers with `/*` instead of `/**` (#18061) 2025-01-07 22:33:03 +01:00
NOTICE
README.md Fix Zigbee name stylization (#13954) 2022-12-17 17:25:38 +01:00
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00

README.md

Plugwise Binding

The Plugwise binding adds support to openHAB for Plugwise Zigbee devices using the Stick.

Users should use the Plugwise Source software to define the network, reset devices or perform firmware upgrades.

Currently only "V2" of the Plugwise protocol is supported. It is advised that users of the binding upgrade their devices to the latest firmware using the Plugwise Source software.

Supported Things

The binding supports the following Plugwise devices:

Device Type Description Thing Type
Circle A power outlet plug that provides energy measurement and switching control of appliances circle
Circle+ A special Circle that coordinates the Zigbee network and acts as network gateway circleplus
Scan A wireless motion (PIR) and light sensor scan
Sense A wireless temperature and humidity sensor sense
Stealth A Circle with a more compact form factor that can be built-in stealth
Stick A Zigbee USB controller that openHAB uses to communicate with the Circle+ stick
Switch A wireless wall switch switch

Discovery

Automatic device discovery runs every 3 minutes which can be sped up by starting a manual discovery. All Circle, Circle+ and Stealth devices are discovered immediately after adding the Stick. Battery powered devices like the Scan, Sense and Switch are discovered when they are awake. The Scan and Sense can be woken by pressing the "Wake" button. The Switch is detected when it is awake after switching the left or right button.

Thing Configuration

MAC addresses

The MAC addresses are stickered to the back of Plugwise devices. The binding uses full MAC addresses i.e. also the fine print on the sticker. If you don't want to get off your chair, climb up ladders and unplug devices all across your home, causing all sorts of havoc; you can also find them in Source. Open Settings > Appliances. Then double click on an appliance. Click on the little Circle icon to the right of the short Address to see the details of a module and the full MAC address.

Similarly the MAC addresses of the Scan, Sense and Switch can also be obtained from the Appliances screen by double clicking them in the Sensors and other modules list.

Stick

Configuration Parameter Required Default Description
serialPort X /dev/ttyUSB0 The serial port of the Stick, e.g. "/dev/ttyUSB0" for Linux or "COM1" for Windows
messageWaitTime 150 The time to wait between messages sent on the Zigbee network (in ms)

To determine the serial port in Linux, insert the Stick, then execute the dmesg command. The last few lines of the output will contain the USB port of the Stick (e.g. /dev/ttyUSB0). In Windows the Device Manager lists it in the Ports (COM & LPT) section. On some Linux distributions (e.g. Raspbian) an OS restart may be required before the Stick is properly configured. To access the serial port of the Stick on Linux, the user running openHAB needs to be part of the 'dialout' group. E.g. for the user 'openhab' issue the following command: sudo adduser openhab dialout.

Circle(+), Stealth

Configuration Parameter Required Default Description
macAddress X The full device MAC address e.g. "000D6F0000A1B2C3"
powerStateChanging commandSwitching Controls if the power state can be changed with commands or is always on/off (commandSwitching, alwaysOn or alwaysOff)
suppliesPower false Enables power production measurements (true or false)
measurementInterval 60 The energy measurement interval (in minutes) (5 to 60)
temporarilyNotInNetwork false Stops searching for an unplugged device on the Zigbee network traffic (true or false)

Scan

Configuration Parameter Required Default Description
macAddress X The full device MAC address e.g. "000D6F0000A1B2C3"
sensitivity medium The sensitivity of movement detection (off, medium or high)
switchOffDelay 5 The delay the Scan waits before sending an off command when motion is no longer detected (in minutes) (1 to 240)
daylightOverride false Disables movement detection when there is daylight (true or false)
wakeupInterval 1440 The interval in which the Scan wakes up at least once (in minutes) (5 to 1440)
wakeupDuration 10 The number of seconds the Scan stays awake after it woke up (10 to 120)

Sense

Configuration Parameter Required Default Description
macAddress X The full device MAC address e.g. "000D6F0000A1B2C3"
measurementInterval 15 The interval in which the Sense measures the temperature and humidity (in minutes) (5 to 60)
boundaryType none The boundary type that is used for switching (none, temperature or humidity)
boundaryAction offBelowOnAbove The boundary switch action when the value is below/above the boundary minimum/maximum (offBelowOnAbove or onBelowOffAbove)
temperatureBoundaryMin 15 The minimum boundary for the temperature boundary action (0 to 60)
temperatureBoundaryMax 25 The maximum boundary for the temperature boundary action (0 to 60)
humidityBoundaryMin 45 The minimum boundary for the humidity boundary action (5 to 95)
humidityBoundaryMax 65 The maximum boundary for the humidity boundary action (5 to 95)
wakeupInterval 1440 The interval in which the Sense wakes up at least once (in minutes) (5 to 1440)
wakeupDuration 10 The number of seconds the Sense stays awake after it woke up (10 to 120)

Switch

Configuration Parameter Required Default Description
macAddress X The full device MAC address e.g. "000D6F0000A1B2C3"
wakeupInterval 1440 The interval in which the Switch wakes up at least once (in minutes) (5 to 1440)
wakeupDuration 10 The number of seconds the Switch stays awake after it woke up (10 to 120)

Channels

Channel Type ID Item Type Description Thing Types
clock String Time as indicated by the internal clock of the device circle, circleplus, stealth
energy Number:Energy Energy consumption/production during the last measurement interval circle, circleplus, stealth
energystamp DateTime Timestamp of the start of the last energy measurement interval circle, circleplus, stealth
humidity Number:Dimensionless Current relative humidity sense
lastseen DateTime Timestamp of the last received message. Because there is no battery level indication this is a helpful value to determine if a battery powered device is still operating properly even when no state changes occur circle, circleplus, scan, sense, stealth, switch
leftbuttonstate Switch Current state of the left button switch
power Number:Power Current power consumption, measured over 1 second interval circle, circleplus, stealth
realtimeclock DateTime Time as indicated by the internal clock of the Circle+ circleplus
rightbuttonstate Switch Current state of the right button switch
state Switch Switches the power state on/off circle, circleplus, stealth
temperature Number:Temperature Current temperature sense
triggered Switch Most recent switch action initiated by the device. When daylight override is disabled on a Scan this corresponds one to one with motion detection scan, sense

Example

demo.things

Bridge plugwise:stick:demostick [ serialPort="/dev/ttyUSB0", messageWaitTime=150 ]

Thing plugwise:circle:fan (plugwise:stick:demostick) [ macAddress="000D6F0000A1A1A1", measurementInterval=15 ]

Thing plugwise:circleplus:lamp (plugwise:stick:demostick) [ macAddress="000D6F0000B2B2B2" ] {
    Channels:
        Type clock : clock [ updateInterval=30 ]
        Type energy : energy [ updateInterval=600 ]
        Type power : power [ updateInterval=10 ]
        Type realtimeclock : realtimeclock [ updateInterval=30 ]
        Type state : state [ updateInterval=10 ]
}

Thing plugwise:scan:motionsensor (plugwise:stick:demostick) [ macAddress="000D6F0000C3C3C3", sensitivity="high", switchOffDelay=10 ]

Thing plugwise:sense:climatesensor (plugwise:stick:demostick) [ macAddress="000D6F0000D4D4D4", measurementInterval=10, boundaryType="temperature", boundaryAction="onBelowOffAbove", temperatureBoundaryMin=15, temperatureBoundaryMax=20 ]

Thing plugwise:stealth:fridge (plugwise:stick:demostick) [ macAddress="000D6F0000E5E5E5", powerStateChanging="alwaysOn" ] {
    Channels:
        Type power : power [ updateInterval=10 ]
        Type state : state [ updateInterval=10 ]
}

Thing plugwise:switch:lightswitches (plugwise:stick:demostick) [ macAddress="000D6F0000F6F6F6", wakeupInterval=240, wakeupDuration=20 ]

demo.items

/* Circle */
Switch Fan_Switch "Switch" <switch> { channel="plugwise:circle:fan:state" }
String Fan_Clock "Clock [%s]" <clock> { channel="plugwise:circle:fan:clock" }
Number:Power Fan_Power "Power [%.1f %unit%]" <energy> { channel="plugwise:circle:fan:power" }
Number:Energy Fan_Energy "Energy [%.3f %unit%]" <chart> { channel="plugwise:circle:fan:energy" }
DateTime Fan_Energy_Stamp "Energy stamp [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:circle:fan:energystamp" }
DateTime Fan_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:circle:fan:lastseen" }

/* Circle+ */
Switch Lamp_Switch "Switch" <switch> { channel="plugwise:circleplus:lamp:state" }
String Lamp_Clock "Clock [%s]" <clock> { channel="plugwise:circleplus:lamp:clock" }
Number:Power Lamp_Power "Power [%.1f %unit%]" <energy> { channel="plugwise:circleplus:lamp:power" }
Number:Energy Lamp_Energy "Energy [%.3f %unit%]" <chart> { channel="plugwise:circleplus:lamp:energy" }
DateTime Lamp_Energy_Stamp "Energy stamp [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:circleplus:lamp:energystamp" }
DateTime Lamp_Real_Time_Clock "Real time clock [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <clock> { channel="plugwise:circleplus:lamp:realtimeclock" }
DateTime Lamp_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:circleplus:lamp:lastseen" }

/* Scan */
Switch Motion_Sensor_Switch "Triggered [%s]" <switch> { channel="plugwise:scan:motionsensor:triggered" }
DateTime Motion_Sensor_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <clock> { channel="plugwise:scan:motionsensor:lastseen" }

/* Sense */
Switch Climate_Sensor_Switch "Triggered [%s]" <switch> { channel="plugwise:sense:climatesensor:triggered" }
Number:Dimensionless Climate_Sensor_Humidity "Humidity [%.1f %unit%]" <humidity> { channel="plugwise:sense:climatesensor:humidity" }
Number:Temperature Climate_Sensor_Temperature "Temperature [%.1f %unit%]" <temperature> { channel="plugwise:sense:climatesensor:temperature" }
DateTime Climate_Sensor_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <clock> { channel="plugwise:sense:climatesensor:lastseen" }

/* Stealth */
Switch Fridge_Switch "Switch" <switch> { channel="plugwise:stealth:fridge:state" }
String Fridge_Clock "Clock [%s]" <clock> { channel="plugwise:stealth:fridge:clock" }
Number:Power Fridge_Power "Power [%.1f %unit%]" <energy> { channel="plugwise:stealth:fridge:power" }
Number:Energy Fridge_Energy "Energy [%.3f %unit%]" <chart> { channel="plugwise:stealth:fridge:energy" }
DateTime Fridge_Energy_Stamp "Energy stamp [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:stealth:fridge:energystamp" }
DateTime Fridge_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <calendar> { channel="plugwise:stealth:fridge:lastseen" }

/* Switch */
Switch Light_Switches_Left_Button_State "Left button [%s]" <switch> { channel="plugwise:switch:lightswitches:leftbuttonstate" }
Switch Light_Switches_Right_Button_State "Right button [%s]" <switch> { channel="plugwise:switch:lightswitches:rightbuttonstate" }
DateTime Light_Switches_Last_Seen "Last seen [%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS]" <clock> { channel="plugwise:switch:lightswitches:lastseen" }

demo.sitemap

sitemap demo label="Main Menu"
{

  Frame label="Fan (Circle)" {
    Switch item=Fan_Switch
    Text item=Fan_Clock
    Text item=Fan_Power
    Text item=Fan_Energy
    Text item=Fan_Energy_Stamp
    Text item=Fan_Last_Seen
  }

  Frame label="Lamp (Circle+)" {
    Switch item=Lamp_Switch
    Text item=Lamp_Clock
    Text item=Lamp_Power
    Text item=Lamp_Energy
    Text item=Lamp_Energy_Stamp
    Text item=Lamp_Real_Time_Clock
    Text item=Lamp_Last_Seen
  }

  Frame label="Motion Sensor (Scan)" {
    Text item=Motion_Sensor_Switch
    Text item=Motion_Sensor_Last_Seen
  }

  Frame label="Climate Sensor (Sense)" {
    Text item=Climate_Sensor_Switch
    Text item=Climate_Sensor_Humidity
    Text item=Climate_Sensor_Temperature
    Text item=Climate_Sensor_Last_Seen
  }

  Frame label="Fridge (Stealth)" {
    Switch item=Fridge_Switch
    Text item=Fridge_Clock
    Text item=Fridge_Power
    Text item=Fridge_Energy
    Text item=Fridge_Energy_Stamp
    Text item=Fridge_Last_Seen
  }

  Frame label="Light Switches (Switch)" {
    Text item=Light_Switches_Left_Button_State
    Text item=Light_Switches_Right_Button_State
    Text item=Light_Switches_Last_Seen
  }

}