mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-06 15:59:52 +03:00
263 lines
9.2 KiB
JavaScript
263 lines
9.2 KiB
JavaScript
console.log("[INFO] Starting MyESP WebSocket Emulation Server");
|
|
|
|
const WebSocket = require("ws");
|
|
|
|
console.log("[INFO] You can connect to ws://localhost or load URL .../src/websrc/temp/index.html");
|
|
console.log("[INFO] Password is 'neo'");
|
|
|
|
const wss = new WebSocket.Server({
|
|
port: 80
|
|
});
|
|
|
|
wss.broadcast = function broadcast(data) {
|
|
wss.clients.forEach(function each(client) {
|
|
if (client.readyState === WebSocket.OPEN) {
|
|
client.send(JSON.stringify(data));
|
|
}
|
|
});
|
|
};
|
|
|
|
var networks = {
|
|
"command": "ssidlist",
|
|
"list": [{
|
|
"ssid": "Company's Network",
|
|
"bssid": "4c:f4:39:a1:41",
|
|
"rssi": "-84"
|
|
},
|
|
{
|
|
"ssid": "Home Router",
|
|
"bssid": "8a:e6:63:a8:15",
|
|
"rssi": "-42"
|
|
},
|
|
{
|
|
"ssid": "SSID Shown Here",
|
|
"bssid": "8a:f5:86:c3:12",
|
|
"rssi": "-77"
|
|
},
|
|
{
|
|
"ssid": "Great Wall of WPA",
|
|
"bssid": "9c:f1:90:c5:15",
|
|
"rssi": "-80"
|
|
},
|
|
{
|
|
"ssid": "Not Internet",
|
|
"bssid": "8c:e4:57:c5:16",
|
|
"rssi": "-87"
|
|
}
|
|
]
|
|
}
|
|
|
|
var eventlog = {
|
|
"command": "eventlist",
|
|
"page": 1,
|
|
"haspages": 1,
|
|
"list": [
|
|
"{ \"type\": \"WARN\", \"src\": \"sys\", \"desc\": \"Event log cleared!\", \"data\": \"\", \"time\": 1563371160 }",
|
|
"{ \"type\": \"WARN\", \"src\": \"sys\", \"desc\": \"Event log cleared!\", \"data\": \"\", \"time\": 1563371160 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"wifi\", \"desc\": \"WiFi is connected\", \"data\": \"SMC\", \"time\": 13 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"sys\", \"desc\": \"System setup completed, running\", \"data\": \"\", \"time\": 13 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"wifi\", \"desc\": \"WiFi is connected\", \"data\": \"SMC\", \"time\": 13 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"sys\", \"desc\": \"System setup completed, running\", \"data\": \"\", \"time\": 13 }",
|
|
"{ \"type\": \"WARN\", \"src\": \"websrv\", \"desc\": \"New login attempt\", \"data\": \"\", \"time\": 1563371160 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"websrv\", \"desc\": \"Login success!\", \"data\": \"\", \"time\": 1563371160 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"wifi\", \"desc\": \"WiFi is connected\", \"data\": \"SMC\", \"time\": 13 }",
|
|
"{ \"type\": \"INFO\", \"src\": \"sys\", \"desc\": \"System setup completed, running\", \"data\": \"\", \"time\": 13 }",
|
|
"{ \"type\": \"WARN\", \"src\": \"websrv\", \"desc\": \"New login attempt\", \"data\": \"\", \"time\": 1563371160 }"
|
|
]
|
|
}
|
|
|
|
var configfile = {
|
|
"command": "configfile",
|
|
"network": {
|
|
"ssid": "myssid",
|
|
"wmode": 0,
|
|
"password": "password"
|
|
},
|
|
"general": {
|
|
"hostname": "myesp",
|
|
"password": "admin",
|
|
"serial": true
|
|
},
|
|
"mqtt": {
|
|
"enabled": false,
|
|
"ip": "ip",
|
|
"port": "port",
|
|
"base": "base",
|
|
"user": "user",
|
|
"password": "password",
|
|
"heartbeat": false
|
|
},
|
|
"ntp": {
|
|
"server": "pool.ntp.org",
|
|
"interval": "30",
|
|
"timezone": "0",
|
|
"enabled": false
|
|
}
|
|
};
|
|
|
|
var custom_configfile = {
|
|
"command": "custom_configfile",
|
|
"settings": {
|
|
"led": true,
|
|
"led_gpio": 2,
|
|
"dallas_gpio": 14,
|
|
"dallas_parasite": false,
|
|
"listen_mode": false,
|
|
"shower_timer": false,
|
|
"shower_alert": false,
|
|
"publish_time": 120,
|
|
"heating_circuit": 1
|
|
}
|
|
};
|
|
|
|
function sendEventLog() {
|
|
wss.broadcast(eventlog);
|
|
var res = {
|
|
"command": "result",
|
|
"resultof": "eventlist",
|
|
"result": true
|
|
};
|
|
wss.broadcast(res);
|
|
}
|
|
|
|
function sendStatus() {
|
|
var stats = {
|
|
"command": "status",
|
|
"availspiffs": 948,
|
|
"spiffssize": 957,
|
|
"initheap": 25392,
|
|
"heap": 13944,
|
|
"sketchsize": 673,
|
|
"availsize": 2469,
|
|
"ip": "10.10.10.198",
|
|
"ssid": "derbyshire",
|
|
"mac": "DC:4F:11:22:93:06",
|
|
"signalstr": 62,
|
|
"systemload": 0,
|
|
"mqttconnected": true,
|
|
"mqttheartbeat": false,
|
|
"uptime": "0 days 0 hours 1 minute 45 seconds",
|
|
"mqttloghdr": "home/ems-esp/",
|
|
"mqttlog": [
|
|
{ "topic": "start", "payload": "start", "time": 1565956388 },
|
|
{ "topic": "shower_timer", "payload": "1", "time": 1565956388 },
|
|
{ "topic": "shower_alert", "payload": "0", "time": 1565956388 },
|
|
{ "topic": "boiler_data", "payload": "{\"wWComfort\":\"Hot\",\"wWSelTemp\":60,\"selFlowTemp\":5,\"selBurnPow\":0,\"curBurnPow\":0,\"pumpMod\":0,\"wWCurTmp\":48.4,\"wWCurFlow\":0,\"curFlowTemp\":49.3,\"retTemp\":49.3,\"sysPress\":1.8,\"boilTemp\":50.5,\"wWActivated\":\"on\",\"burnGas\":\"off\",\"heatPmp\":\"off\",\"fanWork\":\"off\",\"ignWork\":\"off\",\"wWCirc\":\"off\",\"wWHeat\":\"on\",\"burnStarts\":223397,\"burnWorkMin\":366019,\"heatWorkMin\":294036,\"ServiceCode\":\"0H\",\"ServiceCodeNumber\":203}", "time": 1565956463 },
|
|
{ "topic": "tapwater_active", "payload": "0", "time": 1565956408 },
|
|
{ "topic": "heating_active", "payload": "0", "time": 1565956408 },
|
|
{ "topic": "thermostat_data", "payload": "{\"thermostat_hc\":\"1\",\"thermostat_seltemp\":15,\"thermostat_currtemp\":23,\"thermostat_mode\":\"auto\"}", "time": 1565956444 }
|
|
]
|
|
};
|
|
|
|
wss.broadcast(stats);
|
|
}
|
|
|
|
function sendCustomStatus() {
|
|
var stats = {
|
|
"command": "custom_status",
|
|
"version": "1.9.0b",
|
|
"customname": "ems-esp",
|
|
"appurl": "https://github.com/proddy/EMS-ESP",
|
|
"updateurl": "https://api.github.com/repos/proddy/EMS-ESP/releases/latest",
|
|
|
|
"emsbus": {
|
|
"ok": true,
|
|
"msg": "everything is OK",
|
|
"devices": [
|
|
{ "type": 1, "model": "model 1", "deviceid": "device id1", "version": "version id1", "productid": "product id1" },
|
|
{ "type": 2, "model": "model 2", "deviceid": "device id2", "version": "version id2", "productid": "product id2" },
|
|
{ "type": 3, "model": "model 3", "deviceid": "device id3", "version": "version id3", "productid": "product id3" },
|
|
{ "type": 4, "model": "model 4", "deviceid": "device id3", "version": "version id3", "productid": "product id3" },
|
|
{ "type": 5, "model": "model 5", "deviceid": "device id3", "version": "version id3", "productid": "product id3" }
|
|
]
|
|
},
|
|
|
|
"thermostat": {
|
|
"ok": true,
|
|
"tm": "model abc",
|
|
"ts": "23",
|
|
"tc": "27.5",
|
|
"tmode": "manual"
|
|
},
|
|
|
|
"boiler": {
|
|
"ok": true,
|
|
"bm": "mode boiler",
|
|
"b1": "on",
|
|
"b2": "off",
|
|
"b3": 15.8,
|
|
"b4": 61.5,
|
|
"b5": 35.8,
|
|
"b6": 47.1
|
|
}
|
|
|
|
};
|
|
|
|
wss.broadcast(stats);
|
|
}
|
|
|
|
wss.on('connection', function connection(ws) {
|
|
ws.on("error", () => console.log("[WARN] WebSocket Error - Assume a client is disconnected."));
|
|
ws.on('message', function incoming(message) {
|
|
var obj = JSON.parse(message);
|
|
console.log("[INFO] Got Command: " + obj.command);
|
|
switch (obj.command) {
|
|
case "configfile":
|
|
console.log("[INFO] New system settings file received");
|
|
configfile = obj;
|
|
break;
|
|
case "custom_configfile":
|
|
console.log("[INFO] New custom config file received");
|
|
custom_configfile = obj;
|
|
break;
|
|
case "status":
|
|
console.log("[INFO] Sending Fake Emulator Status");
|
|
sendStatus();
|
|
break;
|
|
case "custom_status":
|
|
console.log("[INFO] Sending custom status");
|
|
sendCustomStatus();
|
|
break;
|
|
case "scan":
|
|
console.log("[INFO] Sending Fake Wireless Networks");
|
|
wss.broadcast(networks);
|
|
break;
|
|
case "gettime":
|
|
console.log("[INFO] Sending time");
|
|
var res = {};
|
|
res.command = "gettime";
|
|
res.epoch = Math.floor((new Date).getTime() / 1000);
|
|
res.timezone = configfile.timezone;
|
|
wss.broadcast(res);
|
|
break;
|
|
case "settime":
|
|
console.log("[INFO] Setting time (fake)");
|
|
var res = {};
|
|
res.command = "gettime";
|
|
res.epoch = Math.floor((new Date).getTime() / 1000);
|
|
res.timezone = configfile.timezone;
|
|
wss.broadcast(res);
|
|
break;
|
|
case "getconf":
|
|
console.log("[INFO] Sending system configuration file (if set any)");
|
|
wss.broadcast(configfile);
|
|
break;
|
|
case "geteventlog":
|
|
console.log("[INFO] Sending eventlog");
|
|
sendEventLog();
|
|
break;
|
|
case "clearevent":
|
|
console.log("[INFO] Clearing eventlog");
|
|
break;
|
|
case "restart":
|
|
console.log("[INFO] Restart");
|
|
break;
|
|
case "destroy":
|
|
console.log("[INFO] Destroy");
|
|
break;
|
|
default:
|
|
console.log("[WARN] Unknown command ");
|
|
break;
|
|
}
|
|
});
|
|
}); |