Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende ÜberarbeitungLetzte ÜberarbeitungBeide Seiten der Revision | ||
manuals:symcon:mqtt-integration [2017/08/04 17:43] – paulg4h | manuals:symcon:mqtt-integration [2018/09/22 18:52] – admin | ||
---|---|---|---|
Zeile 1: | Zeile 1: | ||
====== MQTT in Symcon Einbinden ====== | ====== MQTT in Symcon Einbinden ====== | ||
+ | |||
+ | <WRAP center round info 60%> | ||
+ | Stand September 2018, IPS 4.4 | ||
+ | </ | ||
+ | |||
Diese Anleitung zeigt wie man auf einem Raspberry PI 3 das MQTT Protokoll über Mosquitto und mqttwarn in Symcon schreibend und per Modul auch Beschreibbar ist. Also in beide Richtungen Ereigniss Basierend kommuniziert so wie ich es schon seit einem halben Jahr Produktiv mit diversen Arduinos und ESP8266 (PubSub Library) einsetze. | Diese Anleitung zeigt wie man auf einem Raspberry PI 3 das MQTT Protokoll über Mosquitto und mqttwarn in Symcon schreibend und per Modul auch Beschreibbar ist. Also in beide Richtungen Ereigniss Basierend kommuniziert so wie ich es schon seit einem halben Jahr Produktiv mit diversen Arduinos und ESP8266 (PubSub Library) einsetze. | ||
Zeile 7: | Zeile 12: | ||
**Auch müssen alle Werte in < | **Auch müssen alle Werte in < | ||
- | </ | ||
- | |||
- | <WRAP center round info 90%> | ||
- | Nachdem Symcon ja Debian auf x86 Hardware nicht Unterstütz (werd ich nie verstehen) sondern nur Ubuntu und da die jetzt schon sehr alte 14.04er habe ich soeben ein paar Ergänzungen in der Anleitung gemacht und die MQTT integration nun auch auf Ubuntu Installiert (Stand Jänner 2017) | ||
</ | </ | ||
Zeile 40: | Zeile 41: | ||
===== Pakete Installieren ===== | ===== Pakete Installieren ===== | ||
- | + | Einen MQTT Broker | |
- | ==== Mosquitto (MQTT Broker) ==== | + | aptitude install mosquitto |
- | aptitude install mosquitto | + | |
| | ||
- | ==== mqttwarn (mqtt daemon der alle Ereignisse zu Symcon | + | ===== Symcon |
- | [[https:// | + | |
- | Abhängige Pakete Installieren: | + | |
- | pip install paho-mqtt jinja2 | + | |
- | Verzeichniss erstellen | + | |
- | cd /opt/ | + | |
- | Herunterladen mit: | + | |
- | git clone https:// | + | |
- | cd mqttwarn | + | |
- | chmod +x mqttwarn.py | + | |
- | cp mqttwarn.ini.sample mqttwarn.ini | + | |
- | Derinhalt der mqttwarn.ini sollte so aussehen: | + | |
- | < | + | |
- | # mqttwarn example configuration file " | + | |
- | [defaults] | + | ==== MQTT Client zum Senden in Symcon Installieren ==== |
- | hostname | + | Zum Senden von Daten per MQTT_Publish aus jedem script: |
- | port = 1883 | + | https:// |
- | username | + | |
- | password | + | |
- | clientid | + | |
- | lwt | + | |
- | skipretained | + | |
- | cleansession = True | + | |
- | protocol | ||
- | ; logging | + | ==== Mosquitto an Symcon Anbinden ==== |
- | logformat | + | |
- | logfile | + | |
- | ; one of: CRITICAL, DEBUG, ERROR, INFO, WARN | + | Eine Kategorie anlegen |
- | loglevel | + | |
- | # | + | |
+ | In diesem Knoten werden dann alle Geräte und Datenpunkte Automatisch erstellt / Aktualisiert, | ||
+ | Datenpunkte/ | ||
+ | und erstellen das Script " | ||
- | ; path to file containing self-defined functions for formatmap and datamap | + | Die Datei: |
- | ; omit the ' | + | |
- | functions = ' | + | |
- | ; name the service providers you will be using. | + | mit folgendem Inhalt: |
- | launch | + | <code php><? |
+ | $d = false; $msg = ""; | ||
+ | $value = ""; | ||
+ | if ($d){ $msg .= " | ||
+ | //if (($_IPS[' | ||
+ | if ($_IPS[' | ||
+ | $value | ||
+ | if ($value == $_IPS[' | ||
+ | $msg .= " | ||
+ | $run = false; | ||
+ | } | ||
+ | } | ||
+ | if (($_IPS[' | ||
+ | | ||
+ | } | ||
+ | if ($d){ $msg .= " | ||
+ | $id = $_IPS[' | ||
+ | $topic = explode(";" | ||
+ | if((strlen($topic) > 3) and ($run)){ | ||
+ | switch(IPS_GetVariable($id)[' | ||
+ | case 0: //boolean | ||
+ | if($value == 1){ $value = " | ||
+ | break; | ||
+ | case 1: //Integer | ||
- | [config: | + | |
- | append_newline = True | + | case 2: //float |
- | targets = { | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | [config: | + | |
- | targets = { | + | case 3: //string |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | [config: | + | |
- | timeout = 60 | + | } |
- | targets = { | + | |
- | # | + | |
- | ' | + | } |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | ; special config for ' | + | if ($d){ $msg .= " |
- | [failover] | + | |
- | targets = log:error, file: | + | if(strlen($msg) > 0){ |
+ | | ||
+ | } | ||
- | [devices/# | + | ?> |
- | targets = http: | + | |
- | template = ipsrpc.json | + | |
</ | </ | ||
- | <WRAP center round info 100%> | ||
- | der letzte Abschnitt [devices/#] bedeutet das alle daten im MQTT Broker (mosquitto) unter devices/* an IPS übergeben werden! | ||
- | </ | ||
+ | Das Eigentliche Script welces die Daten per RPC vom mqttwarn Daemon entgegennimmt und ablegt, in dem nicht Vergessen die ID's in den ersten Zeilen durch die Eigenen ersetzen: | ||
- | dann noch das template | + | <code php> <? |
- | cd / | + | $d = true; $msg = ""; |
- | in form der Datei | + | |
- | vi ipsrpc.json | + | |
- | mit folgendem Inhalt erstellen: | + | |
- | < | + | |
- | set data = { | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | %} | + | |
- | {{ data | jsonify }}</ | + | |
- | + | ||
- | === Supervisor === | + | |
- | Damit mqttwarn als Dienst ausgeführt wird verwende ich supervisor wie [[http:// | + | |
- | aptitude install supervisor | + | |
- | in dem Ornder | + | |
- | cd / | + | |
- | die Datei mqttwarn.conf anlegen | + | |
- | vi mqttwarn.conf | + | |
- | mit folgendem Inhalt | + | |
- | < | + | |
- | directory = / | + | |
- | command = / | + | |
- | user = root | + | |
- | environment= MQTTWARNINI="/ | + | |
- | + | ||
- | Nun kann mqttwarn gestartet werden mit: | + | |
- | service supervisor start | + | |
- | und z.B. in einem zweiten Terminal Fenster die Log Datei beobachtet werden: | + | |
- | tail -f / | + | |
- | was so aussehen sollte: | + | |
- | < | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | + | ||
- | ===== Symcon ===== | + | |
- | Nach der Installation von IPS dort in einer Kategorie z.b. Datenpunlte/ | + | |
- | <code php><? | + | |
- | $d = false; $msg = ""; | + | |
//sample value: devices/ | //sample value: devices/ | ||
// mqtt topic to symcon variable id mapping | // mqtt topic to symcon variable id mapping | ||
$idParent = IPS_GetParent($_IPS[' | $idParent = IPS_GetParent($_IPS[' | ||
- | $archiveId = <archiv id> | + | $archiveId = 32289 / |
- | $relaisScriptId = <id des Relais scripts> | + | $relaisScriptId = 17676 / |
// get value from mqtt variable | // get value from mqtt variable | ||
- | $var = $_IPS[' | + | if( array_key_exists(" |
- | $varsplit | + | |
+ | $topic = $_IPS[' | ||
+ | $topics | ||
+ | $payload = $_IPS[' | ||
- | if(count($varsplit)> | ||
- | $topics = explode("/", | ||
- | $topic=$varsplit[0]; | ||
- | $payload=$varsplit[1]; | ||
$payload = str_replace(array(" | $payload = str_replace(array(" | ||
Zeile 214: | Zeile 155: | ||
for($i = 0; $i < count($topics); | for($i = 0; $i < count($topics); | ||
if ($i == (count($topics) -1)){ | if ($i == (count($topics) -1)){ | ||
- | $type = 2; | + | $type = 2; |
} else { | } else { | ||
$type = 0; | $type = 0; | ||
Zeile 226: | Zeile 167: | ||
} | } | ||
- | // | ||
IPS_SetIdent($idf, | IPS_SetIdent($idf, | ||
- | //Wert Setzen | ||
mqset($idf, | mqset($idf, | ||
- | |||
} | } | ||
- | if (strlen($msg) > 0){ | + | if ((strlen($msg) > 0) and ($d)){ |
| | ||
print $msg; | print $msg; | ||
- | } else { | + | } |
- | IPS_LogMessage(" | + | IPS_LogMessage(" |
- | } | + | |
} | } | ||
Zeile 248: | Zeile 185: | ||
function mqset($id, $value){ | function mqset($id, $value){ | ||
- | switch(IPS_GetVariable($id)[" | + | if(GetValue($id) != $value){ |
- | case 0: // boolean | + | switch(IPS_GetVariable($id)[" |
- | $val = filter_var($value, | + | case 0: // boolean |
- | SetValue($id, | + | $val = filter_var($value, |
- | break; | + | SetValue($id, |
- | case 1: // integer | + | break; |
- | $val = intval($value); | + | case 1: // integer |
- | SetValue($id, | + | $val = intval($value); |
- | break; | + | SetValue($id, |
- | case 2: // float | + | break; |
- | $val = floatval($value); | + | case 2: // float |
- | SetValue($id, | + | $val = floatval($value); |
- | break; | + | SetValue($id, |
- | case 3: // string | + | break; |
- | SetValue($id, | + | case 3: // string |
- | break; | + | SetValue($id, |
+ | break; | ||
+ | } | ||
} | } | ||
} | } | ||
Zeile 356: | Zeile 295: | ||
} | } | ||
?></ | ?></ | ||
+ | ==== Mosquitto (MQTT Broker) ==== | ||
+ | aptitude install mosquitto mosquitto-clients python-pip git -y | ||
+ | | ||
+ | ==== mqttwarn (mqtt daemon der alle Ereignisse zu Symcon weiterleitet) ==== | ||
+ | [[https:// | ||
+ | Abhängige Pakete Installieren: | ||
+ | pip install paho-mqtt jinja2 | ||
+ | Verzeichniss erstellen | ||
+ | cd /opt/ | ||
+ | Herunterladen mit: | ||
+ | git clone https:// | ||
+ | cd mqttwarn | ||
+ | chmod +x mqttwarn.py | ||
+ | cp mqttwarn.ini.sample mqttwarn.ini | ||
+ | Derinhalt der mqttwarn.ini sollte so aussehen: | ||
+ | < | ||
+ | # mqttwarn example configuration file " | ||
- | hier noch das switch Script damit sind " | + | [defaults] |
+ | hostname | ||
+ | port = 1883 | ||
+ | username | ||
+ | password | ||
+ | clientid | ||
+ | lwt = ' | ||
+ | skipretained = False | ||
+ | cleansession = True | ||
- | <code php><? | + | protocol |
- | $d = false; $msg = ""; | + | |
- | $value = ""; | + | |
- | if ($d){ $msg .= " | + | |
- | //if (($_IPS[' | + | |
- | if ($_IPS[' | + | |
- | | + | |
- | if ($value == $_IPS[' | + | |
- | $msg .= " | + | |
- | $run = false; | + | |
- | } | + | |
- | } | + | |
- | if (($_IPS[' | + | |
- | | + | |
- | } | + | |
- | if ($d){ $msg .= " | + | |
- | $id = $_IPS[' | + | |
- | $topic = explode(";", | + | |
- | if((strlen($topic) > 3) and ($run)){ | + | |
- | switch(IPS_GetVariable($id)[' | + | |
- | case 0: //boolean | + | |
- | if($value == 1){ $value = " | + | |
- | break; | + | |
- | case 1: //Integer | + | |
- | break; | + | ; logging |
- | case 2: //float | + | logformat = ' |
+ | logfile | ||
- | break; | + | ; one of: CRITICAL, DEBUG, ERROR, INFO, WARN |
- | case 3: //string | + | loglevel |
+ | # | ||
- | break; | + | ; path to file containing self-defined functions for formatmap and datamap |
- | } | + | ; omit the ' |
- | | + | functions |
- | MQTT_Publish(50729 / | + | |
- | } | + | |
- | if ($d){ $msg .= " | + | ; name the service providers you will be using. |
- | + | launch | |
- | if(strlen($msg) > 0){ | + | |
- | IPS_LogMessage("mqtt_switch_relais", | + | [config: |
- | } | + | append_newline = True |
+ | targets = { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | |||
+ | [config: | ||
+ | targets | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | |||
+ | [config: | ||
+ | timeout = 60 | ||
+ | targets = { | ||
+ | # | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | | ||
+ | |||
+ | ; special config for ' | ||
+ | [failover] | ||
+ | targets = log:error, file: | ||
+ | |||
+ | [devices/# | ||
+ | targets = log:info, http: | ||
+ | template = ipsrpc.json | ||
+ | </ | ||
+ | |||
+ | <WRAP center round info 100%> | ||
+ | der letzte Abschnitt [devices/#] bedeutet das alle daten im MQTT Broker | ||
+ | </ | ||
+ | |||
+ | |||
+ | dann noch das template | ||
+ | cd / | ||
+ | in form der Datei | ||
+ | vi ipsrpc.json | ||
+ | mit folgendem Inhalt erstellen: | ||
+ | <code>{% set data = { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | %} | ||
+ | {{ data | jsonify }}</ | ||
+ | |||
+ | === Supervisor === | ||
+ | Damit mqttwarn als Dienst ausgeführt wird verwende ich supervisor wie [[http:// | ||
+ | aptitude install supervisor | ||
+ | in dem Ornder | ||
+ | cd / | ||
+ | die Datei mqttwarn.conf anlegen | ||
+ | vi mqttwarn.conf | ||
+ | mit folgendem Inhalt | ||
+ | < | ||
+ | directory = / | ||
+ | command = / | ||
+ | user = root | ||
+ | environment= MQTTWARNINI="/ | ||
+ | |||
+ | Nun kann mqttwarn gestartet werden mit: | ||
+ | service supervisor start | ||
+ | und z.B. in einem zweiten Terminal Fenster die Log Datei beobachtet werden: | ||
+ | tail -f / | ||
+ | was so aussehen sollte: | ||
+ | < | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
- | ?></ | ||