Das Script läuft so ähnlich bei mir zu Hause. Vor einiger Zeit habe ich, nach Rückfrage hier aus dem Forum, getestet, ob es auch ohne WLAN Verbindung zum Router klappt. Ging bei mir einwandfrei.
Der AP des Shelly kann ja ruhig angeschaltet bleiben, bei Bedarf kannst du den Zugang mit einem Passwort schützen.
Hast du die richtige Adresse des BLU Button eingestellt? Wurde das Script gestartet und läuft es auch?
Beiträge von horkatz
-
-
So sollte es aussehen:
Code
Alles anzeigen/** * This script lets you use your Gen2 device as a gateway between Shelly BLU button1 and other Shelly devices (no matter Gen1 or Gen2) * by sending local requests by their local IP APIs. * * What you should change before using it: * > bluButtonAddress -> You should put the mac address of your blu button here. * This script will help you find the mac address: https://github.com/ALLTERCO/shelly-script-examples/blob/main/ble-shelly-scanner.js * * > actions -> You should put the urls here to be executed at the specified event. Urls that shoudl be called on single/short push * of the button, must be placed in the singlePush object. This applies to the double and triple push as well. Example below. * * Limitations: * > At the moment there is a limit of 5 RPC calls at the same time and because of this, the script will execute every 3 urls with a 1 second delay. * Limitations can be check here: https://shelly-api-docs.shelly.cloud/gen2/Scripts/ShellyScriptLanguageFeatures#resource-limits * * > The order of the execution of the urls can't be guaranteed */ /** =============================== CHANGE HERE =============================== */ let CONFIG = { bluButtonAddress: "5c:c7:c1:f2:77:ab", //the mac address of shelly blu button1 that will trigger the actions actions: { //urls to be called on a event //when adding urls you must separate them with commas and put them in quotation marks singlePush: [ //urls that will be executed at singlePush event from the blu button1 "http://127.0.0.1/relay/0?turn=on" ], doublePush: [ //urls that will be executed at doublePush event from the blu button1 ], triplePush: [ //urls that will be executed at triplePush event from the blu button1 ], longPush: [ //urls that will be executed at longPush event from the blu button1 ] } }; /** =============================== STOP CHANGING HERE =============================== */ let urlsPerCall = 3; let urlsQueue = []; let callsCounter = 0; let ALLTERCO_MFD_ID_STR = "0ba9"; let BTHOME_SVC_ID_STR = "fcd2"; let uint8 = 0; let int8 = 1; let uint16 = 2; let int16 = 3; let uint24 = 4; let int24 = 5; let BTH = {}; BTH[0x00] = { n: "pid", t: uint8 }; BTH[0x01] = { n: "Battery", t: uint8, u: "%" }; BTH[0x05] = { n: "Illuminance", t: uint24, f: 0.01 }; BTH[0x1a] = { n: "Door", t: uint8 }; BTH[0x20] = { n: "Moisture", t: uint8 }; BTH[0x2d] = { n: "Window", t: uint8 }; BTH[0x3a] = { n: "Button", t: uint8 }; function getByteSize(type) { if (type === uint8 || type === int8) return 1; if (type === uint16 || type === int16) return 2; if (type === uint24 || type === int24) return 3; //impossible as advertisements are much smaller; return 255; } let BTHomeDecoder = { utoi: function (num, bitsz) { let mask = 1 << (bitsz - 1); return num & mask ? num - (1 << bitsz) : num; }, getUInt8: function (buffer) { return buffer.at(0); }, getInt8: function (buffer) { return this.utoi(this.getUInt8(buffer), 8); }, getUInt16LE: function (buffer) { return 0xffff & ((buffer.at(1) << 8) | buffer.at(0)); }, getInt16LE: function (buffer) { return this.utoi(this.getUInt16LE(buffer), 16); }, getUInt24LE: function (buffer) { return ( 0x00ffffff & ((buffer.at(2) << 16) | (buffer.at(1) << 8) | buffer.at(0)) ); }, getInt24LE: function (buffer) { return this.utoi(this.getUInt24LE(buffer), 24); }, getBufValue: function (type, buffer) { if (buffer.length < getByteSize(type)) return null; let res = null; if (type === uint8) res = this.getUInt8(buffer); if (type === int8) res = this.getInt8(buffer); if (type === uint16) res = this.getUInt16LE(buffer); if (type === int16) res = this.getInt16LE(buffer); if (type === uint24) res = this.getUInt24LE(buffer); if (type === int24) res = this.getInt24LE(buffer); return res; }, unpack: function (buffer) { //beacons might not provide BTH service data if (typeof buffer !== "string" || buffer.length === 0) return null; let result = {}; let _dib = buffer.at(0); result["encryption"] = _dib & 0x1 ? true : false; result["BTHome_version"] = _dib >> 5; if (result["BTHome_version"] !== 2) return null; //can not handle encrypted data if (result["encryption"]) return result; buffer = buffer.slice(1); let _bth; let _value; while (buffer.length > 0) { _bth = BTH[buffer.at(0)]; if (typeof _bth === "undefined") { console.log("BTH: unknown type"); break; } buffer = buffer.slice(1); _value = this.getBufValue(_bth.t, buffer); if (_value === null) break; if (typeof _bth.f !== "undefined") _value = _value * _bth.f; result[_bth.n] = _value; buffer = buffer.slice(getByteSize(_bth.t)); } return result; }, }; function callQueue() { if(callsCounter < 6 - urlsPerCall) { for(let i = 0; i < urlsPerCall && i < urlsQueue.length; i++) { let url = urlsQueue.splice(0, 1)[0]; callsCounter++; Shelly.call("HTTP.GET", { url: url, timeout: 5 }, function(_, error_code, _, data) { if(error_code !== 0) { console.log("Calling", data.url, "failed"); } else { console.log("Calling", data.url, "successed"); } callsCounter--; }, { url: url } ); } } //if there are more urls in the queue if(urlsQueue.length > 0) { Timer.set( 1000, //the delay false, function() { callQueue(); } ); } } let lastPacketId = 0x100; function bleScanCallback(event, result) { //exit if the call is not for a received result if (event !== BLE.Scanner.SCAN_RESULT) { return; } //exit if the data is not coming from a Shelly Blu button1 and if the mac address doesn't match if ( typeof result.local_name === "undefined" || typeof result.addr === "undefined" || result.local_name.indexOf("SBBT") !== 0 || result.addr !== CONFIG.bluButtonAddress ) { return; } let servData = result.service_data; //exit if service data is null/device is encrypted if(servData === null || typeof servData === "undefined" || typeof servData[BTHOME_SVC_ID_STR] === "undefined") { console.log("Can't handle encrypted devices"); return; } let receivedData = BTHomeDecoder.unpack(servData[BTHOME_SVC_ID_STR]); //exit if unpacked data is null or the device is encrypted if(receivedData === null || typeof receivedData === "undefined" || receivedData["encryption"]) { console.log("Can't handle encrypted devices"); return; } //exit if the event is duplicated if (lastPacketId === receivedData.pid) { return; } lastPacketId = receivedData["pid"]; //getting and execuing the action let actionType = ["", "singlePush", "doublePush", "triplePush", "longPush"][receivedData["Button"]]; let actionUrls = CONFIG.actions[actionType]; //exit if the event doesn't exist in the config if(typeof actionType === "undefined") { console.log("Unknown event type in the config"); return; } //save all urls into the queue for the current event for(let i in actionUrls) { urlsQueue.push(actionUrls[i]); } callQueue(); } function bleScan() { //check whether the bluethooth is enabled let bleConfig = Shelly.getComponentConfig("ble"); //exit if the bluetooth is not enabled if(bleConfig.enable === false) { console.log("BLE is not enabled"); return; } //start the scanner let bleScanner = BLE.Scanner.Start({ duration_ms: BLE.Scanner.INFINITE_SCAN, active: true }); //exist if the scanner can not be started if(bleScanner === false) { console.log("Error when starting the BLE scanner"); return; } BLE.Scanner.Subscribe(bleScanCallback); console.log("BLE is successfully started"); } function init() { //exit if there isn't a config if(typeof CONFIG === "undefined") { console.log("Can't read the config"); return; } //exit if there isn't a blu button address if(typeof CONFIG.bluButtonAddress !== "string") { console.log("Error with the Shelly BLU button1's address"); return; } //exit if there isn't action object if(typeof CONFIG.actions === "undefined") { console.log("Can't find the actions object in the config"); return; } //start the ble scan bleScan(); } //init the script init();
Viele Grüße
Horst -
Welches Script meinst du? Das von mir verlinkte ist doch einfach zu handhaben, Mac Adresse des Blu Button eintragen, ersten Befehl abändern, die anderen Befehle löschen, (fast) fertig. Im Plus 1 noch den Auto Timer off einrichten (1 Sekunde), fertig.
-
Hallo Winter52,
das passende Script gibt es schon, zu finden untershelly-script-examples/ble-shelly-btn-gateway-for-other-devices.js at main · ALLTERCO/shelly-script-examplesExamples for Shelly Scripts for Gen2 Shelly devices - shelly-script-examples/ble-shelly-btn-gateway-for-other-devices.js at main ·…github.comDu musst nur die Zeile für den Single push anpassen: "http://127.0.0.1/relay/0?turn=on" (da es sich ja um den lokalen Shelly handelt).
Im Shelly einen AutoTimer off einstellen, fertig. -
-
ich komme im eingebauten Zustand nur an eine Einstellschraube.
Motor aushängen und so einhängen, dass beide Endlagenschalter eingestellt werden können. Erst wenn die Endlagen sauber eingestellt sind kommt der Shelly zum Zug
-
-
Vermutlich reicht es mit der höheren Wattzahl. Evtl. musst du die Leistungen etwas beobachten, während der Trockner läuft. Beim Knitterschutz sollte die Leistung deutlich unterhalb der in Zeile 28 eingegebenen Leistung bleiben,
Ansonsten kann man noch mit den Intervallen und der Zeitbasis experimentieren (Zeilen 24 und 42).Viele Grüße
Horst -
Die angegebene Spannungsfestigkeit ist nicht ausschlaggebend, es darf gerne etwas mehr sein. Problem ist oft der knappe Platz. Wenn die neuen Elkos höhere Temperaturen vertragen, dann ist das auch von Vorteil...
-
-
Hört sich sehr vielversprechend an . Der neue Shelly Dimmer 0/1-10V Gen3 kann genau das, was ich mir seinerzeit beim ersten 0-10V Dimmer erhofft hatte.
-
Hallo Rappteller,
warum eine 2. Phase? Kann nicht alles von der gleichen Phase versorgt werden? Was willst du schalten?
Wenn du etwas genauer erklärst, was du vorhast, dann kann dir bestimmt geholfen werden- -
-
-
Müsste sich mit Optokopplern relativ leicht anpassen lassen.
-
Und das gut 3 Jahre nach der letzten Antwort...
-
Die Brandgefahr sehe ich da eher beim Relaiskontakt des Shelly. Auch wenn er bei dir selten unter Last schaltet, der ganze Strom fließt trotzdem darüber. Irgendwann wird der Kontakt nachlassen und schmoren. Aber mach du einfach dein Ding, meine Waschmaschine und mein Trockner bleiben am Strom. Jeder so, wie er mag. Mehr gibt es dazu von meiner Seite nicht mehr zu sagen...
-
Wozu soll ich der Waschmaschine nach dem Waschen den Strom abdrehen? Damit ich die Tür nicht aufbekomme und erst wieder mit dem Smartphone einschalten muss? Die Wärmepumpe des Trockners darf auch gerne nach dem Trocknen kontrolliert herunterfahren, häufiges hartes Abschalten kann dem Kompressor schaden. Es gibt keinen triftigen Grund, diese Geräte überhaupt vom Strom zu trennen, der Standby Verbrauch ist bei mir faktisch nicht messbar.
-
-