auch ein anderer 2PM bringt das gleiche Ergebnis.
Kann mir nicht vorstellen, dass 2 neue Shellys defekt sind. Wenn es wirklich richtig angeschlossen war, dann müsste es funktionieren...
auch ein anderer 2PM bringt das gleiche Ergebnis.
Kann mir nicht vorstellen, dass 2 neue Shellys defekt sind. Wenn es wirklich richtig angeschlossen war, dann müsste es funktionieren...
Der richtige Shelly wäre der Shelly 1 Gen3 oder Gen4. Ab Gen3 kann der BluButton direkt mit dem Shelly kommunizieren, er wird als BTHome Device eingebunden.
benötigt der Shelly zwingend den tatsächlichen L-Leiter an L und den N-Leiter an N?
Nein, wenn du den Shelly über einen Schukostecker versorgen würdest, kannst du diesen ja auch um 180° verdreht einstecken. Wenn am Schalter wirklich der Neutralleiter geschaltet wird, dann musst du den Shelly "verpolt" anschließen, L und N vertauschen. Du brauchst aber trotzdem L und N zur Versorgung des Shelly, vermutlich sind braun und gelb-grün gar nicht angeschlossen und enden in einer Dose, wenn du Pech hast, direkt beim Rollladen. Wenn ohnehin der braune Draht angeklemmt werden muss, dann könnte man es auch direkt richtig klemmen. Wichtig ist auch, dass der Rollladen die gleiche Phase hat, wie der Shelly, das ist bei dir nicht sicher, wenn wirklich der N geschaltet wird...
Das Script ist nicht von mir, du findest es auch unter github.
Du musst die MAC-Adresse des BluButton anpassen (Achtung: Kleinbuchstaben verwenden) und die Aktionen anpassen (unten siehst du meine Aktionen).
Wenn du nicht alle 4 Möglichkeiten nutzen willst, dann den "http-Teil" weglassen.
/**
* 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: "1a:b2:c3:d4:55:ef", //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
"http://192.168.2.66/relay/0?turn=toggle"
],
triplePush: [ //urls that will be executed at triplePush event from the blu button1
"http://192.168.2.47/relay/0?turn=on"
],
longPush: [ //urls that will be executed at longPush event from the blu button1
"http://192.168.2.41/color/0?turn=on&red=255&green=0&blue=0&white=0&gain=100&effect=3&timer=10",
"http://192.168.2.42/color/0?turn=on&red=0&green=255&blue=0&white=0&gain=100&effect=3&timer=20"
]
}
};
/** =============================== 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
Der PE und der braune N liegen jeweils gebrückt im Inneren der Dose.
Ich hoffe mal, dass diese Drähte unbenutzt sind und der Elektriker sparen wollte und sie daher zusammen geklemmt hat. Gut ist das auf keinen Fall!
Du wirst messen müssen, bevor man hier etwas sagen kann. Vielleicht ist der blaue Draht ja der L...
aber es kommt kein Saft an O1 oder O2 an. Phasenprüfer zeigt nix an.
........
Ich vermute das der 2PM keinen Verbraucher erkennt
.......
S1 bzw. S2 nicht beutzt
Das kann so nicht sein. Der Shelly schaltet einfach von L nach O, auch wenn keine Last angeschlossen ist. Stimmt deine Verdrahtung? Hast du die Phase für den Shelly von dem ehemaligen Schalter genommen? Was hast du mit dem Schalter gemacht, wenn an S1 und S2 nichts angeschlossen ist?
Zitat: „… wenn der Plus 1 PM in der Cloud ist“
Was heißt das denn genau?
Vereinfacht ausgedückt: Die alten Shellys können nicht direkt mit den Blu Geräten kommunizieren, am einfachsten geht es dann mit einer Szene (Beispiel):
Funktioniert natürlich nur, wenn eine Internet- und Cloudverbindung besteht. Man kann aber auch ein Script nutzen, welches das Blu-Gerät mit dem Shelly koppelt. Wenn du willst, kann ich es dir zukommen lassen.
Das Script wertet die Tastendrücke des Blu-Geräts aus und startet Aktionen.
Die findest du über dem Schlüssel, bei mir z.B. 71
Es geht um die Verbindung Blu Button zum alten Shelly Plus 1 PM. Einfach mal genau lesen, was ich geschrieben habe...
Also würde der hier Shelly BLU Button1 - Weiß (Amazon ca. 10€) problemlos mit meinem Shelly Plus 1PM laufen?
Ja aber...
Einfach geht es dann nur, wenn der Plus 1 PM in der Cloud ist. Wenn du das nicht willst, dann brauchst du ein Script auf dem Shelly. Neuere Shellys ab Gen3 können auch direkt mit Blu - Geräten kommunizieren.
Was mache ich falsch
Evtl musst du runterscrollen, da könnte sich noch eine Speichern - Schaltfläche verbergen...
Übrigens wäre eine Glühbirne auch ein Strombegrenzer
Nicht wirklich, sie hat im kalten Zustand einen kleinen Widerstand, wenn sie warm wird, wird er größer.
Der Einschaltstrombegrenzer macht es genau anders herum...
Den verlinkten Einschaltstrombegrenzer kenne ich nicht, es stehen auch leider wenig Angaben in der Beschreibung, kannst du aber bestimmt auch verwenden...
Wenn man etwas sucht, findet man die Teile oft günstiger.
Ich stelle fest, dass der Gen3 Mini deutlich robuster ist, als die ersten Minis, denn auf ähnliche Weise (2 verschiedene Phasen) habe ich mal den Eingang eines Mini geschrottet. Ich habe es seinerzeit aber nicht absichtlich falsch angeschlossen, bei mir war es ein Versehen, kann jedem passieren...
Das Problem ist einfach erklärt: Normalerweise schaltet man zwischen L und SW des Shelly. Ist der Schalter geschlossen, dann haben beide das gleiche Potential und es fließt ein ganz geringer Strom.
Du schaltest eine andere Phase auf den SW, der Potentialunterschied zwischen L und SW beträgt dann 400VAC. Diese werden im Inneren des Shelly verbraten, dadurch wird er warm. Ich wundere mich, dass er das ausgehalten hat.
Auch mit dem alten Shelly ist das falsch und gefährlich!
Die einfachste Lösung wäre wirklich, den Shelly zum Jung-Regler zu setzen, dort hast du eine Phae und einen Neutralleiter, der Ausgang vom Jung kann dann auf den Eingang des Shelly geschaltet werden.
L und I gleiche Phase?
immer noch nur die 67 bis 124 Volt bringt. Ohne Test mit Motor. Wenn dem nicht so ist, dann hat es tatsächlich die Relais verbrannt
Von wo nach wo misst du die Spannungen?
Es gibt da so ein Elektrikersprichwort: "Wer misst, misst Mist".
Ich habe den Verdacht, dass dies bei dir zutrifft und du falsch misst...
Wird aber sehr eng in der Unterputzdose
Kannst das Teil ja auch beim Netzteil unterbringen, wenn dort mehr Platz ist...
Wie das Teil angeschlossen wird, weißt du, oder? (Ich gehe mal davon aus, anhand deiner Beiträge...).
Die Trennrelais werden dann auch speziell sein. Da bei der PEZ I explizit geschrieben steht, keinen Motor an diesen Klemmen anzuschließen, werden die Trennrelais ziemlich sicher nicht mit 230VAC angesteuert. Das macht es etwas komplizierter. Evtl könnte man hinter den Shelly noch 2 Koppelrelais mit 230V Spule setzen und so 2 potentialfreie Kontakte gewinnen.
Kommt drauf an, ob es wirklich diese Variante ist...
Ich gehe stark davon aus, dass man mit der Uhr direkt auf- und ab schalten kann und das Trennrelais verbaut sind. Wenn keine Infos zur Uhr zu finden sind, einfach mal ausbauen und schauen, wie die Rückseite aussieht.