Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Anbindung 3cx TK-Anlage

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    1.6k

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    671

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    1.2k

Anbindung 3cx TK-Anlage

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
3cx abfrage tk-anlage
1 Beiträge 1 Kommentatoren 374 Aufrufe 2 Beobachtet
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • J Offline
    J Offline
    Josh
    schrieb am zuletzt editiert von Josh
    #1

    Hallo zusammen!

    Ich habe es geschafft meine 3cx-TK-Anlage mit einem BlocklyScript in ioBroker anzubinden. Das möchte ich kurz beschreiben.

    Hier mein BlocklyScript:

    3cx-version-auslesen.png

    Als erstes legen wir einen neuen Datenpunkt an. In meinem Beispiel fragen wir einfach mal die Version der Anlage ab.

    Danach muss als erstes ein Login-Cookie angelegt werden, indem wir folgenden curl-Befehl absetzen:

    curl 'https://myhost.my3cx.de:5001/api/login'
    -H 'authority: myhost.my3cx.de:5001'
    -H 'accept: application/json, text/plain, /'
    -H 'user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Safari/537.36 Edg/88.0.705.63'
    -H 'content-type: application/json;charset=UTF-8'
    -H 'origin: https://myhost.my3cx.de:5001'
    -H 'sec-fetch-site: same-origin'
    -H 'sec-fetch-mode: cors'
    -H 'sec-fetch-dest: empty'
    -H 'referer: https://myhost.my3cx.de:5001/'
    -H 'accept-language: de'
    -b /tmp/curl-cookies.txt
    -c /tmp/curl-cookies.txt
    --data-raw '{"Username":"admin","Password":"xxx"}'
    --compressed
    

    Ihr müsst natürlich eure URL der Anlage, den Anmeldenamen und das Passwort anpassen. Zur besseren Lesbarkeit, habe ich den Befehl über mehrere Zeilen aufgeteilt. In Blockly muss das alles in einer Zeile stehen.

    Schön, jetzt ist der Login in die Anlage erfolgreich verlaufen. Als nächstes warten wir kurz, bis die Cookie-Datei ins Dateisystem geschrieben wurde. Habe 100ms empirisch ermittelt. Vielleicht kennt jmd ja eine Methode, die besser ist als die Zeit abzuwarten.

    Nun kommt der zweite curl-Befehl mit dem wir den Datenpunkt abfragen:

    curl 'https://myhost.my3cx.de:5001/api/SystemStatus'
    -H 'authority: myhost.my3cx.de:5001'
    -H 'accept: application/json, text/plain, /'
    -H 'user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Safari/537.36 Edg/88.0.705.63'
    -H 'content-type: application/json;charset=UTF-8'
    -H 'origin: https://myhost.my3cx.de:5001'
    -H 'sec-fetch-site: same-origin'
    -H 'sec-fetch-mode: cors'
    -H 'sec-fetch-dest: empty'
    -H 'referer: https://myhost.my3cx.de:5001/'
    -H 'accept-language: de'
    -b /tmp/curl-cookies.txt
    -c /tmp/curl-cookies.txt
    --compressed
    

    Auch hier ist wegen der besseren Lesbarkeit der Befehl auf mehrere Zeilen aufgeteilt.

    Es kommt ein JSON-Payload zurück, den wir nur zerlegen müssen, um die Version auszulesen. Die Versionsnummer wird in den oben angelegten Datenpunkt geschrieben. Dieser Datenpunkt kann dann für weitere Auswertungen genutzt werden.

    Jetzt warten wir nochmal 100ms, bis wir das Cookie löschen.

    Fertig.

    Natürlich ist die Abfrage der Versionsnummer nur ein Beispiel. Nehmt dann einfach den Datenpunkt, den ihr abfragen möchtet. Im Prinzip funktioniert das alles wie oben beschrieben.

    Zum Schluss noch die mir bekannten API-Abfragen:

    https://myhost.my3cx.de:5001/api/SystemStatus
    https://myhost.my3cx.de:5001/api/ActiveCalls
    https://myhost.my3cx.de:5001/api/ServiceList
    https://myhost.my3cx.de:5001/api/ExtensionList
    https://myhost.my3cx.de:5001/api/TrunkList
    https://myhost.my3cx.de:5001/api/InboundRulesList
    https://myhost.my3cx.de:5001/api/OutboundRuleList
    https://myhost.my3cx.de:5001/api/IVRList
    https://myhost.my3cx.de:5001/api/RingGroupList
    https://myhost.my3cx.de:5001/api/CallLog?callState=All&dateRangeType=Yesterday
    https://myhost.my3cx.de:5001/api/PhoneBookEntryList?count=50&filter=&from=0
    

    Um die Datenpunkte im Browser anzusehen, einfach sich auf der Anlage anmelden und dann die o.g. URLs aufrufen. Natürlich wieder an eure Anlage anpassen. Zur bessere Lesbarkeit im Firefox habe ich das Add-On JSON Lite genutzt.

    Ich möchte euch hiermit anregen weiteren Input zu geben, sodass sich ggf. ein Entwickler berufen fühlt einen Adapter zu programmieren ;-)

    Anbei das Script.

    3cx-version-auslesen.txt

    Intel NUC10i5-32GB-1TB_SSD - Proxmox 9.1 - LXC Debian 13 (Trixi)
    RPi3B - ZigBee2MQTT - CC2652P
    RPi3B - ZigBee2MQTT - CC2538+CC2592
    node.js 22.24.0 / NPM 10.9.4 / js-controller 7.0.7

    1 Antwort Letzte Antwort
    0

    Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

    Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

    Mit deinem Input könnte dieser Beitrag noch besser werden 💗

    Registrieren Anmelden
    Antworten
    • In einem neuen Thema antworten
    Anmelden zum Antworten
    • Älteste zuerst
    • Neuste zuerst
    • Meiste Stimmen


    Support us

    ioBroker
    Community Adapters
    Donate
    FAQ Cloud / IOT
    HowTo: Node.js-Update
    HowTo: Backup/Restore
    Downloads
    BLOG

    556

    Online

    32.9k

    Benutzer

    83.0k

    Themen

    1.3m

    Beiträge
    Community
    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
    ioBroker Community 2014-2025
    logo
    • Anmelden

    • Du hast noch kein Konto? Registrieren

    • Anmelden oder registrieren, um zu suchen
    • Erster Beitrag
      Letzter Beitrag
    0
    • Home
    • Aktuell
    • Tags
    • Ungelesen 0
    • Kategorien
    • Unreplied
    • Beliebt
    • GitHub
    • Docu
    • Hilfe