Opennet Homematic: Unterschied zwischen den Versionen

Aus Opennet
Wechseln zu: Navigation, Suche
Zeile 44: Zeile 44:
 
     "id": 1,
 
     "id": 1,
 
     "result": "abcd123xyz",
 
     "result": "abcd123xyz",
 +
    "version": "1.1"
 +
}
 +
* Logout
 +
! Request
 +
{
 +
  "method": "Session.logout",
 +
  "id": 4,
 +
  "params": {
 +
    "_session_id_": "abcd123xyz"
 +
  }
 +
}
 +
! Response
 +
HTTP/1.1 200 OK
 +
...
 +
{
 +
    "error": null,
 +
    "id": 4,
 +
    "result": true,
 
     "version": "1.1"
 
     "version": "1.1"
 
  }
 
  }

Version vom 15. März 2019, 16:33 Uhr

JSON-RPC API: /api/homematic.cgi (via POST)

Verwendung zur Steuerung der Tür in der Frieda23.

Vorbereitung:

  • Benutzer anlegen (hier: opennet)
  • Programme anlegen (hier: door_open, door_close)

Ablauf:

  1. Session.login (username password) - Anmeldung vornehmen, Session-ID erhalten
  2. Program.getAll (_session_id_) - Liste der Programme ausgeben; Liste durchsuchen nach den relevanten Programmen durchsuchen und jeweilige aktuelle Programm-ID erhalten
  3. Program.execute (_session_id_ id) - gewünschtes Programm id ausführen
  4. Session.logout (_session_id_) - Abmeldung vornehmen, auch bei vorzeitigem Programmabbruch

Webinterface:

  • Login, denkbar via Opennet CA Client Login oder Nutzername/Passwort auf jeweils Basis Apache
  • Tür Öffnen, Ausführung nur mit Login
  • Tür Schließen, auch ohne Login erlauben? (Aka, "der letzte der geht macht die Tür zu"?)

Sonstiges:

  • Welche Softwareumgebung soll zum Einsatz kommen? Typisch wäre Bash, PHP, Python und HTML? (SN nutzt PHP-GuzzleHttpClient als Backend und Postman)
  • Verschlusszustand der Tür prüfen und/oder nachts automatisch schließen? (Kann jeder Zeit von innen mechanisch geöffnet werden)
  • Hosting in der Frieda23 um lokalen Zugriff sicher zu stellen?

JSON Beispiele:

  • Login:
! Request
{
 "method": "Session.login",
 "id": 1,
 "params": {
   "username": "opennet",
   "password": "XXX"
 }
}
! Response
HTTP/1.1 200 OK
CONTENT-TYPE: application/json; charset=utf-8
Content-Length: 63
Date: ...
Server: lighttpd/1.4.50
{
   "error": null,
   "id": 1,
   "result": "abcd123xyz",
   "version": "1.1"
}
  • Logout
! Request
{
 "method": "Session.logout",
 "id": 4,
 "params": {
   "_session_id_": "abcd123xyz"
 }
}
! Response
HTTP/1.1 200 OK
...
{
   "error": null,
   "id": 4,
   "result": true,
   "version": "1.1"
}
Meine Werkzeuge
Namensräume

Varianten
Aktionen
Start
Opennet
Kommunikation
Karten
Werkzeuge