# Souliss Binding

Souliss (opens new window) is a networking framework for Arduino and compatible boards, designed to let you easily build a smart home distributed over multiple boards via Ethernet, Wi‑Fi, wireless point‑to‑point, and RS‑485 bus.

Souliss is an open-source and community-driven project. You can use the Souliss Wiki documentation (opens new window) and Souliss Community Page on GitHub (opens new window) to get help and share your results.

# Prerequisites

The binding requires a deployed network. As a minimum, you need one Souliss node with Ethernet or Wi‑Fi access configured as a Souliss Gateway (opens new window). A gateway is a special node that is able to communicate with user interfaces. The binding interacts as a user interface for Souliss.

Start with the Souliss Wiki documentation (opens new window). It's best to begin with a single node and connect using SoulissApp. The networking code of this binding is based on the SoulissApp documentation (opens new window), so once you're connected with SoulissApp, you can move to openHAB directly.

You can use SoulissApp and the Souliss binding at the same time, generally up to five user interfaces simultaneously by default (this can be increased).

# Sketches

The easiest way is to start with a simple example to control an ON/OFF light (through a relay).

See the Souliss GitHub project (opens new window) for many example sketches in the Examples directory (opens new window).

# Discovery

First add a gateway (only one gateway on the LAN is supported at a time), then discovery can find other things (Souliss Typicals).

# Supported Things

In the Souliss framework, a Typical is a predefined logic block for smart‑home functions such as lights, heating, or anti‑theft.

Typicals can be one of T11, T12, T13, T14, etc., as defined in the Souliss Wiki Typicals documentation (opens new window).

Typicals map directly to openHAB Thing types.

Device type Typical Code Thing type
ON/OFF Digital Output with Timer Option T11 t11
ON/OFF Digital Output with AUTO mode T12 t12
Digital Input Value T13 t13
Pulse Digital Output T14 t14
RGB LED Strip T16 t16
ON/OFF Digital Output T18 t18
Single Color LED Strip T19 t19
Digital Input Pass Through T1A t1A
Motorized devices with limit switches T21 t21
Motorized devices with limit switches and middle position T22 t22
Temperature control T31 t31
Anti-theft integration (Main) T41 t41
Anti-theft integration (Peer) T42 t42
Analog input, half-precision floating point T51 t51
Temperature measure (-20, +50) °C T52 t52
Humidity measure (0, 100) % T53 t53
Light Sensor (0, 40) kLux T54 t54
Voltage (0, 400) V T55 t55
Current (0, 25) A T56 t56
Power (0, 6500) W T57 t57
Pressure measure (0, 1500) hPa T58 t58
Analog Setpoint T61 t61
Analog Setpoint-Temperature measure (-20, +50) °C T62 t62
Analog Setpoint-Humidity measure (0, 100) % T63 t63
Analog Setpoint-Light Sensor (0, 40) kLux T64 t64
Analog Setpoint-Voltage (0, 400) V T65 t65
Analog Setpoint-Current (0, 25) A T66 t66
Analog Setpoint-Power (0, 6500) W T67 t67
Analog Setpoint-Pressure measure (0, 1500) hPa T68 t68
Broadcast messages Action Message topic

# Channels

The following matrix lists the capabilities (channels) for each type:

Thing type / Channel Switch / onOff Switch / sleep DateTime / lastStatusStored Number / healthy Switch / autoMode Contact / stateOnOff Contact / stateOpenClose Switch / pulse Switch / whiteMode Rollershutter / rollerBrightness Dimmer / dimmerBrightness Color / ledColor Switch / one Switch / two Switch / three Switch / four Switch / five Switch / six Switch / seven Switch / eight
t11 x x x x
t12 x x x x
t13 x x x x
t14 x x x
t16 x x x x x x x x
t18 x x x
t19 x x x x x x
t1A x x x x x x x x x x
Thing type / Channel DateTime / lastStatusStored Number / healthy Rollershutter / rollerShutter (see below) / rollerShutterState (see below) / mode (see below) / fan Switch / status Number / setPoint Switch / setAsMeasured Switch / measured Switch / statusAlarm Switch / onOffAlarm Switch / rearmAlarm
t21 x x x x
t22 x x x x
t31 x x x x x x x x
t41 x x x x x
t42 x x x x

