In der App wäre der Zustand ja sofort zu sehen
Stimmt leider nicht so ganz, wenn kein Beacon Mode aktiviert ist, zeigt es nur den letzten übermittelten Status, der kann aber ewig her sein...
VPN/Proxy erkannt
Es scheint, dass Sie einen VPN- oder Proxy-Dienst verwenden. Bitte beachten Sie, dass die Nutzung eines solchen Dienstes die Funktionalität dieser Webseite einschränken kann.
In der App wäre der Zustand ja sofort zu sehen
Stimmt leider nicht so ganz, wenn kein Beacon Mode aktiviert ist, zeigt es nur den letzten übermittelten Status, der kann aber ewig her sein...
Haben die Shellys möglicherweise noch eine 6stellige ID?
Was hier noch nicht erwähnt wurde, du nutzt einen Shelly 1, den du mit 230VAC versorgst und schaltest damit Schutzkleinspannung. Diese Art Mischbetrieb ist beim alten Shelly 1 nicht erlaubt, es sollte dann der Plus 1 sein.
Wie du das Schalten der Lampen mit einem weiteren Shelly lösen willst, ist mir auch nicht klar, am grundsätzlichen Problem ändert der 2. Shelly ja nichts...
Er hat den AP Modus nicht aktiviert, sein Shelly ist in sein Netzwerk eingebunden.
Das Handy verbindet sich unterschiedlich schnell, manchmal dauert es 15-20 Sekunden.
Wenn der Shelly und dein normales WLAN in Reichweite sind, kann ich mir gut vorstellen, dass das Handy sich mit dem normalen WLAN verbindet.
Auf welcher Frequenz arbeitet dein Tor? Hast du schon mal überprüft, ob es Sender auf der gleichen Frequenz gibt, die deinen Empfänger "zumüllen"?
Alternativ kannst du auch einen zusätzlichen Empfänger mit passendem Sender an dein Tor anschließen, die sind recht günstig.
Der TE sucht ja etwas, wo er ohne WLAN mit dem BluButton den Shelly steuern kann, das funktioniert mit dem Original Script gut, die Frage gab es im Forum schon mal, damals habe ich es ausprobiert ![]()
Ja, stimmt, da gibt es natürlich viele Möglichkeiten. Bei diesem Script handelt es sich um das Script, welches von Allterco kurz nach Erscheinen des BluButton veröffentlicht wurde. Da es funktioniert und das macht, was der TE haben möchte, habe ich "das Script" geschrieben ![]()
Ja, außerdem hat nur Gen2 Bluetooth an Bord. Statt des I3 kannst du ja auch einen I4 nehmen...
Noch ein Tipp, nach Erhalt der Geräte mache erst die Firmware Updates, bevor du sie an den Ort ohne WLAN verfrachtest. Den AP des Plus 1 aktiviert lassen, aber mit Passwort versehen.
Das ist das Script. Du musst an der Stelle
die MAC-Adresse deines Blu Button eintragen. Die URL für singlePush passt, sie schaltet das eigene Relais. Die 3 anderen habe ich gelöscht, sie schalten bei mir andere Shellys.
/**
* 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: "xx:xx:xx:xx:xx:xx", //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=toggle"
],
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();
Alles anzeigen
Ok, eine weitere Möglichkeit, aber genau so wenig zu gebrauchen wie beim 2.5er, da es im Cover Mode keine Tastenaktionen gibt (Single, Double, Longpush...).
Wie schon geschrieben, ich habe mir die gewünschten Aktionen auf einen benachbarten Lichttaster gelegt. Das hat den WAF deutlich erhöht
. Wäre natürlich schick, wenn es über die eigentlichen Rolladentaster im Detached Mode auch möglich wäre, wenn ich Zeit und Lust habe, kann ich den Vorschlag ja nochmal bei Allterco einreichen, ich glaube aber nicht so recht daran, dass es umgesetzt wird. Die meisten Nutzer werden auch höchstens die Zeitpläne (zusätzlich zur manuellen Bedienung) nutzen...
Mehr gibt es nicht beim 2.5er im Cover Mode.
So, klinke mich mal aus, wollte früh aufstehen morgen...
Hast du beim 2PM mal geschaut, welche Aktionen es im Cover Modus gibt? Habe leider keinen...
Das Festhalteproblem sollte mit Bordmitteln zu lösen sein, zumindest kann es der 2.5er, dann hoffe ich mal, dass es der Nachfolger auch kann
.
Kurz lang geht leider nicht, weil es keine Tastenaktionen im Detached Mode beim 2.5er gibt. Das habe ich schon vor Jahren bei Allterco vorgeschlagen, es wurde aber nie integriert. Mein Plan war, kurze Tastendrücke steuern den direkt angeschlossenen Shelly, Doppel- oder Longpush mehrere Shellys gleichzeitig (so eine Art "Mastertaster" der mehrere Rolladen steuert). Ob es der 2PM kann, weiß ich nicht, habe leider keinen.
Die von mir gewünschte "Masterfunktion" habe ich dann später auf einen benachbarten "Lichttaster" gelegt.
Mit kurzen Tastendrücken toggelt der sein Licht, Doppelpush öffnet die Rolläden, Longpush schließt die Rolläden...
Bei Serientastern bzw. Doppeltastern oder Jalousietastern führt ein kurzer Tastendruck dazu, dass der Rolladen komplett in die entsprechende Richtung fährt. Drückt man während der Bewegung erneut auf die gleiche Taste, stoppt der Rolladen an der aktuellen Position.
Einzeltasten habe ich nicht, soweit ich weiß, wird dort einfach eine Sequenz durchgetastet. Auf, Stopp, Ab, Stopp, Auf usw. usw.
Ich glaube, diese Frage wurde schon mal gestellt, seinerzeit habe ich es extra ausprobiert, es funktioniert. Soweit ich mich erinnere, musst du im Plus1 aber das passende Script laufen lassen...
Ich wollte eigentlich Funktionen belegen, sprich Taster kurz drücken - Rolläden fährt komplett hoch, Taster länger drücken - Rolläden fährt auf Position. Runter entsprechend genauso.
Soweit ich weiß, geht das so leider nicht, auch nicht im Detached Mode. Bei richtiger Einstellung fahren die Rolläden aber so, wie von DIYROLLY beschrieben.
Anfahren einer "Schattenposition" habe ich auf einen ganz anderen Shelly gelegt...
Mein (fest angeschlossenes) Balkonkraftwerk betreibe ich über einen (modifizierten) Plus 1 PM. (Relais ausgelötet und durch Brücke ersetzt). Heute würde ich einen Plus PM Mini nehmen, den gab es vor einem halben Jahr noch nicht.
Wielandstecker sind total überbewertet, es geht dabei auch nicht um Verpolungssicherheit sondern um den Berührungsschutz. In der Theorie könnte man ja einen Stromschlag bekommen, wenn man den Schuko Stecker zieht und ganz schnell an die Kontakte fasst. Alle zugelassenen Wechselrichter müssen aber sicher über ein Relais innerhalb weniger ms abschalten, wenn das Netz ausfällt. Tatsächlich wurde aber dort schon getrickst, Stichwort "Deye". Wer also auf Nummer sicher gehen will, der soll sich die Wieland Steckverbindung holen, ich persönlich halte sie aber für überflüssig, man sollte halt einen vernünftigen Wechselrichter kaufen...
Aber wenn ich den taster manuell drücke passiert nichts bzw. Das Tor fährt wie gewohnt aber das Lichtbild schaltet nicht an
Das ist vermutlich der Taster, der schon da war, bevor du den Shelly parallel geklemmt hast, oder? Woher soll der Shelly wissen, dass du diesen Taster betätigt hast?
Im Schaltschrank könnte der WLAN Empfang ziemlich bescheiden sein...
Die PRO Geräte sind teurer, weil sie u.a. eine Ethernet Schnittstelle haben und für die Hutschiene gedacht sind.
Zum Thema messen: Alles mit PM im Namen kann messen, die Daten aber nicht speichern, du brauchst entweder die Cloud oder ein übergeordnetes System.
Zum "richtigen" Messen sind die EM gedacht. Es kommt letztlich immer drauf an, was man haben will. Der neue Plus PM Mini kann z.B. auch messen (16A), er kann aber nichts schalten. Für mich ein ideales Gerät für Kühlschränke, Kühltruhen, Waschmaschinen, ich würde nie einen Schaltaktor an ein Kühlgerät hängen...
Er ist aber auch nicht für die Hutschiene gedacht.
Klimaanlage: Würde ich auch nicht netzseitig schalten, es gibt bestimmt einen Steuerkontakt.
Beleuchtung 1 Kanal: Soll auch gemessen werden, oder nur geschaltet? Für den Schaltschrank PRO 1 PM oder PRO 1.