123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346 |
- "use strict";
- var __assign = (this && this.__assign) || function () {
- __assign = Object.assign || function(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
- t[p] = s[p];
- }
- return t;
- };
- return __assign.apply(this, arguments);
- };
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
- };
- var __generator = (this && this.__generator) || function (thisArg, body) {
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
- function verb(n) { return function (v) { return step([n, v]); }; }
- function step(op) {
- if (f) throw new TypeError("Generator is already executing.");
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
- if (y = 0, t) op = [op[0] & 2, t.value];
- switch (op[0]) {
- case 0: case 1: t = op; break;
- case 4: _.label++; return { value: op[1], done: false };
- case 5: _.label++; y = op[1]; op = [0]; continue;
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
- default:
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
- if (t[2]) _.ops.pop();
- _.trys.pop(); continue;
- }
- op = body.call(thisArg, _);
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
- }
- };
- var __importDefault = (this && this.__importDefault) || function (mod) {
- return (mod && mod.__esModule) ? mod : { "default": mod };
- };
- Object.defineProperty(exports, "__esModule", { value: true });
- var coolkit_ws_1 = __importDefault(require("coolkit-ws"));
- var dataUtil_1 = require("./dataUtil");
- var Controller_1 = __importDefault(require("../controller/Controller"));
- var app_1 = require("../config/app");
- var CloudSwitchController_1 = __importDefault(require("../controller/CloudSwitchController"));
- var CloudTandHModificationController_1 = __importDefault(require("../controller/CloudTandHModificationController"));
- var CloudRGBBulbController_1 = __importDefault(require("../controller/CloudRGBBulbController"));
- var CloudDimmingController_1 = __importDefault(require("../controller/CloudDimmingController"));
- var CloudPowerDetectionSwitchController_1 = __importDefault(require("../controller/CloudPowerDetectionSwitchController"));
- var CloudMultiChannelSwitchController_1 = __importDefault(require("../controller/CloudMultiChannelSwitchController"));
- var CloudRGBLightStripController_1 = __importDefault(require("../controller/CloudRGBLightStripController"));
- var restApi_1 = require("../apis/restApi");
- var CloudDoubleColorBulbController_1 = __importDefault(require("../controller/CloudDoubleColorBulbController"));
- var eventBus_1 = __importDefault(require("./eventBus"));
- var CloudDualR3Controller_1 = __importDefault(require("../controller/CloudDualR3Controller"));
- var LanDualR3Controller_1 = __importDefault(require("../controller/LanDualR3Controller"));
- var CloudDW2WiFiController_1 = __importDefault(require("../controller/CloudDW2WiFiController"));
- var CloudUIID104Controller_1 = __importDefault(require("../controller/CloudUIID104Controller"));
- var CloudZigbeeUIID1770Controller_1 = __importDefault(require("../controller/CloudZigbeeUIID1770Controller"));
- var CloudZigbeeUIID2026Controller_1 = __importDefault(require("../controller/CloudZigbeeUIID2026Controller"));
- var CloudZigbeeUIID3026Controller_1 = __importDefault(require("../controller/CloudZigbeeUIID3026Controller"));
- var CloudZigbeeUIID4026Controller_1 = __importDefault(require("../controller/CloudZigbeeUIID4026Controller"));
- var CloudZigbeeUIID1000Controller_1 = __importDefault(require("../controller/CloudZigbeeUIID1000Controller"));
- var CloudCoverController_1 = __importDefault(require("../controller/CloudCoverController"));
- var LanTandHModificationController_1 = __importDefault(require("../controller/LanTandHModificationController"));
- var CloudRFBridgeController_1 = __importDefault(require("../controller/CloudRFBridgeController"));
- var CloudUIID44Controller_1 = __importDefault(require("../controller/CloudUIID44Controller"));
- var CloudUIID34Controller_1 = __importDefault(require("../controller/CloudUIID34Controller"));
- var process_1 = __importDefault(require("process"));
- var logger_1 = require("./logger");
- var CloudZigbeeMultiSwitchController_1 = __importDefault(require("../controller/CloudZigbeeMultiSwitchController"));
- var CloudZigbeeDoubleColorBulbController_1 = __importDefault(require("../controller/CloudZigbeeDoubleColorBulbController"));
- var CloudZigbeeFiveColorBulbController_1 = __importDefault(require("../controller/CloudZigbeeFiveColorBulbController"));
- var CloudUIID181Controller_1 = __importDefault(require("../controller/CloudUIID181Controller"));
- var CloudUIID190Controller_1 = __importDefault(require("../controller/CloudUIID190Controller"));
- var CloudUIID137Controller_1 = __importDefault(require("../controller/CloudUIID137Controller"));
- var CloudUIID173Controller_1 = __importDefault(require("../controller/CloudUIID173Controller"));
- var mergeDeviceParams_1 = __importDefault(require("./mergeDeviceParams"));
- var LanDeviceController_1 = __importDefault(require("../controller/LanDeviceController"));
- var CloudDeviceController_1 = __importDefault(require("../controller/CloudDeviceController"));
- var CloudUIID130Controller_1 = __importDefault(require("../controller/CloudUIID130Controller"));
- var CloudUIID182Controller_1 = __importDefault(require("../controller/CloudUIID182Controller"));
- var lodash_1 = __importDefault(require("lodash"));
- var channelMap_1 = require("../config/channelMap");
- exports.default = (function () { return __awaiter(void 0, void 0, void 0, function () {
- var apikey, at, region, res;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- apikey = (0, dataUtil_1.getDataSync)('user.json', ['user', 'apikey']);
- at = (0, dataUtil_1.getDataSync)('user.json', ['at']);
- region = (0, dataUtil_1.getDataSync)('user.json', ['region']);
- logger_1.logger.debug("initCkWs.ts at: ".concat(at, " region: ").concat(region));
- if (!at || !apikey) {
- return [2, -1];
- }
- return [4, coolkit_ws_1.default.init({
- appid: app_1.appId,
- at: at,
- apikey: apikey,
- region: region,
- userAgent: 'app',
- reqTimeout: 30000,
- useTestEnv: process_1.default.env.CK_API_ENV === 'test',
- maxRetry: 10000,
- })];
- case 1:
- res = _a.sent();
- logger_1.logger.debug('initCkWs.ts res: ' + JSON.stringify(res));
- logger_1.logger.debug("initCkWs at: ".concat(at));
- coolkit_ws_1.default.on('message', function (ws) { return __awaiter(void 0, void 0, void 0, function () {
- var type, data, tmp, device, _a, currentTemperature, currentHumidity, state, _b, bright, status_1, _c, current, voltage, power, status_2, switches, switches, ids, switches, switches, switches, _d, online, name_1, updateUnavailable2Ha, switches, channelNum, i;
- return __generator(this, function (_e) {
- try {
- type = ws.type, data = ws.data;
- logger_1.logger.debug("receive CK-WS msg: type: ".concat(type));
- logger_1.logger.debug("receive CK-WS msg: data: ".concat(JSON.stringify(data)));
- if (type === 'message' && data !== 'pong') {
- tmp = JSON.parse(data);
- if (!tmp.deviceid) {
- return [2];
- }
- device = Controller_1.default.getDevice(tmp.deviceid);
- if (tmp.action === 'update') {
- if (device instanceof LanDeviceController_1.default || device instanceof CloudDeviceController_1.default) {
- (0, mergeDeviceParams_1.default)(device.params, tmp.params);
- }
- if (device instanceof CloudSwitchController_1.default) {
- device.updateState(tmp.params.switch);
- }
- else if (device instanceof CloudTandHModificationController_1.default || device instanceof LanTandHModificationController_1.default) {
- _a = tmp.params, currentTemperature = _a.currentTemperature, currentHumidity = _a.currentHumidity, state = _a.switch;
- if (currentHumidity || currentTemperature) {
- device.updateTandH(currentTemperature, currentHumidity);
- }
- else if (state) {
- device.updateState(state);
- }
- }
- else if (device instanceof CloudRGBBulbController_1.default) {
- device.updateState(device.parseCkData2Ha(tmp.params));
- }
- else if (device instanceof CloudDimmingController_1.default) {
- _b = tmp.params, bright = _b.bright, status_1 = _b.switch;
- device.updateState({
- status: status_1,
- bright: bright,
- });
- }
- else if (device instanceof CloudPowerDetectionSwitchController_1.default) {
- _c = tmp.params, current = _c.current, voltage = _c.voltage, power = _c.power, status_2 = _c.switch;
- logger_1.logger.info("Get power detection switch message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState({
- status: status_2,
- current: current,
- voltage: voltage,
- power: power,
- });
- }
- else if (device instanceof CloudMultiChannelSwitchController_1.default) {
- switches = tmp.params.switches;
- if (Array.isArray(switches)) {
- device.updateState(switches);
- }
- }
- else if (device instanceof CloudZigbeeMultiSwitchController_1.default) {
- switches = tmp.params.switches;
- if (Array.isArray(switches)) {
- device.updateState(switches);
- }
- }
- else if (device instanceof CloudRGBLightStripController_1.default) {
- logger_1.logger.info("Get lamp strip message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState(device.parseCkData2Ha(tmp.params));
- }
- else if (device instanceof CloudDoubleColorBulbController_1.default) {
- logger_1.logger.info("Get double color bulb message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudUIID104Controller_1.default) {
- logger_1.logger.info("Get UIID 104 message, params: ".concat(tmp.params));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudDualR3Controller_1.default || device instanceof LanDualR3Controller_1.default) {
- logger_1.logger.info("Get DualR3 message, params: ".concat(tmp.params));
- if (tmp.params && tmp.params.switches) {
- device.updateState(tmp.params.switches);
- }
- }
- else if (device instanceof CloudDW2WiFiController_1.default) {
- logger_1.logger.info("Get DW2 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudZigbeeUIID1000Controller_1.default) {
- logger_1.logger.info("Get Zigbee UIID 1000 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudZigbeeUIID1770Controller_1.default) {
- logger_1.logger.info("Get Zigbee UIID 1770 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudZigbeeUIID2026Controller_1.default) {
- logger_1.logger.info("Get Zigbee UIID 2026 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudZigbeeUIID3026Controller_1.default) {
- logger_1.logger.info("Get Zigbee UIID 3026 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudZigbeeUIID4026Controller_1.default) {
- logger_1.logger.info("Get Zigbee UIID 4026 message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudCoverController_1.default) {
- logger_1.logger.info("Get cover message, params: ".concat(tmp.params));
- if (tmp.params) {
- device.updateState(tmp.params);
- }
- }
- else if (device instanceof CloudRFBridgeController_1.default) {
- logger_1.logger.info("Get RF-Bridge message, params: ".concat(tmp.params));
- ids = device.parseCkData2Ha(tmp.params);
- device.updateState(ids);
- }
- else if (device instanceof CloudUIID34Controller_1.default) {
- logger_1.logger.info("Get UIID 34 message, params: ".concat(tmp.params));
- device.updateState(tmp.params.switches);
- }
- else if (device instanceof CloudUIID44Controller_1.default) {
- logger_1.logger.info("Get UIID 44 message, params: ".concat(tmp.params));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudZigbeeDoubleColorBulbController_1.default || device instanceof CloudZigbeeFiveColorBulbController_1.default) {
- logger_1.logger.info("Get UIID 1258 message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudUIID181Controller_1.default) {
- device.updateState(tmp.params.switch);
- }
- else if (device instanceof CloudUIID190Controller_1.default) {
- logger_1.logger.info("Get UIID 190 message, params: ".concat(JSON.stringify(tmp.params)));
- switches = tmp.params.switches;
- if (Array.isArray(switches)) {
- device.updateState(switches);
- }
- }
- else if (device instanceof CloudUIID137Controller_1.default) {
- logger_1.logger.info("Get UIID 137 message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudUIID173Controller_1.default) {
- logger_1.logger.info("Get UIID 173 message, params: ".concat(JSON.stringify(tmp.params)));
- device.updateState(tmp.params);
- }
- else if (device instanceof CloudUIID130Controller_1.default) {
- logger_1.logger.info("Get UIID 130 message, params: ".concat(JSON.stringify(tmp.params)));
- switches = tmp.params.switches;
- if (Array.isArray(switches)) {
- device.updateState(switches);
- }
- }
- else if (device instanceof CloudUIID182Controller_1.default) {
- logger_1.logger.info("Get UIID 182 message, params: ".concat(JSON.stringify(tmp.params)));
- switches = tmp.params.switches;
- if (Array.isArray(switches)) {
- device.updateState(switches);
- }
- }
- eventBus_1.default.emit('update-controller', data);
- }
- if (tmp.action === 'sysmsg' && (device === null || device === void 0 ? void 0 : device.entityId)) {
- _d = tmp.params, online = _d.online, name_1 = _d.name;
- if (device instanceof LanDeviceController_1.default || device instanceof CloudDeviceController_1.default) {
- (0, mergeDeviceParams_1.default)(device, { online: online, deviceName: name_1 });
- }
- if (online === false) {
- updateUnavailable2Ha = function (entityId) { return __awaiter(void 0, void 0, void 0, function () {
- var state, entityRes;
- return __generator(this, function (_a) {
- switch (_a.label) {
- case 0:
- state = 'unavailable';
- return [4, (0, restApi_1.getStateByEntityId)(entityId)];
- case 1:
- entityRes = _a.sent();
- if (entityRes && entityRes.data) {
- (0, restApi_1.updateStates)(entityId, {
- entity_id: entityId,
- state: state,
- attributes: __assign(__assign({}, entityRes.data.attributes), { state: state })
- });
- }
- return [2];
- }
- });
- }); };
- switches = lodash_1.default.get(device, ['params', 'switches'], undefined);
- if (switches && switches.length > 0) {
- channelNum = (0, channelMap_1.getMaxChannelByUiid)(device.uiid);
- for (i = 0; i < channelNum; i++) {
- updateUnavailable2Ha("".concat(device.entityId, "_").concat(i + 1));
- }
- }
- else {
- updateUnavailable2Ha(device.entityId);
- }
- eventBus_1.default.emit('device-offline', device.deviceId);
- }
- }
- eventBus_1.default.emit('sse');
- }
- }
- catch (error) {
- logger_1.logger.error("initCkWs error: ".concat(error));
- }
- return [2];
- });
- }); });
- return [2];
- }
- });
- }); });
|