rollerShutterState = opening, stop, closing, limSwitchOpen, limSwitchClose, stateOpen, stateClose, NoLimSwitch

mode = COOLING_MODE, HEATING_MODE

fan = AUTO, HIGH, MEDIUM, LOW, FANOFF

Thing type / Channel DateTime / lastStatusStored Number / healthy Number / value
t51 x x x
t52 x x x
t53 x x x
t54 x x x
t55 x x x
t56 x x x
t57 x x x
t58 x x x
Thing type / Channel DateTime / lastStatusStored Number / healthy Number / value
t61 x x x
t62 x x x
t63 x x x
t64 x x x
t65 x x x
t66 x x x
t67 x x x
t68 x x x
topic x x

# Parameters

Thing type Parameters Name and Default Value Description
Gateway gatewayLanAddress="" Mandatory – LAN IPv4 address of the gateway
" gatewayWanAddress="" (advanced) Hostname or IPv4 address for external access
" gatewayPortNumber=230 (advanced) Gateway UDP port
" preferredLocalPortNumber=23000 (advanced) Local UDP port (don't use 0; required when upgrading from 2.x)
" pingInterval=30s (advanced) Interval in seconds to check for device presence
" subscriptionInterval=30s (advanced) Interval in seconds to subscribe to the Souliss gateway
" healthyInterval=60s (advanced) Interval in seconds to send node health
" sendInterval=30ms (advanced) Interval in milliseconds between queued packet sends
" timeoutToRequeue=5000ms (advanced) Requeue timeout in milliseconds for unexecuted packets
" timeoutToRemovePacket=20000ms (advanced) Removal timeout in milliseconds for stale packets
" userIndex=70 (advanced) Generally the default is fine; must differ from other UIs (e.g., SoulissApp)
" nodeIndex=120 (advanced) Generally the default works well; must differ from other UIs (e.g., SoulissApp)
Txx (all) Node Node of typical
Txx (all) Slot Slot of typical
T11 sleep=5 Set sleep timer in cycles
T11 secureSend=true Ensure command is correctly executed
T12
T13
T14
T16 sleep=5 Set sleep timer in cycles
T19 sleep=5 Set sleep timer in cycles
T1A
T21
T22
T31
T4x
T5x
T6x

# Full Example

souliss.things:

Bridge souliss:gateway:105 "Souliss Gateway - 105" [gatewayLanAddress="192.168.1.105", gatewayPortNumber=230, pingInterval=30, subscriptionInterval=2, healthyInterval=38, userIndex=72, nodeIndex=38,  timeoutToRequeue=5000, timeoutToRemovePacket=20000]
{
Thing t14 1-6 "Portoncino"@"Rientro" [node=1,slot=6] //thing UID is named as node-slot only as mnemonic convention, but you are free to assign other values
Thing t14 1-7 "Cancello"@"Rientro" [node=1,slot=7]
Thing t57 1-4 "Consumo"@"Soggiorno" [node=1,slot=4]
Thing t57 4-0 "Fotovoltaico"@"Soggiorno" [node=4,slot=0]
Thing t57 4-6 "Pannelli Gruppo 1"@"Soggiorno" [node=4,slot=6]
Thing t57 4-8 "Pannelli Gruppo 2"@"Soggiorno" [node=4,slot=8]
Thing t52 4-10 "Temp.Pannelli Gruppo 1"@"Soggiorno" [node=4,slot=10]
Thing t52 4-12 "Temp.Pannelli Gruppo 2"@"Soggiorno" [node=4,slot=12]

Thing t52 3-0 "Temperatura Boiler Solare Termico" [node=3,slot=0]
Thing t52 3-2 "Temperatura Termocamino" [node=3,slot=2]
Thing t11 3-4 "Acqua Termocamino" [node=3,slot=4]
Thing t11 3-6 "Auto: Boiler / Termocamino" [node=3,slot=6]
Thing t31 3-7  "Acqua Auto: Boiler / Termocamino" [node=3,slot=7]

Thing t31 6-0 "Termostato Soggiorno"@"Soggiorno" [node=6,slot=0]
Thing t53 6-7 "Umidità"@"Soggiorno" [node=6,slot=7]
Thing t19 6-9 "Termostato Soggiorno - Luminosità"@"Soggiorno" [node=6,slot=9]

Thing t11 5-0 "Tettoia"@"Giardino"  [node=5,slot=0]

Thing t11 12-0 "Divano"@"Soggiorno" [node=12,slot=0,sleep=10, secureSend=false]

Thing t16 8-0 "LYT1" [node=8,slot=0]

Thing t11 10-0 "Albero di Natale" [node=10,slot=0]
Thing t11 11-0 "Birra"@"Soppalco" [node=11,slot=0]
Thing t52 11-1 "Birra - Temp 1"@"Soppalco" [node=11,slot=1]
Thing t52 11-3 "Birra - Temp 2"@"Soppalco" [node=11,slot=3]
}

