NEWS
telegram
-
/*****Bewegung Doorbell **************************************************** * Mai 2025 * Adapter: * geä: *************************************************************************/ const idmotion = "reolink.1.sensor.motion" const camurl = 'http://192.168.188.122/cgi-bin/api.cgi?cmd=Snap&channel=0&rs=wuuPhkmUCeI9WG7C&user=admin&password=rxxxxxg04&width=800&height=600' on({ id: idmotion, change:"any" }, function (obj) { if (obj.state.val == true) { log("Motion Doorbell") httpGet(camurl, { responseType: 'arraybuffer' }, async (err, response) => { if (!err) { writeFile('vis.0', '/Doorbell/Doorbell.jpg', response.data, (err) => { if (err) { console.error(err); } }); } else { console.error(err); } }); } readFile('vis.0', '/Doorbell/Doorbell.jpg', function (err, img) { var ereignis_text = formatDate(new Date(obj.state.ts), "hh:mm:ss"); sendTo("telegram.0", { text: img, caption: "Doorbell Bewegung " + ereignis_text, type: "photo" }); delFileAsync('vis.0', '/Doorbell/Doorbell.jpg') }); });
Aktuell ist das jetzt die Fehlermeldung
elegram.0 2025-05-09 12:12:09.035 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:12:03.582 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:59.114 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:53.525 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:49.124 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:48.590 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:40.331 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:36.294 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:30.005 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:23.893 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:19.774 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:13.677 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:10.434 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:11:04.927 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:10:59.677 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:10:53.561 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:10:49.077 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:10:44.206 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty telegram.0 2025-05-09 12:10:42.514 error Failed sending [chatId - 6105180270]: Error: ETELEGRAM: 400 Bad Request: message text is empty
-
Da ist ein Zeitfehler drin.
Httpget
Und Readfile wird relativ zeitnah hintereinander ändernaufgerufen.
Es ist nicht gesichert, das die callbacks genau auch so in der Reihenfolge fertig sind.D.h. Das Bild das du mit HTTPget abrufst ist wahrscheinlich noch nicht vorhanden, wenn du den readfile/telegram Befehl aufrufst.
Daher auch die Meldung mit undefined oder message empty.Wenn du auf die Verwendung der callback Versionen der Funktionen verzichtest und mit await arbeitest, wird es viel logischer von der Abarbeitung her.
-
@michihorn Das geht so nicht, Du übergibst die Daten aus
readFile
direkt an Telegam. Also Binärdaten. Der Telegram-Adapter kann damit aber nicht umgehen und hätte gerne einen Pfad. Dafür habe ich die FunktioncreateTempFile
eingebaut.Und @OliverIO hat auch Recht - am besten mit einem weiteren Trigger auf geändert Bild-Dateien reagieren (oder sich den Umweg über das Datei-Management von ioBroker komplett sparen, wenn Du die Datei eh direkt wieder löschen willst).
Vorschlag 1)
const idmotion = 'reolink.1.sensor.motion'; const camurl = 'http://192.168.188.122/cgi-bin/api.cgi?cmd=Snap&channel=0&rs=wuuPhkmUCeI9WG7C&user=admin&password=rxxxxxg04&width=800&height=600'; on({ id: idmotion, change: 'any' }, (obj) => { if (obj.state.val == true) { log('Motion Doorbell'): httpGet(camurl, { responseType: 'arraybuffer' }, async (err, response) => { if (!err) { writeFile('vis.0', '/Doorbell/Doorbell.jpg', response.data, (err) => { if (err) { console.error(err); } }); } else { console.error(err); } }); } }); onFile('vis.0', '/Doorbell/*.jpg', true, async (id, fileName, size, data, mimeType) => { const ereignis_text = formatDate(new Date(), 'hh:mm:ss'); sendToAsync('telegram.0', { text: createTempFile(fileName, data), caption: `Doorbell Bewegung ${ereignis_text}`, type: 'photo' }); });
Vorschlag 2:
const idmotion = 'reolink.1.sensor.motion'; const camurl = 'http://192.168.188.122/cgi-bin/api.cgi?cmd=Snap&channel=0&rs=wuuPhkmUCeI9WG7C&user=admin&password=rxxxxxg04&width=800&height=600'; on({ id: idmotion, change: 'any' }, (obj) => { if (obj.state.val == true) { log('Motion Doorbell'): httpGet(camurl, { responseType: 'arraybuffer' }, async (err, response) => { if (!err) { const ereignis_text = formatDate(new Date(obj.state.ts), 'hh:mm:ss'); sendToAsync('telegram.0', { text: createTempFile(fileName, response.data), caption: `Doorbell Bewegung ${ereignis_text}`, type: 'photo' }); } else { console.error(err); } }); } });
-
Ein File handle sollte gemäß Doku auch gehen.
Vgl. Beispiel
https://github.com/iobroker-community-adapters/ioBroker.telegram/blob/master/docs/en/README.md#explicit-types-of-messagessendTo('telegram.0', 'send', { text: fs.readFileSync('/opt/path/picture.png'), type: 'photo' });
-
@oliverio Ja stimmt, zumindest machmal, aber jetzt weiß ich ja woran es gelegen hat. Danke
-
@haus-automatisierung Danke für die Überarbeitung des Scriptes, ich habe jetzt mal die Variante eingebaut. Danke
-
@haus-automatisierung sagte in telegram:
Dafür habe ich die Funktion createTempFile eingebaut.
Das Script moniert den fileName
text: createTempFile(fileName, response.data),javascript.0 15:04:31.098 error ReferenceError: fileName is not defined javascript.0 15:04:31.099 error at Object.<anonymous> (script.js.SYSTEM.Motion_Doorbell:26:40)
-
Ok, Du hast überhaupt keine Ahnung von JavaScript?
Filename ist eine variable in der der Dateiname zu deinem Bild steht.
Also entweder die Daten die aus dem httprequest kommen als Datei speichern oder besser doch wieder das file handle wie in deinem ursprünglichen Beispiel übergeben.Kann es leider nicht selbst nachstellen.
-
@oliverio Ich lerne jeden Tag dazu. Es ist noch kein Meister vom Himmel gefallen.
Die Variante2 von Hausautomatik habe ich so übernommen. Die Variable fileName war nicht in der Definition angegeben und es ist nicht klar wo wird die Variable "gefüllt", ergo moppert das Script. Leider gibt es auch keine Sendung per Telegram. Ich schaue mir das später nochmal an. Danke erstmal -
Trage da einfach mal anstatt dessen
createTempFile('telegram-image.png', response.data)
Ein.
-
-
@michihorn Ist die Doku der Funktion unvollständig?
-
@haus-automatisierung Aus meiner Sicht schon, ich werde mich am Montag mal in Ruhe damit beschäftigen.
Viele Grüße -
Das ist nur der temporäre Dateiname.
Gefüllt wird das durch diese Funktion.
Der Inhalt kommt von response.data