85 lines
2.5 KiB
Markdown
85 lines
2.5 KiB
Markdown
# LIRC Binding
|
|
|
|
This binding integrates infrared transceivers through [LIRC](https://www.lirc.org) or [WinLIRC](http://winlirc.sourceforge.net).
|
|
|
|
A list of remote configuration files for LIRC is available [here](http://lirc-remotes.sourceforge.net/remotes-table.html).
|
|
|
|
## Supported Things
|
|
|
|
This binding supports LIRC and WinLIRC as bridges for accessing the configured remotes.
|
|
|
|
LIRC must be started with TCP enabled. On systemd based systems, TCP can be enabled by editing the file
|
|
`/usr/lib/systemd/system/lirc.service` and adding `--listen` to the end of the `ExecStart` line. An example
|
|
systemd service file for LIRC is shown below.
|
|
|
|
```ini
|
|
[Unit]
|
|
Description=Linux Infrared Remote Control
|
|
After=network.target
|
|
|
|
[Service]
|
|
RuntimeDirectory=lirc
|
|
ExecStart=/usr/sbin/lircd --nodaemon --driver=default --device=/dev/lirc0 --listen
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|
|
```
|
|
|
|
By default, LIRC will listen on IP address 0.0.0.0 (any available IP address) and port 8765. If you would
|
|
rather run LIRC on a specific port or IP address, you can use `--listen=192.168.1.100:9001` instead.
|
|
|
|
## Discovery
|
|
|
|
Discovery of the LIRC bridge is not supported. However, remotes will be automatically discovered once
|
|
a bridge is configured.
|
|
|
|
## Example Configuration
|
|
|
|
### Things
|
|
|
|
```java
|
|
Bridge lirc:bridge:local [ host="192.168.1.120", portNumber="9001" ] {
|
|
Thing remote Onkyo_RC_799M [ remote="Onkyo_RC-799M" ]
|
|
Thing remote Samsung [ remote="Samsung" ]
|
|
}
|
|
```
|
|
|
|
Bridge:
|
|
|
|
- **host**: IP address or hostname of the LIRC server. Defaults to localhost
|
|
- **port**: The port number the LIRC server is listening on. Defaults to 8765
|
|
|
|
Remote:
|
|
|
|
- **remote**: The name of the remote as known by LIRC
|
|
|
|
### Items
|
|
|
|
```java
|
|
String Remote_AVReceiver { channel="lirc:remote:local:Onkyo_RC_799M:transmit" }
|
|
String Remote_TV { channel="lirc:remote:local:Samsung:transmit" }
|
|
```
|
|
|
|
### Rules
|
|
|
|
```java
|
|
rule "LIRC Test"
|
|
when
|
|
Channel 'lirc:remote:local:Samsung:event' triggered KEY_DVD
|
|
then
|
|
// Toggle base boost on the AV Receiver
|
|
Remote_AVReceiver.sendCommand("KEY_BASEBOOST")
|
|
// Increase the volume by 5.
|
|
Remote_AVReceiver.sendCommand("KEY_VOLUMEUP 5")
|
|
end
|
|
```
|
|
|
|
## Channels
|
|
|
|
This binding currently supports following channels:
|
|
|
|
| Channel Type ID | Item Type | Description |
|
|
|-----------------|--------------|---------------------------------------|
|
|
| event | Trigger | Triggers when a button is pressed. |
|
|
| transmit | String | Used to transmit IR commands to LIRC. |
|