Enter your gateway IP address; you can leave the other parameters at their default values.

default.items:

Group    Home                 "Tonino"        <house>

Group    FamilyRoom           "Soggiorno"     <parents_2_4>   (Home)
Group    Divano               "Divano"        (Home)
Group    Outside              "Esterno"   <garden>   (Home)
Group    TV                   "TV"   <television>   (Home)
Group    Elettricita
Group    Diagnostic
Group    TermostatoSoggiorno

Switch   tettoia                "Tettoia"                                   <light>     (Outside)   ["Lighting"]    {autoupdate="false", channel="souliss:t11:105:5-0:onOff"}
String   tettoia_aggiornamento  "Agg [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]" <keyring>   (Outside, Diagnostic)       {channel="souliss:t11:105:5-0:lastStatusStored"}

Switch   portoncino             "Portoncino"            <light>         (FamilyRoom)         ["Lighting"]   {autoupdate="false",channel="souliss:t14:105:1-6:pulse"}
Switch   cancello               "Cancello"              <light>         (FamilyRoom)         ["Lighting"]   {autoupdate="false",channel="souliss:t14:105:1-7:pulse"}

Number   FamilyRoom_Temperature   "Temperatura [%.1f °C]"                       <temperature>   (FamilyRoom)              {channel="souliss:t31:105:6-0:measured"}
Number   FamilyRoom_Humidity      "Umidità [%.1f %%]"                           <humidity>      (FamilyRoom)              {channel="souliss:t53:105:6-7:value"}
String   AggiornamentoNodo6       "Agg [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]"   <keyring>       (FamilyRoom, Diagnostic)  {channel="souliss:t31:105:6-0:lastStatusStored"}

Number   Consumo            "Consumo [%.1f W]"                                          <energy>  (FamilyRoom, Elettricita)              {channel="souliss:t57:105:1-4:value"}
Number   Fotovoltaico       "Fotovoltaico [%.1f W]"                                     <energy>  (FamilyRoom, Elettricita)              {channel="souliss:t57:105:4-0:value"}
String   AggiornamentoNodo1 "Agg.Consumi [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]"         <keyring> (FamilyRoom, Elettricita, Diagnostic)  {channel="souliss:t57:105:1-4:lastStatusStored"}
String   AggiornamentoNodo4 "Agg.Fotovoltaico [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]"    <keyring> (FamilyRoom, Elettricita, Diagnostic)  {channel="souliss:t57:105:4-0:lastStatusStored"}

Switch divano               "Divano"                                        <light> (FamilyRoom, Divano ) ["Switchable"]    {autoupdate="false", channel="souliss:t11:105:12-0:onOff"}
String divano_aggiornamento "Agg. [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]"    <keyring> (FamilyRoom, Divano, Diagnostic)      {channel="souliss:t11:105:12-0:lastStatusStored"}
String divano_healthy       "Salute"                                        <keyring> (FamilyRoom, Divano, Diagnostic)      {channel="souliss:t11:105:12-0:healthy"}

