@sued72 Danke.
Leider weiter der gleiche Fehler
00:22:10.707 silly javascript.0 (1749383) Objects user redis pmessage */cfg.o.script.js.Bayrol:{"common":{"name":"Bayrol","expert":true,"engineType":"Javascript/js","engine":"system.adapter.javascript.0","source":"// jshint esversion: 8\nconst fetch = require('node-fetch'); \n \n//config start\nlet user=\"xxx\";\nlet password=\"xxx\";\nlet dpPH = \"0_userdata.0.BayrolSaltRlxPro.pH\";\nlet dpMV = \"0_userdata.0.BayrolSaltRlxPro.Redox\";\nlet dpCC = \"0_userdata.0.BayrolSaltRlxPro.Temperature\";\nlet requesttime=10*1000; //erneuterdatenabruf in Millisekunden\n \nconst useragent = \"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36 Edg/123.0.0.0\";\n//config end\n \nasync function main() {\n let sessionid = await getSession ();\n let cid= await login(user,password,sessionid); \n if (cid) await getData(sessionid,cid);\n}\nasync function getSession() {\n const response = await fetch(\"https://www.bayrol-poolaccess.de/webview/index.php\", {\n \"headers\": {\n \"accept\": \"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7\",\n \"accept-language\": \"de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7\",\n \"cache-control\": \"no-cache\",\n \"pragma\": \"no-cache\",\n \"sec-ch-ua\": \"\\\"Not_A Brand\\\";v=\\\"8\\\", \\\"Chromium\\\";v=\\\"120\\\", \\\"Google Chrome\\\";v=\\\"120\\\"\",\n \"sec-ch-ua-mobile\": \"?0\",\n \"sec-ch-ua-platform\": \"\\\"Windows\\\"\",\n \"sec-fetch-dest\": \"document\",\n \"sec-fetch-mode\": \"navigate\",\n \"sec-fetch-site\": \"none\",\n \"sec-fetch-user\": \"?1\",\n \"upgrade-insecure-requests\": \"1\",\n \"User-Agent\":useragent\n },\n \"ReferrerPolicy\": \"strict-origin-when-cross-origin\",\n \"body\": null,\n \"method\": \"GET\"\n });\n let headers = await response.headers;\n //log (headers);\n return getSessionId(headers.get(\"set-cookie\"));\n}\nasync function login(user,password,sessionid) {\n let body=`username=${encodeURIComponent(user)}&password=${encodeURIComponent(password)}&login=Anmelden`;\n const response = await fetch(\"https://www.bayrol-poolaccess.de/webview/p/login.php?r=reg\", {\n \"headers\": {\n \"accept\": \"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7\",\n \"accept-language\": \"de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7\",\n \"cache-control\": \"no-cache\",\n \"content-type\": \"application/x-www-form-urlencoded\",\n \"pragma\": \"no-cache\",\n \"sec-ch-ua\": \"\\\"Not_A Brand\\\";v=\\\"8\\\", \\\"Chromium\\\";v=\\\"120\\\", \\\"Google Chrome\\\";v=\\\"120\\\"\",\n \"sec-ch-ua-mobile\": \"?0\",\n \"sec-ch-ua-platform\": \"\\\"Windows\\\"\",\n \"sec-fetch-dest\": \"document\",\n \"sec-fetch-mode\": \"navigate\",\n \"sec-fetch-site\": \"same-origin\",\n \"sec-fetch-user\": \"?1\",\n \"upgrade-insecure-requests\": \"1\",\n \"cookie\": `PHPSESSID=${sessionid}`,\n \"Referer\": \"https://www.bayrol-poolaccess.de/webview/p/login.php\",\n \"Referrer-Policy\": \"strict-origin-when-cross-origin\",\n \"User-Agent\":useragent\n },\n \"body\": body,\n \"method\": \"POST\"\n }); \n let text=await response.text();\n //log(text);\n return getCID(text);\n}\nasync function getData(sessionid,cid) {\n const response = await fetch(`https://www.bayrol-poolaccess.de/webview/getdata.php?cid=${cid}`, {\n \"headers\": {\n \"accept\": \"*/*\",\n \"accept-language\": \"de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7\",\n \"cache-control\": \"no-cache\",\n \"pragma\": \"no-cache\",\n \"sec-ch-ua\": \"\\\"Not_A Brand\\\";v=\\\"8\\\", \\\"Chromium\\\";v=\\\"120\\\", \\\"Google Chrome\\\";v=\\\"120\\\"\",\n \"sec-ch-ua-mobile\": \"?0\",\n \"sec-ch-ua-platform\": \"\\\"Windows\\\"\",\n \"sec-fetch-dest\": \"empty\",\n \"sec-fetch-mode\": \"cors\",\n \"sec-fetch-site\": \"same-origin\",\n \"x-requested-with\": \"XMLHttpRequest\",\n \"cookie\": `PHPSESSID=${sessionid}`,\n \"Referer\": \"https://www.bayrol-poolaccess.de/webview/p/plants.php\",\n \"Referrer-Policy\": \"strict-origin-when-cross-origin\",\n \"User-Agent\":useragent\n },\n \"body\": null,\n \"method\": \"GET\"\n });\n let text=await response.text();\n log(text)\n writeData(extractValues(text));\n setTimeout(getData.bind(this),requesttime,sessionid,cid);\n}\nfunction writeData(obj) {\ntry {\n setState(dpCC,parseFloat(obj.CC));\n setState(dpMV,parseFloat(obj.MV));\n setState(dpPH,parseFloat(obj.PH));\n} catch (error) {\n log(error);\n} \n}\nfunction extractValues(text){\n const regexPH = /[pH]\\<\\/span><h1>([\\d\\.]+)<\\/h1>/gm;\n const regexMV = /[mV]\\<\\/span><h1>([\\d\\.]+)<\\/h1>/gm;\n const regexCC = /[°C]\\<\\/span><h1>([\\d\\.]+)<\\/h1>/gm;\n \n return {\n PH:regexPH.exec(text)[1],\n MV:regexMV.exec(text)[1],\n CC:regexCC.exec(text)[1],\n\n };\n \n}\nasync function getCID(text){\n const regex = /var clients = [(\\d+)];/gm;\n let result = regex.exec(text);\n //log(text);\n //log(result);\n if (result.length==2) return result[1];\n return undefined;\n}\nfunction getSessionId(setcookie){\n let cookieHeader = setcookie;\n if (cookieHeader.length>0) {\n let cookieArray = cookieHeader.split(\";\")\n const cookieObject = {};\n cookieArray.forEach(cookie => {\n const [name, value] = cookie.split('=');\n cookieObject[(name||\"empty\").trim()] = (value||\"\").trim();\n });\n return cookieObject[\"PHPSESSID\"]||\"\";\n }\n}\nmain();\n","debug":true,"verbose":true,"enabled":true},"type":"script","from":"system.adapter.admin.0","user":"system.user.admin","ts":1712352130706,"_id":"script.js.Bayrol","acl":{"object":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
00:22:10.712 info javascript.0 (1749383) Stop script script.js.Bayrol
00:22:10.772 info javascript.0 (1749383) Start javascript script.js.Bayrol
00:22:10.782 info javascript.0 (1749383) script.js.Bayrol: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
00:22:11.315 error javascript.0 (1749383) script.js.Bayrol: TypeError: Cannot read properties of null (reading 'length')
00:22:11.315 error javascript.0 (1749383) at getCID (script.js.Bayrol:128:16)
00:22:11.316 error javascript.0 (1749383) at login (script.js.Bayrol:72:10)
00:22:11.316 error javascript.0 (1749383) at main (script.js.Bayrol:17:14)
// jshint esversion: 8
const fetch = require('node-fetch');
//config start
let user="xxx";
let password="xxx";
let dpPH = "0_userdata.0.BayrolSaltRlxPro.pH";
let dpMV = "0_userdata.0.BayrolSaltRlxPro.Redox";
let dpCC = "0_userdata.0.BayrolSaltRlxPro.Temperature";
let requesttime=10*1000; //erneuterdatenabruf in Millisekunden
const useragent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36 Edg/123.0.0.0";
//config end
async function main() {
let sessionid = await getSession();
let cid= await login(user,password,sessionid);
if (cid) await getData(sessionid,cid);
}
async function getSession() {
const response = await fetch("https://www.bayrol-poolaccess.de/webview/index.php", {
"headers": {
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
"accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
"cache-control": "no-cache",
"pragma": "no-cache",
"sec-ch-ua": "\"Not_A Brand\";v=\"8\", \"Chromium\";v=\"120\", \"Google Chrome\";v=\"120\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"Windows\"",
"sec-fetch-dest": "document",
"sec-fetch-mode": "navigate",
"sec-fetch-site": "none",
"sec-fetch-user": "?1",
"upgrade-insecure-requests": "1",
"User-Agent":useragent
},
"ReferrerPolicy": "strict-origin-when-cross-origin",
"body": null,
"method": "GET"
});
let headers = await response.headers;
//log (headers);
return getSessionId(headers.get("set-cookie"));
}
async function login(user,password,sessionid) {
let body=`username=${encodeURIComponent(user)}&password=${encodeURIComponent(password)}&login=Anmelden`;
const response = await fetch("https://www.bayrol-poolaccess.de/webview/p/login.php?r=reg", {
"headers": {
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
"accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
"cache-control": "no-cache",
"content-type": "application/x-www-form-urlencoded",
"pragma": "no-cache",
"sec-ch-ua": "\"Not_A Brand\";v=\"8\", \"Chromium\";v=\"120\", \"Google Chrome\";v=\"120\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"Windows\"",
"sec-fetch-dest": "document",
"sec-fetch-mode": "navigate",
"sec-fetch-site": "same-origin",
"sec-fetch-user": "?1",
"upgrade-insecure-requests": "1",
"cookie": `PHPSESSID=${sessionid}`,
"Referer": "https://www.bayrol-poolaccess.de/webview/p/login.php",
"Referrer-Policy": "strict-origin-when-cross-origin",
"User-Agent":useragent
},
"body": body,
"method": "POST"
});
let text=await response.text();
//log(text);
return getCID(text);
}
async function getData(sessionid,cid) {
const response = await fetch(`https://www.bayrol-poolaccess.de/webview/getdata.php?cid=${cid}`, {
"headers": {
"accept": "*/*",
"accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
"cache-control": "no-cache",
"pragma": "no-cache",
"sec-ch-ua": "\"Not_A Brand\";v=\"8\", \"Chromium\";v=\"120\", \"Google Chrome\";v=\"120\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"Windows\"",
"sec-fetch-dest": "empty",
"sec-fetch-mode": "cors",
"sec-fetch-site": "same-origin",
"x-requested-with": "XMLHttpRequest",
"cookie": `PHPSESSID=${sessionid}`,
"Referer": "https://www.bayrol-poolaccess.de/webview/p/plants.php",
"Referrer-Policy": "strict-origin-when-cross-origin",
"User-Agent":useragent
},
"body": null,
"method": "GET"
});
let text=await response.text();
log(text)
writeData(extractValues(text));
setTimeout(getData.bind(this),requesttime,sessionid,cid);
}
function writeData(obj) {
try {
setState(dpCC,parseFloat(obj.CC));
setState(dpMV,parseFloat(obj.MV));
setState(dpPH,parseFloat(obj.PH));
} catch (error) {
log(error);
}
}
function extractValues(text){
const regexPH = /[pH]\<\/span><h1>([\d\.]+)<\/h1>/gm;
const regexMV = /[mV]\<\/span><h1>([\d\.]+)<\/h1>/gm;
const regexCC = /[°C]\<\/span><h1>([\d\.]+)<\/h1>/gm;
return {
PH:regexPH.exec(text)[1],
MV:regexMV.exec(text)[1],
CC:regexCC.exec(text)[1],
};
}
async function getCID(text){
const regex = /var clients = [(\d+)];/gm;
let result = regex.exec(text);
//log(text);
//log(result);
if (result.length==2) return result[1];
return undefined;
}
function getSessionId(setcookie){
let cookieHeader = setcookie;
if (cookieHeader.length>0) {
let cookieArray = cookieHeader.split(";")
const cookieObject = {};
cookieArray.forEach(cookie => {
const [name, value] = cookie.split('=');
cookieObject[(name||"empty").trim()] = (value||"").trim();
});
return cookieObject["PHPSESSID"]||"";
}
}
main();