Number termostatosoggiorno_temperatura  "Temperatura [%.1f °C]" <temperature>   (TermostatoSoggiorno) {channel="souliss:t31:105:6-0:measured"}
Number termostatosoggiorno_umidita      "Umidità [%.1f %%]"     <temperature>   (TermostatoSoggiorno) {channel="souliss:t53:105:6-7:value" }

Number termostatosoggiorno_umidita "Umidità" <humidity>   (TermostatoSoggiorno)  {channel="souliss:t53:105:6-7:value" }

Number termostatosoggiorno_temperatura      "Temperatura"                   <temperature>   (TermostatoSoggiorno) {channel="souliss:t31:105:6-0:measured"}
Number termostatosoggiorno_setpoint         "Regola Set Point [%.1f °c]"    <heating>       (TermostatoSoggiorno) {autoupdate="false", channel="souliss:t31:105:6-0:setPoint"}
Switch termostatosoggiorno_setasmeasured    "Set temp. attuale"             <heating>       (TermostatoSoggiorno) {channel="souliss:t31:105:6-0:setAsMeasured"}
String termostatosoggiorno_modo             "Modo"                                          (TermostatoSoggiorno) {autoupdate="false", channel="souliss:t31:105:6-0:mode"}
Switch termostatosoggiorno_power            "Termostato"                    <powerIcon>     (TermostatoSoggiorno) {channel="souliss:t31:105:6-0:system"}
Switch termostatosoggiorno_fire             "Fire"                          <fire>          (TermostatoSoggiorno) {channel="souliss:t31:105:6-0:fire"}

Dimmer  TermostatoSoggiorno_displayBright   "Lumin.min. display"                                    (TermostatoSoggiorno)               {channel="souliss:t19:105:6-9:dimmerBrightness"}
String TermostatoSoggiorno_aggiornamento    "Agg.[%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]" <keyring>   (TermostatoSoggiorno, Diagnostic)   {channel="souliss:t31:105:6-0:lastStatusStored"}
Number TermostatoSoggiorno_healthy          "Salute"                                    <keyring>   (TermostatoSoggiorno, Diagnostic )  {channel="souliss:t31:105:6-0:healthy"}

default.sitemaps:

sitemap default label="Tonino" {
    Frame {
        Text label="Rientro casa" icon="light" {
           Switch item=portoncino mappings=[ON="Apri"]
           Switch item=cancello mappings=[ON="Apri"]
        }
    }

 Frame {
        Group item=Outside
    }

Text item=Consumo label="Consumo [%.1f W]"
Text item=Fotovoltaico label="Fotovoltaico [%.1f W]"

Frame {

        Group item=Elettricita label="Elettricità" icon="energy"
}

Frame {
       Group item=Divano icon="light"
}

Frame label="Temperature"{

            Text label="Temperatura e umidità" icon="temperature" {
            Default item=FamilyRoom_Temperature label="Temperatura"
            Default item=FamilyRoom_Humidity label="Umidità"
            Default item=AggiornamentoNodo6 icon="icon16x16"

}

Text label="Termostato soggiorno" icon="temperature" {
            Setpoint item=termostatosoggiorno_setpoint step=0.5 minValue=10 maxValue=30
            Default item=termostatosoggiorno_temperatura
            Default item=termostatosoggiorno_umidita
            Switch item=termostatosoggiorno_setasmeasured mappings=[ON="Set"]
            Switch item=termostatosoggiorno_modo label="Heating Mode" mappings=[HEATING_MODE="Set"]
            Switch item=termostatosoggiorno_power label="Power On/Off"
            Default item=termostatosoggiorno_fire label="Fire"
            Text item=TermostatoSoggiorno_aggiornamento label="Aggiornato: [%1$td.%1$tm.%1$tY %1$tk:%1$tM:%1$tS]" icon="icon16x16"
            Default item=TermostatoSoggiorno_healthy
            Slider item=TermostatoSoggiorno_displayBright
   }
 }
}

# Community

Souliss is a small community and does not have sufficient human resources to be very active on the official openHAB community.

Some popular forums:

# Contribution

Official repository for contributing to the Souliss project: Souliss GitHub organization (opens new window)

# Known issues

Secure send is currently enabled and tested only for T11...