supla-device
Loading...
Searching...
No Matches
proto.h
1/*
2 Copyright (C) AC SOFTWARE SP. Z O.O.
3
4 This program is free software; you can redistribute it and/or
5 modify it under the terms of the GNU General Public License
6 as published by the Free Software Foundation; either version 2
7 of the License, or (at your option) any later version.
8
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
13
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 */
18
19#ifndef supla_proto_H_
20#define supla_proto_H_
21
22#ifdef _WIN32
23// *** WINDOWS ***
24
25#include <WinSock2.h>
26#define _supla_int_t int
27#define _supla_int16_t short
28#define _supla_int64_t __int64
29#define _supla_timeval timeval
30
31#elif defined(__AVR__)
32// *** ARDUINO MEGA ***
33
34#define SPROTO_WITHOUT_OUT_BUFFER
35
36struct _supla_timeval {
37 long tv_sec[2];
38 long tv_usec[2];
39};
40
41#define timeval _supla_timeval
42
43#define _supla_int16_t int
44#define _supla_int_t long
45#define _supla_int64_t long long
46
47#elif defined(ESP8266) || defined(ESP32) || defined(ESP_PLATFORM)
48// *** Espressif NONOS SDK for ESP8266 OR ARDUINO WITH ESP8266 or ESP32 ***
49// *** ESP-IDF, ESP8266 RTOS SDK ***
50#ifndef ESP_PLATFORM
51#ifndef ARDUINO
52#include <mem.h>
53#define PROTO_ICACHE_FLASH ICACHE_FLASH_ATTR
54#endif /*ARDUINO*/
55#endif /*ESP_PLATFORM*/
56
57#if defined(ARDUINO) || defined(ESP_PLATFORM)
58// *** Only ARDUINO ESPxxx and ESP-IDS, RTOS SDK (NONOS is excluded) ***
59#define SPROTO_WITHOUT_OUT_BUFFER
60#endif /*ARDUINO_ARCH_ESP8266*/
61
62struct _supla_timeval {
63 long long tv_sec;
64 long long tv_usec;
65};
66
67#define _supla_int16_t short
68#define _supla_int_t int
69#define _supla_int64_t long long
70#elif defined(__arm__)
71// *** ARM - RPI? ***
72
73struct _supla_timeval {
74 long long tv_sec;
75 long long tv_usec;
76};
77
78#include <sys/time.h>
79#define _supla_int16_t short
80#define _supla_int_t int
81#define _supla_int64_t long long
82
83#else /*__arm__*/
84// *** OTHER? Linux, what else? ***
85#include <sys/time.h>
86#define _supla_int16_t short
87#define _supla_int_t int
88#define _supla_int64_t long long
89// timeval for 64 bit system
90#if __GNUC__
91#if __x86_64__ || __ppc64__
92#define _supla_timeval timeval
93#else
94// timeval for 32 bit system
95struct _supla_timeval {
96 long long tv_sec;
97 long long tv_usec;
98};
99
100#endif /* __x86_64__ || __ppc64__*/
101#endif /* __GNUC__*/
102#endif
103
104#ifndef PROTO_ICACHE_FLASH
105#define PROTO_ICACHE_FLASH
106#endif /*PROTO_ICACHE_FLASH*/
107
108#ifdef __cplusplus
109extern "C" {
110#endif
111
112#define SUPLA_TAG_SIZE 5
113extern char sproto_tag[SUPLA_TAG_SIZE];
114
115// DCS - device/client -> server
116// SDC - server -> device/client
117// DS - device -> server
118// SD - server -> device
119// CS - client -> server
120// SC - server -> client
121
122#define SUPLA_PROTO_VERSION 28
123#define SUPLA_PROTO_VERSION_MIN 1
124
125#if defined(ARDUINO_ARCH_AVR) || defined(ARDUINO) || defined(SUPLA_DEVICE)
126// All Arduino IDE and SuplaDevice compilations
127// Max packet size was reduced and register device is now send in chunks:
128// first is header, then channel data
129// SUPLA_MAX_DATA_SIZE should be bigger then calcfg, device config, channel
130// config MAXSIZE. Otherwise sending will fail
131#define SUPLA_MAX_DATA_SIZE 600 // Registration header without channels
132#elif defined(ESP8266)
133#define USE_DEPRECATED_EMEV_V2 // Temporary. It will be removed.
134// supla-espressif-esp compilations
135#define SUPLA_MAX_DATA_SIZE 1536
136#else
137#define SUPLA_MAX_DATA_SIZE 10240
138#endif
139#define SUPLA_RC_MAX_DEV_COUNT 50
140#define SUPLA_SOFTVER_MAXSIZE 21
141
142#define SUPLA_CAPTION_MAXSIZE 401
143
144#define SUPLA_GUID_SIZE 16
145#define SUPLA_GUID_HEXSIZE 33
146#define SUPLA_LOCATION_PWD_MAXSIZE 33
147#define SUPLA_ACCESSID_PWD_MAXSIZE 33
148#define SUPLA_LOCATION_CAPTION_MAXSIZE SUPLA_CAPTION_MAXSIZE
149#define SUPLA_LOCATIONPACK_MAXCOUNT 20
150#define SUPLA_CHANNEL_CAPTION_MAXSIZE SUPLA_CAPTION_MAXSIZE
151#define SUPLA_CHANNEL_GROUP_CAPTION_MAXSIZE SUPLA_CAPTION_MAXSIZE
152#define SUPLA_CHANNELPACK_MAXCOUNT 20
153#define SUPLA_URL_HOST_MAXSIZE 101
154#define SUPLA_URL_PATH_MAXSIZE 101
155#define SUPLA_SERVER_NAME_MAXSIZE 65
156#define SUPLA_EMAIL_MAXSIZE 256 // ver. >= 7
157#define SUPLA_PASSWORD_MAXSIZE 64 // ver. >= 10
158#define SUPLA_AUTHKEY_SIZE 16 // ver. >= 7
159#define SUPLA_AUTHKEY_HEXSIZE 33 // ver. >= 7
160#define SUPLA_OAUTH_TOKEN_MAXSIZE 256 // ver. >= 10
161#define SUPLA_CHANNELGROUP_PACK_MAXCOUNT 20 // ver. >= 9
162#define SUPLA_CHANNELGROUP_CAPTION_MAXSIZE 401 // ver. >= 9
163#define SUPLA_CHANNELVALUE_PACK_MAXCOUNT 20 // ver. >= 9
164#define SUPLA_CHANNELEXTENDEDVALUE_PACK_MAXCOUNT 5 // ver. >= 10
165#define SUPLA_CHANNELEXTENDEDVALUE_PACK_MAXDATASIZE \
166 (SUPLA_MAX_DATA_SIZE - 50) // ver. >= 10
167#define SUPLA_CALCFG_DATA_MAXSIZE 128 // ver. >= 10
168#define SUPLA_TIMEZONE_MAXSIZE 51 // ver. >= 11
169#define SUPLA_ACTION_PARAM_MAXSIZE 500 // ver. >= 18
170
171#ifndef SUPLA_CHANNELGROUP_RELATION_PACK_MAXCOUNT
172#define SUPLA_CHANNELGROUP_RELATION_PACK_MAXCOUNT 100 // ver. >= 9
173#endif /*SUPLA_CHANNELGROUP_RELATION_PACK_MAXCOUNT*/
174
175#define SUPLA_SCENE_CAPTION_MAXSIZE SUPLA_CAPTION_MAXSIZE // ver. >= 18
176#define SUPLA_SCENE_PACK_MAXCOUNT 20 // ver. >= 18
177#define SUPLA_SCENE_STATE_PACK_MAXCOUNT 20 // ver. >= 18
178
179#define SUPLA_CHANNEL_RELATION_PACK_MAXCOUNT 100 // ver. >= 21
180
181#define SUPLA_CHANNEL_STATE_PACK_MAXCOUNT 20 // ver. >= 26
182
183#define SUPLA_DCS_CALL_GETVERSION 10
184#define SUPLA_SDC_CALL_GETVERSION_RESULT 20
185#define SUPLA_SDC_CALL_VERSIONERROR 30
186#define SUPLA_DCS_CALL_PING_SERVER 40
187#define SUPLA_SDC_CALL_PING_SERVER_RESULT 50
188#define SUPLA_DS_CALL_REGISTER_DEVICE 60
189#define SUPLA_DS_CALL_REGISTER_DEVICE_B 65 // ver. >= 2
190#define SUPLA_DS_CALL_REGISTER_DEVICE_C 67 // ver. >= 6
191#define SUPLA_DS_CALL_REGISTER_DEVICE_D 68 // ver. >= 7
192#define SUPLA_DS_CALL_REGISTER_DEVICE_E 69 // ver. >= 10
193#define SUPLA_SD_CALL_REGISTER_DEVICE_RESULT 70
194#define SUPLA_SD_CALL_REGISTER_DEVICE_RESULT_B 71 // ver. >= 25
195#define SUPLA_DS_CALL_REGISTER_DEVICE_F 75 // ver. >= 23
196#define SUPLA_DS_CALL_REGISTER_DEVICE_G 76 // ver. >= 25
197#define SUPLA_CS_CALL_REGISTER_CLIENT 80
198#define SUPLA_CS_CALL_REGISTER_CLIENT_B 85 // ver. >= 6
199#define SUPLA_CS_CALL_REGISTER_CLIENT_C 86 // ver. >= 7
200#define SUPLA_CS_CALL_REGISTER_CLIENT_D 87 // ver. >= 12
201#define SUPLA_SC_CALL_REGISTER_CLIENT_RESULT 90
202#define SUPLA_SC_CALL_REGISTER_CLIENT_RESULT_B 92 // ver. >= 9
203#define SUPLA_SC_CALL_REGISTER_CLIENT_RESULT_C 94 // ver. >= 17
204#define SUPLA_SC_CALL_REGISTER_CLIENT_RESULT_D 96 // ver. >= 19
205#define SUPLA_DS_CALL_DEVICE_CHANNEL_VALUE_CHANGED 100
206#define SUPLA_DS_CALL_DEVICE_CHANNEL_VALUE_CHANGED_B 102 // ver. >= 12
207#define SUPLA_DS_CALL_DEVICE_CHANNEL_VALUE_CHANGED_C 103 // ver. >= 12
208#define SUPLA_DS_CALL_DEVICE_CHANNEL_EXTENDEDVALUE_CHANGED 105 // ver. >= 10
209#define SUPLA_SD_CALL_CHANNEL_SET_VALUE 110
210#define SUPLA_SD_CALL_CHANNELGROUP_SET_VALUE 115 // ver. >= 13
211#define SUPLA_DS_CALL_CHANNEL_SET_VALUE_RESULT 120
212#define SUPLA_SC_CALL_LOCATION_UPDATE 130
213#define SUPLA_SC_CALL_LOCATIONPACK_UPDATE 140
214#define SUPLA_SC_CALL_CHANNELPACK_UPDATE 160
215#define SUPLA_SC_CALL_CHANNEL_VALUE_UPDATE 170
216#define SUPLA_SC_CALL_CHANNEL_VALUE_UPDATE_B 171
217#define SUPLA_CS_CALL_GET_NEXT 180
218#define SUPLA_SC_CALL_EVENT 190
219#define SUPLA_CS_CALL_CHANNEL_SET_VALUE 200
220#define SUPLA_CS_CALL_CHANNEL_SET_VALUE_B 205 // ver. >= 3
221#define SUPLA_DCS_CALL_SET_ACTIVITY_TIMEOUT 210 // ver. >= 2
222#define SUPLA_SDC_CALL_SET_ACTIVITY_TIMEOUT_RESULT 220 // ver. >= 2
223#define SUPLA_DS_CALL_GET_FIRMWARE_UPDATE_URL 300 // ver. >= 5
224#define SUPLA_SD_CALL_GET_FIRMWARE_UPDATE_URL_RESULT 310 // ver. >= 5
225#define SUPLA_DCS_CALL_GET_REGISTRATION_ENABLED 320 // ver. >= 7
226#define SUPLA_SDC_CALL_GET_REGISTRATION_ENABLED_RESULT 330 // ver. >= 7
227#define SUPLA_CS_CALL_OAUTH_TOKEN_REQUEST 340 // ver. >= 10
228#define SUPLA_SC_CALL_OAUTH_TOKEN_REQUEST_RESULT 350 // ver. >= 10
229#define SUPLA_SC_CALL_CHANNELPACK_UPDATE_B 360 // ver. >= 8
230#define SUPLA_SC_CALL_CHANNELPACK_UPDATE_C 361 // ver. >= 10
231#define SUPLA_SC_CALL_CHANNELPACK_UPDATE_D 362 // ver. >= 15
232#define SUPLA_SC_CALL_CHANNELPACK_UPDATE_E 363 // ver. >= 23
233#define SUPLA_SC_CALL_CHANNELGROUP_PACK_UPDATE 380 // ver. >= 9
234#define SUPLA_SC_CALL_CHANNELGROUP_PACK_UPDATE_B 381 // ver. >= 10
235#define SUPLA_SC_CALL_CHANNELGROUP_RELATION_PACK_UPDATE 390 // ver. >= 9
236#define SUPLA_SC_CALL_CHANNEL_RELATION_PACK_UPDATE 395 // ver. >= 21
237#define SUPLA_SC_CALL_CHANNELVALUE_PACK_UPDATE 400 // ver. >= 9
238#define SUPLA_SC_CALL_CHANNELVALUE_PACK_UPDATE_B 401 // ver. >= 15
239#define SUPLA_SC_CALL_CHANNELEXTENDEDVALUE_PACK_UPDATE 405 // ver. >= 10
240#define SUPLA_SC_CALL_CHANNEL_STATE_PACK_UPDATE 408 // ver. >= 26
241#define SUPLA_CS_CALL_SET_VALUE 410 // ver. >= 9
242#define SUPLA_CS_CALL_SUPERUSER_AUTHORIZATION_REQUEST 420 // ver. >= 10
243#define SUPLA_CS_CALL_GET_SUPERUSER_AUTHORIZATION_RESULT 425 // ver. >= 12
244#define SUPLA_SC_CALL_SUPERUSER_AUTHORIZATION_RESULT 430 // ver. >= 10
245#define SUPLA_CS_CALL_DEVICE_CALCFG_REQUEST 440 // ver. >= 10
246#define SUPLA_CS_CALL_DEVICE_CALCFG_REQUEST_B 445 // ver. >= 11
247#define SUPLA_SC_CALL_DEVICE_CALCFG_RESULT 450 // ver. >= 10
248#define SUPLA_SD_CALL_DEVICE_CALCFG_REQUEST 460 // ver. >= 10
249#define SUPLA_DS_CALL_DEVICE_CALCFG_RESULT 470 // ver. >= 10
250#define SUPLA_DCS_CALL_GET_USER_LOCALTIME 480 // ver. >= 11
251#define SUPLA_DCS_CALL_GET_USER_LOCALTIME_RESULT 490 // ver. >= 11
252#define SUPLA_CSD_CALL_GET_CHANNEL_STATE 500 // ver. >= 12
253#define SUPLA_DSC_CALL_CHANNEL_STATE_RESULT 510 // ver. >= 12
254#define SUPLA_CS_CALL_GET_CHANNEL_BASIC_CFG 520 // ver. >= 12
255#define SUPLA_SC_CALL_CHANNEL_BASIC_CFG_RESULT 530 // ver. >= 12
256#define SUPLA_CS_CALL_SET_CHANNEL_FUNCTION 540 // ver. >= 12
257#define SUPLA_SC_CALL_SET_CHANNEL_FUNCTION_RESULT 550 // ver. >= 12
258#define SUPLA_CS_CALL_CLIENTS_RECONNECT_REQUEST 560 // ver. >= 12
259#define SUPLA_SC_CALL_CLIENTS_RECONNECT_REQUEST_RESULT 570 // ver. >= 12
260#define SUPLA_CS_CALL_SET_REGISTRATION_ENABLED 580 // ver. >= 12
261#define SUPLA_SC_CALL_SET_REGISTRATION_ENABLED_RESULT 590 // ver. >= 12
262#define SUPLA_CS_CALL_DEVICE_RECONNECT_REQUEST 600 // ver. >= 12
263#define SUPLA_SC_CALL_DEVICE_RECONNECT_REQUEST_RESULT 610 // ver. >= 12
264#define SUPLA_DS_CALL_GET_CHANNEL_FUNCTIONS 620 // ver. >= 12
265#define SUPLA_SD_CALL_GET_CHANNEL_FUNCTIONS_RESULT 630 // ver. >= 12
266#define SUPLA_DCS_CALL_SET_CHANNEL_CAPTION 640 // ver. >= 12
267#define SUPLA_SCD_CALL_SET_CHANNEL_CAPTION_RESULT 650 // ver. >= 12
268#define SUPLA_CS_CALL_SET_CHANNEL_GROUP_CAPTION 642 // ver. >= 20
269#define SUPLA_SC_CALL_SET_CHANNEL_GROUP_CAPTION_RESULT 652 // ver. >= 20
270#define SUPLA_CS_CALL_SET_LOCATION_CAPTION 645 // ver. >= 14
271#define SUPLA_SC_CALL_SET_LOCATION_CAPTION_RESULT 655 // ver. >= 14
272#define SUPLA_DS_CALL_GET_CHANNEL_CONFIG 680 // ver. >= 16
273#define SUPLA_SD_CALL_GET_CHANNEL_CONFIG_RESULT 690 // ver. >= 16
274#define SUPLA_DS_CALL_SET_CHANNEL_CONFIG 681 // ver. >= 21
275#define SUPLA_SD_CALL_SET_CHANNEL_CONFIG_RESULT 691 // ver. >= 21
276#define SUPLA_SD_CALL_SET_CHANNEL_CONFIG 682 // ver. >= 21
277#define SUPLA_DS_CALL_SET_CHANNEL_CONFIG_RESULT 692 // ver. >= 21
278#define SUPLA_SD_CALL_CHANNEL_CONFIG_FINISHED 683 // ver. >= 21
279#define SUPLA_DS_CALL_SET_DEVICE_CONFIG 684 // ver. >= 21
280#define SUPLA_SD_CALL_SET_DEVICE_CONFIG_RESULT 694 // ver. >= 21
281#define SUPLA_SD_CALL_SET_DEVICE_CONFIG 685 // ver. >= 21
282#define SUPLA_DS_CALL_SET_DEVICE_CONFIG_RESULT 695 // ver. >= 21
283#define SUPLA_DS_CALL_ACTIONTRIGGER 700 // ver. >= 16
284#define SUPLA_CS_CALL_TIMER_ARM 800 // ver. >= 17
285#define SUPLA_SC_CALL_SCENE_PACK_UPDATE 900 // ver. >= 18
286#define SUPLA_SC_CALL_SCENE_STATE_PACK_UPDATE 910 // ver. >= 18
287#define SUPLA_CS_CALL_EXECUTE_ACTION 1000 // ver. >= 19
288#define SUPLA_CS_CALL_EXECUTE_ACTION_WITH_AUTH 1010 // ver. >= 19
289#define SUPLA_SC_CALL_ACTION_EXECUTION_RESULT 1020 // ver. >= 19
290#define SUPLA_CS_CALL_GET_CHANNEL_VALUE_WITH_AUTH 1030 // ver. >= 19
291#define SUPLA_SC_CALL_GET_CHANNEL_VALUE_RESULT 1040 // ver. >= 19
292#define SUPLA_CS_CALL_SET_SCENE_CAPTION 1045 // ver. >= 19
293#define SUPLA_SC_CALL_SET_SCENE_CAPTION_RESULT 1055 // ver. >= 19
294#define SUPLA_DS_CALL_REGISTER_PUSH_NOTIFICATION 1100 // ver. >= 20
295#define SUPLA_DS_CALL_SEND_PUSH_NOTIFICATION 1110 // ver. >= 20
296#define SUPLA_CS_CALL_REGISTER_PN_CLIENT_TOKEN 1120 // ver. >= 20
297#define SUPLA_SC_CALL_REGISTER_PN_CLIENT_TOKEN_RESULT 1121 // ver. >= 20
298#define SUPLA_CS_CALL_GET_CHANNEL_CONFIG 1200 // ver. >= 21
299#define SUPLA_SC_CALL_CHANNEL_CONFIG_UPDATE_OR_RESULT 1210 // ver. >= 21
300#define SUPLA_CS_CALL_SET_CHANNEL_CONFIG 1220 // ver. >= 21
301#define SUPLA_CS_CALL_GET_DEVICE_CONFIG 1240 // ver. >= 21
302#define SUPLA_SC_CALL_DEVICE_CONFIG_UPDATE_OR_RESULT 1250 // ver. >= 21
303#define SUPLA_DS_CALL_SET_SUBDEVICE_DETAILS 1260 // ver. >= 25
304
305#define SUPLA_RESULT_RESPONSE_TIMEOUT -8
306#define SUPLA_RESULT_CANT_CONNECT_TO_HOST -7
307#define SUPLA_RESULT_HOST_NOT_FOUND -6
308#define SUPLA_RESULT_CALL_NOT_ALLOWED -5
309#define SUPLA_RESULT_DATA_TOO_LARGE -4
310#define SUPLA_RESULT_BUFFER_OVERFLOW -3
311#define SUPLA_RESULT_DATA_ERROR -2
312#define SUPLA_RESULT_VERSION_ERROR -1
313#define SUPLA_RESULT_FALSE 0
314#define SUPLA_RESULT_TRUE 1
315
316// SUPLA_RESULTCODE_ are sent in TSuplaDataPacket.data (unsigned char)
317#define SUPLA_RESULTCODE_NONE 0
318#define SUPLA_RESULTCODE_UNSUPORTED 1
319#define SUPLA_RESULTCODE_FALSE 2
320#define SUPLA_RESULTCODE_TRUE 3
321#define SUPLA_RESULTCODE_TEMPORARILY_UNAVAILABLE 4
322#define SUPLA_RESULTCODE_BAD_CREDENTIALS 5
323#define SUPLA_RESULTCODE_LOCATION_CONFLICT 6
324#define SUPLA_RESULTCODE_CHANNEL_CONFLICT 7
325#define SUPLA_RESULTCODE_DEVICE_DISABLED 8
326#define SUPLA_RESULTCODE_ACCESSID_DISABLED 9
327#define SUPLA_RESULTCODE_LOCATION_DISABLED 10
328#define SUPLA_RESULTCODE_CLIENT_DISABLED 11
329#define SUPLA_RESULTCODE_CLIENT_LIMITEXCEEDED 12
330#define SUPLA_RESULTCODE_DEVICE_LIMITEXCEEDED 13
331#define SUPLA_RESULTCODE_GUID_ERROR 14
332#define SUPLA_RESULTCODE_DEVICE_LOCKED 15 // ver. >= 22
333#define SUPLA_RESULTCODE_REGISTRATION_DISABLED 17 // ver. >= 7
334#define SUPLA_RESULTCODE_ACCESSID_NOT_ASSIGNED 18 // ver. >= 7
335#define SUPLA_RESULTCODE_AUTHKEY_ERROR 19 // ver. >= 7
336#define SUPLA_RESULTCODE_NO_LOCATION_AVAILABLE 20 // ver. >= 7
337#define SUPLA_RESULTCODE_USER_CONFLICT 21 // Deprecated
338#define SUPLA_RESULTCODE_UNAUTHORIZED 22 // ver. >= 10
339#define SUPLA_RESULTCODE_AUTHORIZED 23 // ver. >= 10
340#define SUPLA_RESULTCODE_NOT_ALLOWED 24 // ver. >= 12
341#define SUPLA_RESULTCODE_CHANNELNOTFOUND 25 // ver. >= 12
342#define SUPLA_RESULTCODE_UNKNOWN_ERROR 26 // ver. >= 12
343#define SUPLA_RESULTCODE_DENY_CHANNEL_BELONG_TO_GROUP 27 // ver. >= 12
344#define SUPLA_RESULTCODE_DENY_CHANNEL_HAS_SCHEDULE 28 // ver. >= 12
345#define SUPLA_RESULTCODE_DENY_CHANNEL_IS_ASSOCIETED_WITH_SCENE 29 // ver. >= 12
346#define SUPLA_RESULTCODE_DENY_CHANNEL_IS_ASSOCIETED_WITH_ACTION_TRIGGER \
347 30 // ver. >= 16
348#define SUPLA_RESULTCODE_INACTIVE 31 // ver. >= 17
349#define SUPLA_RESULTCODE_CFG_MODE_REQUESTED 32 // ver. >= 18
350#define SUPLA_RESULTCODE_ACTION_UNSUPPORTED 33 // ver. >= 19
351#define SUPLA_RESULTCODE_SUBJECT_NOT_FOUND 34 // ver. >= 19
352#define SUPLA_RESULTCODE_INCORRECT_PARAMETERS 35 // ver. >= 19
353#define SUPLA_RESULTCODE_CLIENT_NOT_EXISTS 36 // ver. >= 19
354#define SUPLA_RESULTCODE_COUNTRY_REJECTED 37
355#define SUPLA_RESULTCODE_CHANNEL_IS_OFFLINE 38 // ver. >= 19
356#define SUPLA_RESULTCODE_NOT_REGISTERED 39 // ver. >= 20
357#define SUPLA_RESULTCODE_DENY_CHANNEL_IS_ASSOCIETED_WITH_VBT 40 // >= 20
358#define SUPLA_RESULTCODE_DENY_CHANNEL_IS_ASSOCIETED_WITH_PUSH 41 // >= 20
359#define SUPLA_RESULTCODE_RESTART_REQUESTED 42 // ver. >= 25
360#define SUPLA_RESULTCODE_IDENTIFY_REQUESTED 43 // ver. >= 25
361#define SUPLA_RESULTCODE_MALFORMED_EMAIL 44 // ver. >= ?
362#define SUPLA_RESULTCODE_RESET_TO_FACTORY_SETTINGS 45 // ver. >= 28
363
364#define SUPLA_OAUTH_RESULTCODE_ERROR 0 // ver. >= 10
365#define SUPLA_OAUTH_RESULTCODE_SUCCESS 1 // ver. >= 10
366#define SUPLA_OAUTH_TEMPORARILY_UNAVAILABLE 2 // ver. >= 10
367
368#define SUPLA_DEVICE_NAME_MAXSIZE 201
369#define SUPLA_CLIENT_NAME_MAXSIZE 201
370#define SUPLA_SENDER_NAME_MAXSIZE 201
371#define SUPLA_INITIATOR_NAME_MAXSIZE SUPLA_SENDER_NAME_MAXSIZE
372
373#define SUPLA_CHANNELMAXCOUNT 128
374
375#define SUPLA_CHANNELVALUE_SIZE 8
376
377#if defined(__AVR__) || defined(ESP8266) || defined(ESP32) || \
378 defined(ESP_PLATFORM) || defined(ARDUINO) || defined(SUPLA_DEVICE)
379#define SUPLA_CHANNELEXTENDEDVALUE_SIZE 256
380#else
381#define SUPLA_CHANNELEXTENDEDVALUE_SIZE 1024
382#endif
383
384#define SUPLA_CHANNELTYPE_SENSORNO 1000 // name DEPRECATED
385// use BINARYSENSOR instead
386#define SUPLA_CHANNELTYPE_BINARYSENSOR 1000
387#define SUPLA_CHANNELTYPE_SENSORNC 1010 // DEPRECATED
388#define SUPLA_CHANNELTYPE_DISTANCESENSOR 1020 // ver. >= 5
389#define SUPLA_CHANNELTYPE_CALLBUTTON 1500 // ver. >= 4
390#define SUPLA_CHANNELTYPE_RELAYHFD4 2000 // DEPRECATED
391#define SUPLA_CHANNELTYPE_RELAYG5LA1A 2010 // DEPRECATED
392#define SUPLA_CHANNELTYPE_2XRELAYG5LA1A 2020 // DEPRECATED
393#define SUPLA_CHANNELTYPE_RELAY 2900
394#define SUPLA_CHANNELTYPE_THERMOMETERDS18B20 3000 // DEPRECATED
395#define SUPLA_CHANNELTYPE_DHT11 3010 // ver. >= 4 DEPRECATED
396#define SUPLA_CHANNELTYPE_DHT22 3020 // ver. >= 4 DEPRECATED
397#define SUPLA_CHANNELTYPE_DHT21 3022 // ver. >= 5 DEPRECATED
398#define SUPLA_CHANNELTYPE_AM2302 3030 // ver. >= 4 DEPRECATED
399#define SUPLA_CHANNELTYPE_AM2301 3032 // ver. >= 5 DEPRECATED
400
401#define SUPLA_CHANNELTYPE_THERMOMETER 3034 // ver. >= 8
402#define SUPLA_CHANNELTYPE_HUMIDITYSENSOR 3036 // ver. >= 8
403#define SUPLA_CHANNELTYPE_HUMIDITYANDTEMPSENSOR 3038 // ver. >= 8
404#define SUPLA_CHANNELTYPE_WINDSENSOR 3042 // ver. >= 8
405#define SUPLA_CHANNELTYPE_PRESSURESENSOR 3044 // ver. >= 8
406#define SUPLA_CHANNELTYPE_RAINSENSOR 3048 // ver. >= 8
407#define SUPLA_CHANNELTYPE_WEIGHTSENSOR 3050 // ver. >= 8
408#define SUPLA_CHANNELTYPE_WEATHER_STATION 3100 // ver. >= 8
409#define SUPLA_CHANNELTYPE_CONTAINER 3200 // ver. >= 26
410
411// Since ver. >= 28 channel types DIMMER, RGBLIGHTING, DIMMERANDRGBLIGHTING
412// support all RGBW/dimmer related functions, when their RGBW_FuncList is != 0.
413// List of supported functions should be determined based on the RGBW_FuncList
414// bitmap value.
415#define SUPLA_CHANNELTYPE_DIMMER 4000 // ver. >= 4
416#define SUPLA_CHANNELTYPE_RGBLEDCONTROLLER 4010 // ver. >= 4
417#define SUPLA_CHANNELTYPE_DIMMERANDRGBLED 4020 // ver. >= 4
418
419#define SUPLA_CHANNELTYPE_ELECTRICITY_METER 5000 // ver. >= 10
420#define SUPLA_CHANNELTYPE_IMPULSE_COUNTER 5010 // ver. >= 10
421
422#define SUPLA_CHANNELTYPE_THERMOSTAT 6000 // ver. >= 11
423#define SUPLA_CHANNELTYPE_THERMOSTAT_HEATPOL_HOMEPLUS 6010 // ver. >= 11
424#define SUPLA_CHANNELTYPE_HVAC 6100 // ver. >= 21
425
426#define SUPLA_CHANNELTYPE_VALVE_OPENCLOSE 7000 // ver. >= 12
427#define SUPLA_CHANNELTYPE_VALVE_PERCENTAGE 7010 // ver. >= 12
428#define SUPLA_CHANNELTYPE_BRIDGE 8000 // ver. >= 12
429#define SUPLA_CHANNELTYPE_GENERAL_PURPOSE_MEASUREMENT 9000 // ver. >= 23
430#define SUPLA_CHANNELTYPE_GENERAL_PURPOSE_METER 9010 // ver. >= 23
431#define SUPLA_CHANNELTYPE_ENGINE 10000 // ver. >= 12
432#define SUPLA_CHANNELTYPE_ACTIONTRIGGER 11000 // ver. >= 16
433#define SUPLA_CHANNELTYPE_DIGIGLASS 12000 // ver. >= 12
434
435#define SUPLA_CHANNELDRIVER_MCP23008 2
436
437#define SUPLA_CHANNELFNC_NONE 0
438#define SUPLA_CHANNELFNC_CONTROLLINGTHEGATEWAYLOCK 10
439#define SUPLA_CHANNELFNC_CONTROLLINGTHEGATE 20
440#define SUPLA_CHANNELFNC_CONTROLLINGTHEGARAGEDOOR 30
441#define SUPLA_CHANNELFNC_THERMOMETER 40
442#define SUPLA_CHANNELFNC_HUMIDITY 42
443#define SUPLA_CHANNELFNC_HUMIDITYANDTEMPERATURE 45
444#define SUPLA_CHANNELFNC_OPENINGSENSOR_GATEWAY 50
445#define SUPLA_CHANNELFNC_OPENINGSENSOR_GATE 60
446#define SUPLA_CHANNELFNC_OPENINGSENSOR_GARAGEDOOR 70
447#define SUPLA_CHANNELFNC_NOLIQUIDSENSOR 80
448#define SUPLA_CHANNELFNC_CONTROLLINGTHEDOORLOCK 90
449#define SUPLA_CHANNELFNC_OPENINGSENSOR_DOOR 100
450#define SUPLA_CHANNELFNC_CONTROLLINGTHEROLLERSHUTTER 110
451#define SUPLA_CHANNELFNC_CONTROLLINGTHEROOFWINDOW 115 // ver. >= 13
452#define SUPLA_CHANNELFNC_OPENINGSENSOR_ROLLERSHUTTER 120
453#define SUPLA_CHANNELFNC_OPENINGSENSOR_ROOFWINDOW 125 // ver. >= 13
454#define SUPLA_CHANNELFNC_POWERSWITCH 130
455#define SUPLA_CHANNELFNC_LIGHTSWITCH 140
456#define SUPLA_CHANNELFNC_RING 150
457#define SUPLA_CHANNELFNC_ALARM 160
458#define SUPLA_CHANNELFNC_NOTIFICATION 170
459#define SUPLA_CHANNELFNC_DIMMER 180
460#define SUPLA_CHANNELFNC_DIMMER_CCT 185 // ver. >= 28
461#define SUPLA_CHANNELFNC_RGBLIGHTING 190
462#define SUPLA_CHANNELFNC_DIMMERANDRGBLIGHTING 200
463#define SUPLA_CHANNELFNC_DIMMER_CCT_AND_RGB 205 // ver. >= 28
464#define SUPLA_CHANNELFNC_DEPTHSENSOR 210 // ver. >= 5
465#define SUPLA_CHANNELFNC_DISTANCESENSOR 220 // ver. >= 5
466#define SUPLA_CHANNELFNC_OPENINGSENSOR_WINDOW 230 // ver. >= 8
467#define SUPLA_CHANNELFNC_HOTELCARDSENSOR 235 // ver. >= 21
468#define SUPLA_CHANNELFNC_ALARMARMAMENTSENSOR 236 // ver. >= 21
469#define SUPLA_CHANNELFNC_MAILSENSOR 240 // ver. >= 8
470#define SUPLA_CHANNELFNC_WINDSENSOR 250 // ver. >= 8
471#define SUPLA_CHANNELFNC_PRESSURESENSOR 260 // ver. >= 8
472#define SUPLA_CHANNELFNC_RAINSENSOR 270 // ver. >= 8
473#define SUPLA_CHANNELFNC_WEIGHTSENSOR 280 // ver. >= 8
474#define SUPLA_CHANNELFNC_WEATHER_STATION 290 // ver. >= 8
475#define SUPLA_CHANNELFNC_STAIRCASETIMER 300 // ver. >= 8
476#define SUPLA_CHANNELFNC_ELECTRICITY_METER 310 // ver. >= 10
477#define SUPLA_CHANNELFNC_IC_ELECTRICITY_METER 315 // ver. >= 12
478#define SUPLA_CHANNELFNC_IC_GAS_METER 320 // ver. >= 10
479#define SUPLA_CHANNELFNC_IC_WATER_METER 330 // ver. >= 10
480#define SUPLA_CHANNELFNC_IC_HEAT_METER 340 // ver. >= 10
481#define SUPLA_CHANNELFNC_IC_EVENTS 350 // ver. >= 21
482#define SUPLA_CHANNELFNC_IC_SECONDS 360 // ver. >= 21
483#define SUPLA_CHANNELFNC_THERMOSTAT_HEATPOL_HOMEPLUS 410 // ver. >= 11
484#define SUPLA_CHANNELFNC_HVAC_THERMOSTAT 420 // ver. >= 21
485#define SUPLA_CHANNELFNC_HVAC_THERMOSTAT_HEAT_COOL 422 // ver. >= 21
486#define SUPLA_CHANNELFNC_HVAC_DRYER 423 // ver. >= 21
487#define SUPLA_CHANNELFNC_HVAC_FAN 424 // ver. >= 21
488#define SUPLA_CHANNELFNC_HVAC_THERMOSTAT_DIFFERENTIAL 425 // ver. >= 21
489#define SUPLA_CHANNELFNC_HVAC_DOMESTIC_HOT_WATER 426 // ver. >= 21
490#define SUPLA_CHANNELFNC_VALVE_OPENCLOSE 500 // ver. >= 12
491#define SUPLA_CHANNELFNC_VALVE_PERCENTAGE 510 // ver. >= 12
492#define SUPLA_CHANNELFNC_GENERAL_PURPOSE_MEASUREMENT 520 // ver. >= 23
493#define SUPLA_CHANNELFNC_GENERAL_PURPOSE_METER 530 // ver. >= 23
494#define SUPLA_CHANNELFNC_CONTROLLINGTHEENGINESPEED 600 // ver. >= 12
495#define SUPLA_CHANNELFNC_ACTIONTRIGGER 700 // ver. >= 16
496#define SUPLA_CHANNELFNC_DIGIGLASS_HORIZONTAL 800 // ver. >= 14
497#define SUPLA_CHANNELFNC_DIGIGLASS_VERTICAL 810 // ver. >= 14
498#define SUPLA_CHANNELFNC_CONTROLLINGTHEFACADEBLIND 900 // ver. >= 24
499#define SUPLA_CHANNELFNC_TERRACE_AWNING 910 // ver. >= 24
500#define SUPLA_CHANNELFNC_PROJECTOR_SCREEN 920 // ver. >= 24
501#define SUPLA_CHANNELFNC_CURTAIN 930 // ver. >= 24
502#define SUPLA_CHANNELFNC_VERTICAL_BLIND 940 // ver. >= 24
503#define SUPLA_CHANNELFNC_ROLLER_GARAGE_DOOR 950 // ver. >= 24
504#define SUPLA_CHANNELFNC_PUMPSWITCH 960 // ver. >= 25
505#define SUPLA_CHANNELFNC_HEATORCOLDSOURCESWITCH 970 // ver. >= 25
506#define SUPLA_CHANNELFNC_CONTAINER 980 // ver. >= 26
507#define SUPLA_CHANNELFNC_SEPTIC_TANK 981 // ver. >= 26
508#define SUPLA_CHANNELFNC_WATER_TANK 982 // ver. >= 26
509#define SUPLA_CHANNELFNC_CONTAINER_LEVEL_SENSOR 990 // ver. >= 26
510#define SUPLA_CHANNELFNC_FLOOD_SENSOR 1000 // ver. >= 27
511#define SUPLA_CHANNELFNC_MOTION_SENSOR 1010 // ver. >= 27
512#define SUPLA_CHANNELFNC_BINARY_SENSOR 1020 // ver. >= 27
513
514// Channel's FuncList bit values:
515#define SUPLA_BIT_FUNC_CONTROLLINGTHEGATEWAYLOCK 0x00000001
516#define SUPLA_BIT_FUNC_CONTROLLINGTHEGATE 0x00000002
517#define SUPLA_BIT_FUNC_CONTROLLINGTHEGARAGEDOOR 0x00000004
518#define SUPLA_BIT_FUNC_CONTROLLINGTHEDOORLOCK 0x00000008
519#define SUPLA_BIT_FUNC_CONTROLLINGTHEROLLERSHUTTER 0x00000010
520#define SUPLA_BIT_FUNC_POWERSWITCH 0x00000020
521#define SUPLA_BIT_FUNC_LIGHTSWITCH 0x00000040
522#define SUPLA_BIT_FUNC_STAIRCASETIMER 0x00000080 // ver. >= 8
523#define SUPLA_BIT_FUNC_THERMOMETER 0x00000100 // ver. >= 12
524#define SUPLA_BIT_FUNC_HUMIDITYANDTEMPERATURE 0x00000200 // ver. >= 12
525#define SUPLA_BIT_FUNC_HUMIDITY 0x00000400 // ver. >= 12
526#define SUPLA_BIT_FUNC_WINDSENSOR 0x00000800 // ver. >= 12
527#define SUPLA_BIT_FUNC_PRESSURESENSOR 0x00001000 // ver. >= 12
528#define SUPLA_BIT_FUNC_RAINSENSOR 0x00002000 // ver. >= 12
529#define SUPLA_BIT_FUNC_WEIGHTSENSOR 0x00004000 // ver. >= 12
530#define SUPLA_BIT_FUNC_CONTROLLINGTHEROOFWINDOW 0x00008000 // ver. >= 13
531#define SUPLA_BIT_FUNC_CONTROLLINGTHEFACADEBLIND 0x00010000 // ver. >= 17
532#define SUPLA_BIT_FUNC_HVAC_THERMOSTAT 0x00020000 // ver. >= 21
533#define SUPLA_BIT_FUNC_HVAC_THERMOSTAT_HEAT_COOL 0x00040000 // ver. >= 21
534#define SUPLA_BIT_FUNC_HVAC_THERMOSTAT_DIFFERENTIAL 0x00080000 // ver. >= 21
535#define SUPLA_BIT_FUNC_HVAC_DOMESTIC_HOT_WATER 0x00100000 // ver. >= 21
536#define SUPLA_BIT_FUNC_TERRACE_AWNING 0x00200000 // ver. >= 24
537#define SUPLA_BIT_FUNC_PROJECTOR_SCREEN 0x00400000 // ver. >= 24
538#define SUPLA_BIT_FUNC_CURTAIN 0x00800000 // ver. >= 24
539#define SUPLA_BIT_FUNC_VERTICAL_BLIND 0x01000000 // ver. >= 24
540#define SUPLA_BIT_FUNC_ROLLER_GARAGE_DOOR 0x02000000 // ver. >= 24
541#define SUPLA_BIT_FUNC_PUMPSWITCH 0x04000000 // ver. >= 25
542#define SUPLA_BIT_FUNC_HEATORCOLDSOURCESWITCH 0x08000000 // ver. >= 25
543
544// Channel's RGBW_FuncList bit values (only for SUPLA_CHANNELTYPE_DIMMER,
545// SUPLA_CHANNELTYPE_RGBLEDCONTROLLER, SUPLA_CHANNELTYPE_DIMMERANDRGBLED):
546#define SUPLA_RGBW_BIT_FUNC_DIMMER 0x00000001 // ver. >= 28
547#define SUPLA_RGBW_BIT_FUNC_RGB_LIGHTING 0x00000002 // ver. >= 28
548#define SUPLA_RGBW_BIT_FUNC_DIMMER_AND_RGB_LIGHTING 0x00000004 // ver. >= 28
549#define SUPLA_RGBW_BIT_FUNC_DIMMER_CCT 0x00000008 // ver. >= 28
550#define SUPLA_RGBW_BIT_FUNC_DIMMER_CCT_AND_RGB 0x00000010 // ver. >= 28
551
552#define SUPLA_EVENT_CONTROLLINGTHEGATEWAYLOCK 10
553#define SUPLA_EVENT_CONTROLLINGTHEGATE 20
554#define SUPLA_EVENT_CONTROLLINGTHEGARAGEDOOR 30
555#define SUPLA_EVENT_CONTROLLINGTHEDOORLOCK 40
556#define SUPLA_EVENT_CONTROLLINGTHEROLLERSHUTTER 50
557#define SUPLA_EVENT_TERRACE_AWNING 51 // ver. >= 24
558#define SUPLA_EVENT_CURTAIN 52 // ver. >= 24
559#define SUPLA_EVENT_PROJECTOR_SCREEN 53 // ver. >= 24
560#define SUPLA_EVENT_ROLLER_GARAGE_DOOR 54 // ver. >= 24
561#define SUPLA_EVENT_CONTROLLINGTHEROOFWINDOW 55
562#define SUPLA_EVENT_CONTROLLINGTHEFACADEBLIND 56 // ver. >= 24
563#define SUPLA_EVENT_VERTICAL_BLIND 57 // ver. >= 24
564#define SUPLA_EVENT_POWERONOFF 60
565#define SUPLA_EVENT_LIGHTONOFF 70
566#define SUPLA_EVENT_STAIRCASETIMERONOFF 80 // ver. >= 9
567#define SUPLA_EVENT_VALVEOPENCLOSE 90 // ver. >= 12
568#define SUPLA_EVENT_SET_BRIDGE_VALUE_FAILED 100 // ver. >= 12
569
570#define SUPLA_URL_PROTO_HTTP 0x01
571#define SUPLA_URL_PROTO_HTTPS 0x02
572
573#define SUPLA_PLATFORM_UNKNOWN 0
574#define SUPLA_PLATFORM_ESP8266 1
575
576#define SUPLA_TARGET_CHANNEL 0
577#define SUPLA_TARGET_GROUP 1
578#define SUPLA_TARGET_IODEVICE 2
579
580#define SUPLA_MFR_UNKNOWN 0
581#define SUPLA_MFR_ACSOFTWARE 1
582#define SUPLA_MFR_TRANSCOM 2
583#define SUPLA_MFR_LOGI 3
584#define SUPLA_MFR_ZAMEL 4
585#define SUPLA_MFR_NICE 5
586#define SUPLA_MFR_ITEAD 6
587#define SUPLA_MFR_DOYLETRATT 7
588#define SUPLA_MFR_HEATPOL 8
589#define SUPLA_MFR_FAKRO 9
590#define SUPLA_MFR_PEVEKO 10
591#define SUPLA_MFR_WEKTA 11
592#define SUPLA_MFR_STA_SYSTEM 12
593#define SUPLA_MFR_DGF 13
594#define SUPLA_MFR_COMELIT 14
595#define SUPLA_MFR_POLIER 15
596#define SUPLA_MFR_ERGO_ENERGIA 16
597#define SUPLA_MFR_SOMEF 17
598#define SUPLA_MFR_AURATON 18
599#define SUPLA_MFR_HPD 19
600#define SUPLA_MFR_LUKFUD 20
601#define SUPLA_MFR_WALA 21
602
603// BIT map definition for TDS_SuplaRegisterDevice_*::Flags (32 bit)
604#define SUPLA_DEVICE_FLAG_CALCFG_ENTER_CFG_MODE 0x0010 // ver. >= 17
605#define SUPLA_DEVICE_FLAG_SLEEP_MODE_ENABLED 0x0020 // ver. >= 18
606#define SUPLA_DEVICE_FLAG_CALCFG_SET_TIME 0x0040 // ver. >= 21
607#define SUPLA_DEVICE_FLAG_DEVICE_CONFIG_SUPPORTED 0x0080 // ver. >= 21
608#define SUPLA_DEVICE_FLAG_DEVICE_LOCKED 0x0100 // ver. >= 22
609#define SUPLA_DEVICE_FLAG_CALCFG_SUBDEVICE_PAIRING 0x0200 // ver. >= 25
610#define SUPLA_DEVICE_FLAG_CALCFG_IDENTIFY_DEVICE 0x0400 // ver. >= 25
611#define SUPLA_DEVICE_FLAG_CALCFG_RESTART_DEVICE 0x0800 // ver. >= 25
612#define SUPLA_DEVICE_FLAG_ALWAYS_ALLOW_CHANNEL_DELETION 0x1000 // ver. >= 25
613#define SUPLA_DEVICE_FLAG_BLOCK_ADDING_CHANNELS_AFTER_DELETION \
614 0x2000 // ver. >= 25
615#define SUPLA_DEVICE_FLAG_CALCFG_FACTORY_RESET_SUPPORTED 0x4000 // ver. >= 28
616#define SUPLA_DEVICE_FLAG_AUTOMATIC_FIRMWARE_UPDATE_SUPPORTED \
617 0x8000 // ver. >= 28
618#define SUPLA_DEVICE_FLAG_CALCFG_SET_CFG_MODE_PASSWORD_SUPPORTED \
619 0x10000 // ver. >= 28
620
621// BIT map definition for TDS_SuplaRegisterDevice_F::ConfigFields (64 bit)
622// type: TDeviceConfig_StatusLed
623#define SUPLA_DEVICE_CONFIG_FIELD_STATUS_LED (1ULL << 0) // v. >= 21
624// type: TDeviceConfig_ScreenBrightness
625#define SUPLA_DEVICE_CONFIG_FIELD_SCREEN_BRIGHTNESS (1ULL << 1) // v. >= 21
626// type: TDeviceConfig_ButtonVolume
627#define SUPLA_DEVICE_CONFIG_FIELD_BUTTON_VOLUME (1ULL << 2) // v. >= 21
628// type: TDeviceConfig_DisableUserInterface
629#define SUPLA_DEVICE_CONFIG_FIELD_DISABLE_USER_INTERFACE \
630 (1ULL << 3) // v. >= 21
631// type: TDeviceConfig_AutomaticTimeSync
632#define SUPLA_DEVICE_CONFIG_FIELD_AUTOMATIC_TIME_SYNC (1ULL << 4) // v. >= 21
633// type: TDeviceConfig_HomeScreenOffDelay
634#define SUPLA_DEVICE_CONFIG_FIELD_HOME_SCREEN_OFF_DELAY (1ULL << 5) // v. >= 21
635// type: TDeviceConfig_HomeScreenContent
636#define SUPLA_DEVICE_CONFIG_FIELD_HOME_SCREEN_CONTENT (1ULL << 6) // v. >= 21
637// type: TDeviceConfig_HomeScreenOffDelayType
638#define SUPLA_DEVICE_CONFIG_FIELD_HOME_SCREEN_OFF_DELAY_TYPE \
639 (1ULL << 7) // v. >= 24
640// type: TDeviceConfig_PowerStatusLed
641#define SUPLA_DEVICE_CONFIG_FIELD_POWER_STATUS_LED (1ULL << 8) // v. >= 25
642// type: TDeviceConfig_Modbus
643#define SUPLA_DEVICE_CONFIG_FIELD_MODBUS (1ULL << 9) // v. >= 27
644// type: TDeviceConfig_FirmwareUpdate
645#define SUPLA_DEVICE_CONFIG_FIELD_FIRMWARE_UPDATE (1ULL << 10) // v. >= 28
646
647// BIT map definition for TDS_SuplaDeviceChannel_C::Flags (32 bit)
648// BIT map definition for TDS_SuplaDeviceChannel_D::Flags (64 bit)
649// BIT map definition for TDS_SuplaDeviceChannel_E::Flags (64 bit)
650#define SUPLA_CHANNEL_FLAG_ZWAVE_BRIDGE 0x0001 // ver. >= 12
651#define SUPLA_CHANNEL_FLAG_IR_BRIDGE 0x0002 // ver. >= 12 DEPRECATED
652#define SUPLA_CHANNEL_FLAG_RF_BRIDGE 0x0004 // ver. >= 12 DEPRECATED
653#define SUPLA_CHANNEL_FLAG_OCR 0x0008 // ver. >= 26
654#define SUPLA_CHANNEL_FLAG_FLOOD_SENSORS_SUPPORTED 0x0010 // ver. >= 27
655#define SUPLA_CHANNEL_FLAG_FILL_LEVEL_REPORTING_IN_FULL_RANGE \
656 0x0020 // ver. >= 27
657#define SUPLA_CHANNEL_FLAG_VALVE_MOTOR_ALARM_SUPPORTED 0x0040 // ver. >= 27
658#define SUPLA_CHANNEL_FLAG_RS_SBS_AND_STOP_ACTIONS 0x0080 // ver. >= 17
659#define SUPLA_CHANNEL_FLAG_RGBW_COMMANDS_SUPPORTED 0x0100 // ver. >= 21
660#define SUPLA_CHANNEL_FLAG_ALWAYS_ALLOW_CHANNEL_DELETION 0x0200 // ver. >= 27
661// Free bits for future use: 0x0400, 0x0800
662#define SUPLA_CHANNEL_FLAG_RS_AUTO_CALIBRATION 0x1000 // ver. >= 15
663#define SUPLA_CHANNEL_FLAG_CALCFG_RESET_COUNTERS 0x2000 // ver. >= 15
664#define SUPLA_CHANNEL_FLAG_CALCFG_RECALIBRATE 0x4000 // ver. >= 15
665#define SUPLA_CHANNEL_FLAG_CALCFG_IDENTIFY_SUBDEVICE 0x8000 // ver. >= 25
666#define SUPLA_CHANNEL_FLAG_CHANNELSTATE 0x00010000 // ver. >= 12
667#define SUPLA_CHANNEL_FLAG_PHASE1_UNSUPPORTED 0x00020000 // ver. >= 12
668#define SUPLA_CHANNEL_FLAG_PHASE2_UNSUPPORTED 0x00040000 // ver. >= 12
669#define SUPLA_CHANNEL_FLAG_PHASE3_UNSUPPORTED 0x00080000 // ver. >= 12
670#define SUPLA_CHANNEL_FLAG_TIME_SETTING_NOT_AVAILABLE 0x00100000 // ver. >= 12
671#define SUPLA_CHANNEL_FLAG_RSA_ENCRYPTED_PIN_REQUIRED 0x00200000 // ver. >= 12
672#define SUPLA_CHANNEL_FLAG_OFFLINE_DURING_REGISTRATION 0x00400000 // ver. >= 12
673#define SUPLA_CHANNEL_FLAG_ZIGBEE_BRIDGE 0x00800000 // ver. >= 12
674#define SUPLA_CHANNEL_FLAG_COUNTDOWN_TIMER_SUPPORTED 0x01000000 // ver. >= 12
675#define SUPLA_CHANNEL_FLAG_LIGHTSOURCELIFESPAN_SETTABLE \
676 0x02000000 // ver. >= 12
677#define SUPLA_CHANNEL_FLAG_POSSIBLE_SLEEP_MODE_deprecated \
678 0x04000000 // ver. >= 12 DEPRECATED
679#define SUPLA_CHANNEL_FLAG_RUNTIME_CHANNEL_CONFIG_UPDATE \
680 0x08000000 // ver. >= 21
681#define SUPLA_CHANNEL_FLAG_WEEKLY_SCHEDULE 0x10000000 // ver. >= 21
682#define SUPLA_CHANNEL_FLAG_HAS_PARENT 0x20000000 // ver. >= 21
683#define SUPLA_CHANNEL_FLAG_CALCFG_RESTART_SUBDEVICE 0x40000000 // ver. >= 25
684#define SUPLA_CHANNEL_FLAG_BATTERY_COVER_AVAILABLE 0x80000000 // ver. >= 25
685#pragma pack(push, 1)
686
687typedef struct {
688 char tag[SUPLA_TAG_SIZE];
689 unsigned char version;
690 unsigned _supla_int_t rr_id; // Request/Response ID
691 unsigned _supla_int_t call_id;
692 unsigned _supla_int_t data_size;
693 char data[SUPLA_MAX_DATA_SIZE]; // Last variable in struct!
695
696typedef struct {
697 // server -> device|client
698 unsigned char proto_version_min;
699 unsigned char proto_version;
700 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
702
703typedef struct {
704 // server -> device|client
705 unsigned char server_version_min;
706 unsigned char server_version;
708
709typedef struct {
710 // device|client -> server
711 struct _supla_timeval now;
713
714// Compatibility with ESP8266
716 _supla_int_t tv_sec;
717 _supla_int_t tv_usec;
718};
719
720typedef struct {
721 // device|client -> server
722 struct timeval_compat now;
724
725typedef struct {
726 // server -> device|client
727 struct _supla_timeval now;
729
730typedef struct {
731 // device|client -> server
732 unsigned char activity_timeout;
734
735typedef struct {
736 // server -> device|client
737 unsigned char activity_timeout;
738 unsigned char min;
739 unsigned char max;
741
742typedef struct {
743 char value[SUPLA_CHANNELVALUE_SIZE];
744 char sub_value[SUPLA_CHANNELVALUE_SIZE]; // For example sensor value
746
747typedef struct {
748 char value[SUPLA_CHANNELVALUE_SIZE];
749 char sub_value[SUPLA_CHANNELVALUE_SIZE]; // For example sensor value
750 char sub_value_type; // SUBV_TYPE_
752
753#define SUBV_TYPE_NOT_SET_OR_OFFLINE 0
754#define SUBV_TYPE_SENSOR 1
755#define SUBV_TYPE_ELECTRICITY_MEASUREMENTS 2
756#define SUBV_TYPE_IC_MEASUREMENTS 3
757
758#define EV_TYPE_NONE 0
759#ifdef USE_DEPRECATED_EMEV_V1
760#define EV_TYPE_ELECTRICITY_METER_MEASUREMENT_V1 10
761#endif /*USE_DEPRECATED_EMEV_V1*/
762#ifdef USE_DEPRECATED_EMEV_V2
763#define EV_TYPE_ELECTRICITY_METER_MEASUREMENT_V2 12
764#endif /*USE_DEPRECATED_EMEV_V2*/
765#define EV_TYPE_ELECTRICITY_METER_MEASUREMENT_V3 14
766#define EV_TYPE_IMPULSE_COUNTER_DETAILS_V1 20
767#define EV_TYPE_THERMOSTAT_DETAILS_V1 30
768#define EV_TYPE_CHANNEL_STATE_V1 40
769#define EV_TYPE_TIMER_STATE_V1 50
770#define EV_TYPE_TIMER_STATE_V1_SEC 51
771#define EV_TYPE_CHANNEL_AND_TIMER_STATE_V1 60
772#define EV_TYPE_MULTI_VALUE 100
773
774#define CALCFG_TYPE_THERMOSTAT_DETAILS_V1 10
775
776typedef struct {
777 char type; // EV_TYPE_
778 unsigned _supla_int_t size;
779 char value[SUPLA_CHANNELEXTENDEDVALUE_SIZE]; // Last variable in struct!
780} TSuplaChannelExtendedValue; // v. >= 10
781
782typedef struct {
783 // server -> client
784 char EOL; // End Of List
785 _supla_int_t Id;
786 unsigned _supla_int_t
787 CaptionSize; // including the terminating null byte ('\0')
788 char Caption[SUPLA_LOCATION_CAPTION_MAXSIZE]; // Last variable in struct!
790
791typedef struct {
792 // server -> client
793 _supla_int_t count;
794 _supla_int_t total_left;
796 items[SUPLA_LOCATIONPACK_MAXCOUNT]; // Last variable in struct!
798
799typedef struct {
800 // device -> server
801 unsigned char Number;
802 _supla_int_t Type;
803 char value[SUPLA_CHANNELVALUE_SIZE];
805
806typedef struct {
807 // device -> server
808
809 _supla_int_t LocationID;
810 char LocationPWD[SUPLA_LOCATION_PWD_MAXSIZE]; // UTF8
811
812 char GUID[SUPLA_GUID_SIZE];
813 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
814 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
815
816 unsigned char channel_count;
818 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
820
821typedef struct {
822 // device -> server
823
824 unsigned char Number;
825 _supla_int_t Type;
826
827 _supla_int_t FuncList;
828 _supla_int_t Default;
829
830 char value[SUPLA_CHANNELVALUE_SIZE];
831} TDS_SuplaDeviceChannel_B; // ver. >= 2
832
833typedef struct {
834 unsigned char relatedChannelNumber; // ChannelNumber + 1.
835 unsigned _supla_int_t disablesLocalOperation;
837
838#define SUPLA_HVAC_VALUE_FLAG_SETPOINT_TEMP_HEAT_SET (1ULL << 0)
839#define SUPLA_HVAC_VALUE_FLAG_SETPOINT_TEMP_COOL_SET (1ULL << 1)
840// Tells if output responsible for heating function is enabled
841#define SUPLA_HVAC_VALUE_FLAG_HEATING (1ULL << 2)
842// Tells if output responsible for cooling function is enabled
843#define SUPLA_HVAC_VALUE_FLAG_COOLING (1ULL << 3)
844// Tells if channel works in Weekly Schedule mode. If set to 0, then it works
845// in manual mode
846#define SUPLA_HVAC_VALUE_FLAG_WEEKLY_SCHEDULE (1ULL << 4)
847#define SUPLA_HVAC_VALUE_FLAG_COUNTDOWN_TIMER (1ULL << 5)
848// FAN flag tells if fan function is enabled
849#define SUPLA_HVAC_VALUE_FLAG_FAN_ENABLED (1ULL << 6)
850#define SUPLA_HVAC_VALUE_FLAG_THERMOMETER_ERROR (1ULL << 7)
851#define SUPLA_HVAC_VALUE_FLAG_CLOCK_ERROR (1ULL << 8)
852#define SUPLA_HVAC_VALUE_FLAG_FORCED_OFF_BY_SENSOR (1ULL << 9)
853// Only for SUPLA_CHANNELFNC_HVAC_THERMOSTAT
854// If the COOL flag is not set, it means that the thermostat is working in
855// heating mode.
856#define SUPLA_HVAC_VALUE_FLAG_COOL (1ULL << 10)
857#define SUPLA_HVAC_VALUE_FLAG_WEEKLY_SCHEDULE_TEMPORAL_OVERRIDE (1ULL << 11)
858#define SUPLA_HVAC_VALUE_FLAG_BATTERY_COVER_OPEN (1ULL << 12)
859#define SUPLA_HVAC_VALUE_FLAG_CALIBRATION_ERROR (1ULL << 13)
860#define SUPLA_HVAC_VALUE_FLAG_ANTIFREEZE_OVERHEAT_ACTIVE (1ULL << 14)
861
862// HVAC modes are used in channel value (as a command from server or
863// as a status response from device to server) and in weekly schedules
864// programs. Programs can't use value TURN_ON and WEEKLY_SCHEDULE
865// Use SUPLA_HVAC_MODE_NOT_SET if you don't want to modify current mode, but
866// only to alter tempreature setpoints.
867#define SUPLA_HVAC_MODE_NOT_SET 0
868#define SUPLA_HVAC_MODE_OFF 1
869#define SUPLA_HVAC_MODE_HEAT 2
870#define SUPLA_HVAC_MODE_COOL 3
871#define SUPLA_HVAC_MODE_HEAT_COOL 4
872#define SUPLA_HVAC_MODE_FAN_ONLY 6
873#define SUPLA_HVAC_MODE_DRY 7
874// TURN ON mode is a command. Device will use it to turn on and then it will
875// restore previous mode which was used before turn off.
876#define SUPLA_HVAC_MODE_CMD_TURN_ON 8
877// Weekly schedule is a command. Device will use it to enable weekly schedule
878// mode and then it will set its mode according to schedule
879#define SUPLA_HVAC_MODE_CMD_WEEKLY_SCHEDULE 9
880// Switch to manual mode - it will restore previously used manual mode and
881// restore manual mode temperature setpoints when no new setpoints are given
882// in value.
883// It can be also used to switch to default manual mode, when no manual mode
884// was used earlier.
885#define SUPLA_HVAC_MODE_CMD_SWITCH_TO_MANUAL 10
886
887typedef struct {
888 unsigned char IsOn; // DS: 0/1 (for off/on) or 2..102 (for 0-100%)
889 unsigned char Mode; // SUPLA_HVAC_MODE_
890 _supla_int16_t
891 SetpointTemperatureHeat; // * 0.01 Celcius degree - used for heating
892 _supla_int16_t
893 SetpointTemperatureCool; // * 0.01 - Celcius degree used for cooling
894 unsigned _supla_int16_t Flags; // SUPLA_HVAC_VALUE_FLAG_
895} THVACValue;
896
897typedef struct {
898 // device -> server
899
900 unsigned char Number;
901 _supla_int_t Type;
902
903 union {
904 _supla_int_t FuncList;
905 unsigned _supla_int_t ActionTriggerCaps; // ver. >= 16
906 };
907
908 _supla_int_t Default;
909 _supla_int_t Flags;
910
911 union {
912 char value[SUPLA_CHANNELVALUE_SIZE];
913 TActionTriggerProperties actionTriggerProperties; // ver. >= 16
914 THVACValue hvacValue;
915 };
916} TDS_SuplaDeviceChannel_C; // ver. >= 10
917
918// Channel state flag values:
919#define SUPLA_CHANNEL_OFFLINE_FLAG_ONLINE 0
920#define SUPLA_CHANNEL_OFFLINE_FLAG_OFFLINE 1
921#define SUPLA_CHANNEL_OFFLINE_FLAG_ONLINE_BUT_NOT_AVAILABLE 2
922#define SUPLA_CHANNEL_OFFLINE_FLAG_OFFLINE_REMOTE_WAKEUP_NOT_SUPPORTED 3
923#define SUPLA_CHANNEL_OFFLINE_FLAG_FIRMWARE_UPDATE_ONGOING 4
924
925// Update below MAX value when new state is added to the list
926#define SUPLA_CHANNEL_OFFLINE_FLAG_MAX \
927 SUPLA_CHANNEL_OFFLINE_FLAG_FIRMWARE_UPDATE_ONGOING
928
929// Only in ONLINE state, ValidityTimeSec and value variables are used.
930// OFFLINE_REMOTE_WAKEUP_NOT_SUPPORTED - device doesn't support remote wakeup,
931// so we wait for it to initiate the communication.
932
933// Channel online flag values (only online/offline 0/1 values are exchanged,
934// compared to state flag values):
935#define SUPLA_CHANNEL_ONLINE_FLAG_ONLINE 1
936#define SUPLA_CHANNEL_ONLINE_FLAG_OFFLINE 0
937#define SUPLA_CHANNEL_ONLINE_FLAG_ONLINE_BUT_NOT_AVAILABLE \
938 SUPLA_CHANNEL_OFFLINE_FLAG_ONLINE_BUT_NOT_AVAILABLE
939#define SUPLA_CHANNEL_ONLINE_FLAG_STATE_REMOTE_WAKEUP_NOT_SUPPORTED \
940 SUPLA_CHANNEL_OFFLINE_FLAG_OFFLINE_REMOTE_WAKEUP_NOT_SUPPORTED
941#define SUPLA_CHANNEL_ONLINE_FLAG_FIRMWARE_UPDATE_ONGOING \
942 SUPLA_CHANNEL_OFFLINE_FLAG_FIRMWARE_UPDATE_ONGOING
943
944typedef struct {
945 // device -> server
946
947 unsigned char Number;
948 _supla_int_t Type;
949
950 union {
951 _supla_int_t FuncList;
952 unsigned _supla_int_t ActionTriggerCaps; // ver. >= 16
953 };
954
955 _supla_int_t Default;
956 _supla_int64_t Flags;
957
958 unsigned char Offline;
959 unsigned _supla_int_t ValueValidityTimeSec;
960
961 union {
962 char value[SUPLA_CHANNELVALUE_SIZE];
963 TActionTriggerProperties actionTriggerProperties; // ver. >= 16
964 THVACValue hvacValue;
965 };
966
967 unsigned char DefaultIcon;
968} TDS_SuplaDeviceChannel_D; // ver. >= 23
969
970typedef struct {
971 // device -> server
972
973 unsigned char Number;
974 _supla_int_t Type;
975
976 union {
977 _supla_int_t FuncList;
978 unsigned _supla_int_t ActionTriggerCaps; // ver. >= 16 only for
979 // SUPLA_CHANNELTYPE_ACTIONTRIGGER
980 unsigned _supla_int_t
981 RGBW_FuncList; // ver. >= 28 only for SUPLA_CHANNELTYPE_DIMMER,
982 // SUPLA_CHANNELTYPE_RGBLEDCONTROLLER,
983 // SUPLA_CHANNELTYPE_DIMMERANDRGBLED
984 };
985
986 _supla_int_t Default;
987 _supla_int64_t Flags;
988
989 unsigned char Offline; // see SUPLA_CHANNEL_OFFLINE_FLAG_
990
991 unsigned _supla_int_t ValueValidityTimeSec;
992
993 union {
994 char value[SUPLA_CHANNELVALUE_SIZE];
995 TActionTriggerProperties actionTriggerProperties; // ver. >= 16
996 THVACValue hvacValue;
997 };
998
999 unsigned char DefaultIcon;
1000 unsigned char SubDeviceId; // 0 - no subdevice, 1..255 - subdevice id
1001} TDS_SuplaDeviceChannel_E; // ver. >= 25
1002
1003typedef struct {
1004 // device -> server
1005
1006 _supla_int_t LocationID;
1007 char LocationPWD[SUPLA_LOCATION_PWD_MAXSIZE]; // UTF8
1008
1009 char GUID[SUPLA_GUID_SIZE];
1010 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1011 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1012
1013 unsigned char channel_count;
1015 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1016} TDS_SuplaRegisterDevice_B; // ver. >= 2
1017
1018typedef struct {
1019 // device -> server
1020
1021 _supla_int_t LocationID;
1022 char LocationPWD[SUPLA_LOCATION_PWD_MAXSIZE]; // UTF8
1023
1024 char GUID[SUPLA_GUID_SIZE];
1025 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1026 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1027
1028 char ServerName[SUPLA_SERVER_NAME_MAXSIZE]; // ServerName is equal to Server
1029 // host name/IP
1030
1031 unsigned char channel_count;
1033 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1034} TDS_SuplaRegisterDevice_C; // ver. >= 6
1035
1036typedef struct {
1037 // device -> server
1038
1039 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1040 char AuthKey[SUPLA_AUTHKEY_SIZE];
1041
1042 char GUID[SUPLA_GUID_SIZE];
1043
1044 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1045 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1046
1047 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1048
1049 unsigned char channel_count;
1051 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1052} TDS_SuplaRegisterDevice_D; // ver. >= 7
1053
1054typedef struct {
1055 // device -> server
1056
1057 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1058 char AuthKey[SUPLA_AUTHKEY_SIZE];
1059
1060 char GUID[SUPLA_GUID_SIZE];
1061
1062 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1063 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1064
1065 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1066
1067 _supla_int_t Flags; // SUPLA_DEVICE_FLAG_*
1068 _supla_int16_t ManufacturerID;
1069 _supla_int16_t ProductID;
1070
1071 unsigned char channel_count;
1073 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1074} TDS_SuplaRegisterDevice_E; // ver. >= 10
1075
1076typedef struct {
1077 // device -> server
1078
1079 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1080 char AuthKey[SUPLA_AUTHKEY_SIZE];
1081
1082 char GUID[SUPLA_GUID_SIZE];
1083
1084 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1085 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1086
1087 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1088
1089 _supla_int_t Flags; // SUPLA_DEVICE_FLAG_*
1090 _supla_int16_t ManufacturerID;
1091 _supla_int16_t ProductID;
1092
1093 unsigned char channel_count;
1095
1096typedef struct {
1097 // device -> server
1098
1099 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1100 char AuthKey[SUPLA_AUTHKEY_SIZE];
1101
1102 char GUID[SUPLA_GUID_SIZE];
1103
1104 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1105 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1106
1107 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1108
1109 _supla_int_t Flags; // SUPLA_DEVICE_FLAG_*
1110 _supla_int16_t ManufacturerID;
1111 _supla_int16_t ProductID;
1112
1113 unsigned char channel_count;
1115 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1116} TDS_SuplaRegisterDevice_F; // ver. >= 23
1117
1118typedef struct {
1119 // device -> server
1120
1121 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1122 char AuthKey[SUPLA_AUTHKEY_SIZE];
1123
1124 char GUID[SUPLA_GUID_SIZE];
1125
1126 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
1127 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1128
1129 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1130
1131 _supla_int_t Flags; // SUPLA_DEVICE_FLAG_*
1132 _supla_int16_t ManufacturerID;
1133 _supla_int16_t ProductID;
1134
1135 unsigned char channel_count;
1137 channels[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
1138} TDS_SuplaRegisterDevice_G; // ver. >= 25
1139
1140typedef struct {
1141 // server -> device
1142
1143 _supla_int_t result_code;
1144 unsigned char activity_timeout;
1145 unsigned char version;
1146 unsigned char version_min;
1148
1149#define CHANNEL_REPORT_CHANNEL_REGISTERED (1 << 0)
1150#define CHANNEL_REPORT_INCORRECT_CHANNEL_TYPE (1 << 1)
1151#define CHANNEL_REPORT_MAXSIZE 256
1152
1153typedef struct {
1154 // server -> device
1155
1156 _supla_int_t result_code;
1157 unsigned char activity_timeout;
1158 unsigned char version;
1159 unsigned char version_min;
1160
1161 unsigned _supla_int16_t channel_report_size;
1162 unsigned char channel_report
1163 [CHANNEL_REPORT_MAXSIZE]; // One byte per channel. The meaning of the
1164 // bits is determined by CHANNEL_REPORT_*.
1165} TSD_SuplaRegisterDeviceResult_B; // ver. >= 25
1166
1167typedef struct {
1168 // device -> server
1169
1170 unsigned char ChannelNumber;
1171 char value[SUPLA_CHANNELVALUE_SIZE];
1173
1174typedef struct {
1175 // device -> server
1176
1177 unsigned char ChannelNumber;
1178 unsigned char Offline;
1179 char value[SUPLA_CHANNELVALUE_SIZE];
1180} TDS_SuplaDeviceChannelValue_B; // v. >= 12
1181
1182typedef struct {
1183 // device -> server
1184
1185 unsigned char ChannelNumber;
1186 unsigned char Offline; // see SUPLA_CHANNEL_OFFLINE_FLAG_
1187
1188 unsigned _supla_int_t ValidityTimeSec;
1189 char value[SUPLA_CHANNELVALUE_SIZE];
1190} TDS_SuplaDeviceChannelValue_C; // v. >= 12
1191
1192typedef struct {
1193 // device -> server
1194
1195 unsigned char ChannelNumber;
1196 TSuplaChannelExtendedValue value; // Last variable in struct!
1198
1199typedef struct {
1200 // server -> device
1201 _supla_int_t SenderID;
1202 unsigned char ChannelNumber;
1203 union {
1204 unsigned _supla_int_t DurationMS;
1205 unsigned _supla_int_t DurationSec; // ver. >= 21. Applies to HVAC
1206 };
1207
1208 char value[SUPLA_CHANNELVALUE_SIZE];
1210
1211typedef struct {
1212 // server -> device
1213 _supla_int_t SenderID;
1214 _supla_int_t GroupID;
1215 unsigned char EOL; // End Of List
1216 unsigned char ChannelNumber;
1217 union {
1218 unsigned _supla_int_t DurationMS;
1219 unsigned _supla_int_t DurationSec; // ver. >= 21. Applies to HVAC
1220 };
1221 char value[SUPLA_CHANNELVALUE_SIZE];
1222} TSD_SuplaChannelGroupNewValue; // v. >= 13
1223
1224typedef struct {
1225 // device -> server
1226 unsigned char ChannelNumber;
1227 _supla_int_t SenderID;
1228 char Success;
1230
1231typedef struct {
1232 // server -> client
1233
1234 char EOL; // End Of List
1235 _supla_int_t Id;
1236 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1237
1238 TSuplaChannelValue value;
1240
1241typedef struct {
1242 // server -> client
1243
1244 char EOL; // End Of List
1245 _supla_int_t Id;
1246 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1247
1249} TSC_SuplaChannelValue_B; // ver. >= 15
1250
1251typedef struct {
1252 // server -> client
1253 _supla_int_t Id;
1254
1255 TSuplaChannelExtendedValue value; // Last variable in struct!
1257
1258typedef struct {
1259 // server -> client
1260
1261 _supla_int_t count;
1262 _supla_int_t total_left;
1263
1265 items[SUPLA_CHANNELVALUE_PACK_MAXCOUNT]; // Last variable in struct!
1266} TSC_SuplaChannelValuePack; // ver. >= 9
1267
1268typedef struct {
1269 // server -> client
1270
1271 _supla_int_t count;
1272 _supla_int_t total_left;
1273
1275 items[SUPLA_CHANNELVALUE_PACK_MAXCOUNT]; // Last variable in struct!
1276} TSC_SuplaChannelValuePack_B; // ver. >= 15
1277
1278typedef struct {
1279 // server -> client
1280
1281 _supla_int_t count;
1282 _supla_int_t total_left;
1283 unsigned _supla_int_t pack_size;
1284
1285 char pack[SUPLA_CHANNELEXTENDEDVALUE_PACK_MAXDATASIZE]; // Last variable in
1286 // struct!
1287} TSC_SuplaChannelExtendedValuePack; // ver. >= 10
1288
1289typedef struct {
1290 // server -> client
1291 char EOL; // End Of List
1292
1293 _supla_int_t Id;
1294 _supla_int_t LocationID;
1295 _supla_int_t Func;
1296 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1297
1298 TSuplaChannelValue value;
1299
1300 unsigned _supla_int_t
1301 CaptionSize; // including the terminating null byte ('\0')
1302 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
1304
1305typedef struct {
1306 // server -> client
1307
1308 _supla_int_t count;
1309 _supla_int_t total_left;
1311 items[SUPLA_CHANNELPACK_MAXCOUNT]; // Last variable in struct!
1313
1314typedef struct {
1315 // server -> client
1316 char EOL; // End Of List
1317
1318 _supla_int_t Id;
1319 _supla_int_t LocationID;
1320 _supla_int_t Func;
1321 _supla_int_t AltIcon;
1322 unsigned _supla_int_t Flags;
1323 unsigned char ProtocolVersion;
1324 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1325
1326 TSuplaChannelValue value;
1327
1328 unsigned _supla_int_t
1329 CaptionSize; // including the terminating null byte ('\0')
1330 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
1331} TSC_SuplaChannel_B; // ver. >= 8
1332
1333typedef struct {
1334 // server -> client
1335
1336 _supla_int_t count;
1337 _supla_int_t total_left;
1339 items[SUPLA_CHANNELPACK_MAXCOUNT]; // Last variable in struct!
1340} TSC_SuplaChannelPack_B; // ver. >= 8
1341
1342typedef struct {
1343 // server -> client
1344 char EOL; // End Of List
1345
1346 _supla_int_t Id;
1347 _supla_int_t DeviceID;
1348 _supla_int_t LocationID;
1349 _supla_int_t Type;
1350 _supla_int_t Func;
1351 _supla_int_t AltIcon;
1352 _supla_int_t UserIcon;
1353 _supla_int16_t ManufacturerID;
1354 _supla_int16_t ProductID;
1355
1356 unsigned _supla_int_t Flags;
1357 unsigned char ProtocolVersion;
1358 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1359
1360 TSuplaChannelValue value;
1361
1362 unsigned _supla_int_t
1363 CaptionSize; // including the terminating null byte ('\0')
1364 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
1365} TSC_SuplaChannel_C; // ver. >= 10
1366
1367typedef struct {
1368 // server -> client
1369 char EOL; // End Of List
1370
1371 _supla_int_t Id;
1372 _supla_int_t DeviceID;
1373 _supla_int_t LocationID;
1374 _supla_int_t Type;
1375 _supla_int_t Func;
1376 _supla_int_t AltIcon;
1377 _supla_int_t UserIcon;
1378 _supla_int16_t ManufacturerID;
1379 _supla_int16_t ProductID;
1380
1381 unsigned _supla_int_t Flags;
1382 unsigned char ProtocolVersion;
1383 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1384
1386
1387 unsigned _supla_int_t
1388 CaptionSize; // including the terminating null byte ('\0')
1389 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
1390} TSC_SuplaChannel_D; // ver. >= 15
1391
1392typedef struct {
1393 // server -> client
1394 char EOL; // End Of List
1395
1396 _supla_int_t Id;
1397 _supla_int_t DeviceID;
1398 _supla_int_t LocationID;
1399 _supla_int_t Type;
1400 _supla_int_t Func;
1401 _supla_int_t AltIcon;
1402 _supla_int_t UserIcon;
1403 _supla_int16_t ManufacturerID;
1404 _supla_int16_t ProductID;
1405 unsigned _supla_int_t DefaultConfigCRC32;
1406
1407 unsigned _supla_int64_t Flags;
1408 unsigned char ProtocolVersion;
1409 char online; // see SUPLA_CHANNEL_ONLINE_FLAG_
1410
1412
1413 unsigned _supla_int_t
1414 CaptionSize; // including the terminating null byte ('\0')
1415 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
1416} TSC_SuplaChannel_E; // ver. >= 23
1417
1418typedef struct {
1419 // server -> client
1420
1421 _supla_int_t count;
1422 _supla_int_t total_left;
1424 items[SUPLA_CHANNELPACK_MAXCOUNT]; // Last variable in struct!
1425} TSC_SuplaChannelPack_C; // ver. >= 10
1426
1427typedef struct {
1428 // server -> client
1429
1430 _supla_int_t count;
1431 _supla_int_t total_left;
1433 items[SUPLA_CHANNELPACK_MAXCOUNT]; // Last variable in struct!
1434} TSC_SuplaChannelPack_D; // ver. >= 15
1435
1436typedef struct {
1437 // server -> client
1438
1439 _supla_int_t count;
1440 _supla_int_t total_left;
1442 items[SUPLA_CHANNELPACK_MAXCOUNT]; // Last variable in struct!
1443} TSC_SuplaChannelPack_E; // ver. >= 23
1444
1445typedef struct {
1446 // server -> client
1447 char EOL; // End Of List
1448
1449 _supla_int_t Id;
1450 _supla_int_t LocationID;
1451 _supla_int_t Func;
1452 _supla_int_t AltIcon;
1453 unsigned _supla_int_t Flags;
1454
1455 unsigned _supla_int_t
1456 CaptionSize; // including the terminating null byte ('\0')
1457 char Caption[SUPLA_CHANNELGROUP_CAPTION_MAXSIZE]; // Last variable in struct!
1458} TSC_SuplaChannelGroup; // ver. >= 9
1459
1460typedef struct {
1461 // server -> client
1462 char EOL; // End Of List
1463
1464 _supla_int_t Id;
1465 _supla_int_t LocationID;
1466 _supla_int_t Func;
1467 _supla_int_t AltIcon;
1468 _supla_int_t UserIcon;
1469 unsigned _supla_int_t Flags;
1470
1471 unsigned _supla_int_t
1472 CaptionSize; // including the terminating null byte ('\0')
1473 char Caption[SUPLA_CHANNELGROUP_CAPTION_MAXSIZE]; // Last variable in struct!
1474} TSC_SuplaChannelGroup_B; // ver. >= 10
1475
1476typedef struct {
1477 // server -> client
1478
1479 _supla_int_t count;
1480 _supla_int_t total_left;
1482 items[SUPLA_CHANNELGROUP_PACK_MAXCOUNT]; // Last variable in struct!
1483} TSC_SuplaChannelGroupPack; // ver. >= 9
1484
1485typedef struct {
1486 // server -> client
1487
1488 _supla_int_t count;
1489 _supla_int_t total_left;
1491 items[SUPLA_CHANNELGROUP_PACK_MAXCOUNT]; // Last variable in struct!
1492} TSC_SuplaChannelGroupPack_B; // ver. >= 10
1493
1494typedef struct {
1495 // server -> client
1496 char EOL; // End Of List
1497
1498 _supla_int_t ChannelGroupID;
1499 _supla_int_t ChannelID;
1500} TSC_SuplaChannelGroupRelation; // ver. >= 9
1501
1502typedef struct {
1503 // server -> client
1504
1505 _supla_int_t count;
1506 _supla_int_t total_left;
1508 items[SUPLA_CHANNELGROUP_RELATION_PACK_MAXCOUNT]; // Last variable in
1509 // struct!
1511
1512#define CHANNEL_RELATION_TYPE_DEFAULT 0
1513#define CHANNEL_RELATION_TYPE_OPENING_SENSOR 1
1514#define CHANNEL_RELATION_TYPE_PARTIAL_OPENING_SENSOR 2
1515#define CHANNEL_RELATION_TYPE_METER 3
1516#define CHANNEL_RELATION_TYPE_MAIN_TERMOMETER 4
1517#define CHANNEL_RELATION_TYPE_AUX_THERMOMETER_FLOOR 5
1518#define CHANNEL_RELATION_TYPE_AUX_THERMOMETER_WATER 6
1519#define CHANNEL_RELATION_TYPE_AUX_THERMOMETER_GENERIC_HEATER 7
1520#define CHANNEL_RELATION_TYPE_AUX_THERMOMETER_GENERIC_COOLER 8
1521
1522#define CHANNEL_RELATION_TYPE_MASTER_THERMOSTAT 20
1523#define CHANNEL_RELATION_TYPE_HEAT_OR_COLD_SOURCE_SWITCH 21
1524#define CHANNEL_RELATION_TYPE_PUMP_SWITCH 22
1525
1526typedef struct {
1527 char EOL; // End Of List
1528 _supla_int_t Id;
1529 _supla_int_t ParentId;
1530 _supla_int16_t Type; // CHANNEL_RELATION_TYPE_
1531} TSC_SuplaChannelRelation; // ver. >= 21
1532
1533typedef struct {
1534 _supla_int_t count;
1535 _supla_int_t total_left;
1537 items[SUPLA_CHANNEL_RELATION_PACK_MAXCOUNT]; // Last variable in struct!
1539
1540typedef struct {
1541 // server -> client
1542 char EOL; // End Of List
1543
1544 _supla_int_t Id;
1545 _supla_int_t LocationId;
1546 _supla_int_t AltIcon;
1547 _supla_int_t UserIcon;
1548
1549 unsigned _supla_int16_t
1550 CaptionSize; // including the terminating null byte ('\0')
1551 char Caption[SUPLA_SCENE_CAPTION_MAXSIZE]; // Last variable in struct!
1552} TSC_SuplaScene; // ver. >= 18
1553
1554typedef struct {
1555 // server -> client
1556
1557 _supla_int_t count;
1558 _supla_int_t total_left;
1559 TSC_SuplaScene items[SUPLA_SCENE_PACK_MAXCOUNT]; // Last variable in struct!
1560} TSC_SuplaScenePack; // ver. >= 18
1561
1562typedef struct {
1563 // server -> client
1564 char EOL; // End Of List
1565
1566 _supla_int_t SceneId;
1567 unsigned _supla_int_t MillisecondsFromStart;
1568 unsigned _supla_int_t MillisecondsLeft;
1569
1570 _supla_int_t InitiatorId;
1571 unsigned _supla_int16_t
1572 InitiatorNameSize; // including the terminating null byte ('\0')
1573 char InitiatorName[SUPLA_INITIATOR_NAME_MAXSIZE]; // Last variable in struct!
1574} TSC_SuplaSceneState; // ver. >= 18
1575
1576typedef struct {
1577 // server -> client
1578
1579 _supla_int_t count;
1580 _supla_int_t total_left;
1582 items[SUPLA_SCENE_STATE_PACK_MAXCOUNT]; // Last variable in struct!
1583} TSC_SuplaSceneStatePack; // ver. >= 18
1584
1585#define ACTION_SUBJECT_TYPE_UNKNOWN 0
1586#define ACTION_SUBJECT_TYPE_CHANNEL 1
1587#define ACTION_SUBJECT_TYPE_CHANNEL_GROUP 2
1588#define ACTION_SUBJECT_TYPE_SCENE 3
1589#define ACTION_SUBJECT_TYPE_SCHEDULE 4
1590
1591#define ACTION_OPEN 10
1592#define ACTION_CLOSE 20
1593#define ACTION_SHUT 30
1594#define ACTION_REVEAL 40
1595#define ACTION_REVEAL_PARTIALLY 50
1596#define ACTION_SHUT_PARTIALLY 51
1597#define ACTION_TURN_ON 60
1598#define ACTION_TURN_ON_WITH_DURATION 61
1599#define ACTION_TURN_OFF 70
1600#define ACTION_TURN_OFF_WITH_DURATION 71
1601#define ACTION_SET_RGBW_PARAMETERS 80
1602#define ACTION_OPEN_CLOSE 90
1603#define ACTION_STOP 100
1604#define ACTION_TOGGLE 110
1605#define ACTION_UP_OR_STOP 140
1606#define ACTION_DOWN_OR_STOP 150
1607#define ACTION_STEP_BY_STEP 160
1608#define ACTION_UP 170
1609#define ACTION_DOWN 180
1610#define ACTION_ENABLE 200
1611#define ACTION_DISABLE 210
1612#define ACTION_SEND 220
1613#define ACTION_HVAC_SET_PARAMETERS 230
1614#define ACTION_HVAC_SWITCH_TO_PROGRAM_MODE 231
1615#define ACTION_HVAC_SWITCH_TO_MANUAL_MODE 232
1616#define ACTION_HVAC_SET_TEMPERATURES 233
1617#define ACTION_HVAC_SET_TEMPERATURE 234
1618#define ACTION_READ 1000
1619#define ACTION_SET 2000
1620#define ACTION_EXECUTE 3000
1621#define ACTION_INTERRUPT 3001
1622#define ACTION_INTERRUPT_AND_EXECUTE 3002
1623#define ACTION_COPY 10100
1624#define ACTION_FORWARD_OUTSIDE 10000
1625
1626#define SSP_FLAG_PERCENTAGE_AS_DELTA (1 << 0)
1627#define SSP_FLAG_TILT_AS_DELTA (1 << 1)
1628
1629typedef struct {
1630 char Percentage;
1631 unsigned char Flags; // SSP_FLAG_
1632 signed char Tilt;
1633 char Reserved[13];
1634} TAction_ShadingSystem_Parameters; // ver. >= 19
1635
1636typedef struct {
1637 char Brightness; // -1 == Ignore
1638 char ColorBrightness; // -1 == Ignore
1639 unsigned _supla_int_t Color; // 0 == Ignore
1640 char ColorRandom;
1641 char OnOff;
1642 char Command; // RGBW_COMMAND_, requires
1643 // SUPLA_CHANNEL_FLAG_RGBW_COMMANDS_SUPPORTED v. >= 21
1644 char WhiteTemperature; // ver. >= 28
1645 char Reserved[6];
1646} TAction_RGBW_Parameters; // ver. >= 19
1647
1648typedef struct {
1649 unsigned _supla_int_t DurationSec;
1650 unsigned char Mode; // for HVAC: SUPLA_HVAC_MODE_
1651 _supla_int16_t
1652 SetpointTemperatureHeat; // * 0.01 Celcius degree - used for heating
1653 _supla_int16_t
1654 SetpointTemperatureCool; // * 0.01 - Celcius degree used for coolingx
1655 unsigned _supla_int16_t Flags; // SUPLA_HVAC_VALUE_FLAG_
1657
1658typedef struct {
1659 _supla_int_t ActionId;
1660 _supla_int_t SubjectId;
1661 unsigned char SubjectType;
1662 unsigned _supla_int16_t ParamSize;
1663 char Param[SUPLA_ACTION_PARAM_MAXSIZE];
1664} TCS_Action; // ver. >= 19
1665
1666typedef struct {
1667 _supla_int_t AccessID;
1668 char AccessIDpwd[SUPLA_ACCESSID_PWD_MAXSIZE]; // UTF8
1669 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1670 char AuthKey[SUPLA_AUTHKEY_SIZE];
1671 char GUID[SUPLA_GUID_SIZE];
1672 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1673} TCS_ClientAuthorizationDetails; // ver. >= 19
1674
1675typedef struct {
1677 TCS_Action Action;
1678} TCS_ActionWithAuth; // ver. >= 19
1679
1680typedef struct {
1681 unsigned char ResultCode;
1682 _supla_int_t ActionId;
1683 _supla_int_t SubjectId;
1684 _supla_int_t SubjectType;
1685} TSC_ActionExecutionResult; // ver. >= 19
1686
1687typedef struct {
1688 // server -> client
1689 unsigned char ResultCode;
1690 _supla_int_t ChannelId; // Alias SubjectId
1691 _supla_int_t Function;
1692
1694 TSuplaChannelExtendedValue ExtendedValue; // Last variable in struct!
1695} TSC_GetChannelValueResult; // ver. >= 19;
1696
1697typedef struct {
1699 _supla_int_t ChannelId;
1700} TCS_GetChannelValueWithAuth; // ver. >= 19
1701
1702typedef struct {
1703 // client -> server
1704
1705 _supla_int_t AccessID;
1706 char AccessIDpwd[SUPLA_ACCESSID_PWD_MAXSIZE]; // UTF8
1707
1708 char GUID[SUPLA_GUID_SIZE];
1709 char Name[SUPLA_CLIENT_NAME_MAXSIZE]; // UTF8
1710 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1712
1713typedef struct {
1714 // client -> server
1715
1716 _supla_int_t AccessID;
1717 char AccessIDpwd[SUPLA_ACCESSID_PWD_MAXSIZE]; // UTF8
1718
1719 char GUID[SUPLA_GUID_SIZE];
1720 char Name[SUPLA_CLIENT_NAME_MAXSIZE]; // UTF8
1721 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1722
1723 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1724} TCS_SuplaRegisterClient_B; // ver. >= 6
1725
1726typedef struct {
1727 // client -> server
1728
1729 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1730 char AuthKey[SUPLA_AUTHKEY_SIZE];
1731
1732 char GUID[SUPLA_GUID_SIZE];
1733 char Name[SUPLA_CLIENT_NAME_MAXSIZE]; // UTF8
1734 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1735
1736 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1737} TCS_SuplaRegisterClient_C; // ver. >= 7
1738
1739typedef struct {
1740 // client -> server
1741
1742 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
1743 char Password[SUPLA_PASSWORD_MAXSIZE]; // Optional - UTF8
1744 char AuthKey[SUPLA_AUTHKEY_SIZE];
1745
1746 char GUID[SUPLA_GUID_SIZE];
1747 char Name[SUPLA_CLIENT_NAME_MAXSIZE]; // UTF8
1748 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
1749
1750 char ServerName[SUPLA_SERVER_NAME_MAXSIZE];
1751} TCS_SuplaRegisterClient_D; // ver. >= 12
1752
1753typedef struct {
1754 // server -> client
1755
1756 _supla_int_t result_code;
1757 _supla_int_t ClientID;
1758 _supla_int_t LocationCount;
1759 _supla_int_t ChannelCount;
1760 unsigned char activity_timeout;
1761 unsigned char version;
1762 unsigned char version_min;
1764
1765typedef struct {
1766 // server -> client
1767
1768 _supla_int_t result_code;
1769 _supla_int_t ClientID;
1770 _supla_int_t LocationCount;
1771 _supla_int_t ChannelCount;
1772 _supla_int_t ChannelGroupCount;
1773 _supla_int_t Flags;
1774 unsigned char activity_timeout;
1775 unsigned char version;
1776 unsigned char version_min;
1777} TSC_SuplaRegisterClientResult_B; // ver. >= 9
1778
1779typedef struct {
1780 // server -> client
1781
1782 _supla_int_t result_code;
1783 _supla_int_t ClientID;
1784 _supla_int_t LocationCount;
1785 _supla_int_t ChannelCount;
1786 _supla_int_t ChannelGroupCount;
1787 _supla_int_t Flags;
1788 unsigned char activity_timeout;
1789 unsigned char version;
1790 unsigned char version_min;
1791 unsigned _supla_int_t serverUnixTimestamp; // current server time
1792} TSC_SuplaRegisterClientResult_C; // ver. >= 17
1793
1794typedef struct {
1795 // server -> client
1796
1797 _supla_int_t result_code;
1798 _supla_int_t ClientID;
1799 _supla_int16_t LocationCount;
1800 _supla_int16_t ChannelCount;
1801 _supla_int16_t ChannelGroupCount;
1802 _supla_int16_t SceneCount;
1803 _supla_int_t Flags;
1804 unsigned char activity_timeout;
1805 unsigned char version;
1806 unsigned char version_min;
1807 unsigned _supla_int_t serverUnixTimestamp; // current server time
1808} TSC_SuplaRegisterClientResult_D; // ver. >= 19
1809
1810typedef struct {
1811 // client -> server
1812 unsigned char ChannelId;
1813 char value[SUPLA_CHANNELVALUE_SIZE];
1814} TCS_SuplaChannelNewValue; // Deprecated
1815
1816typedef struct {
1817 // client -> server
1818 _supla_int_t ChannelId;
1819 char value[SUPLA_CHANNELVALUE_SIZE];
1821
1822typedef struct {
1823 // client -> server
1824 _supla_int_t Id;
1825 char Target; // SUPLA_TARGET_
1826 char value[SUPLA_CHANNELVALUE_SIZE];
1827} TCS_SuplaNewValue; // ver. >= 9
1828
1829typedef struct {
1830 // server -> client
1831 _supla_int_t Event;
1832 _supla_int_t ChannelID;
1833 unsigned _supla_int_t DurationMS;
1834
1835 _supla_int_t SenderID;
1836 unsigned _supla_int_t
1837 SenderNameSize; // including the terminating null byte ('\0')
1838 char
1839 SenderName[SUPLA_SENDER_NAME_MAXSIZE]; // Last variable in struct! | UTF8
1841
1842typedef struct {
1843 char Platform;
1844
1845 _supla_int_t Param1;
1846 _supla_int_t Param2;
1847 _supla_int_t Param3;
1848 _supla_int_t Param4;
1850
1851typedef struct {
1852 char available_protocols;
1853 char host[SUPLA_URL_HOST_MAXSIZE];
1854 _supla_int_t port;
1855 char path[SUPLA_URL_PATH_MAXSIZE];
1857
1858typedef struct {
1859 char exists;
1862
1863typedef struct {
1864 unsigned _supla_int_t client_timestamp; // time >= now == enabled
1865 unsigned _supla_int_t iodevice_timestamp; // time >= now == enabled
1867
1868typedef struct {
1869 unsigned _supla_int_t ExpiresIn;
1870 unsigned _supla_int_t
1871 TokenSize; // including the terminating null byte ('\0')
1872 char Token[SUPLA_OAUTH_TOKEN_MAXSIZE]; // Last variable in struct!
1873} TSC_OAuthToken; // ver. >= 10
1874
1875typedef struct {
1876 unsigned char ResultCode;
1877 TSC_OAuthToken Token;
1878} TSC_OAuthTokenRequestResult; // ver. >= 10
1879
1880typedef struct {
1881 // 3 phases
1882 unsigned _supla_int16_t freq; // * 0.01 Hz
1883 unsigned _supla_int16_t voltage[3]; // * 0.01 V
1884 unsigned _supla_int16_t
1885 current[3]; // * 0.001 A (0.01 A WHEN EM_VAR_CURRENT_OVER_65A)
1886 _supla_int_t
1887 power_active[3]; // * 0.00001 W (0.00001 kW WHEN EM_VAR_POWER_ACTIVE_KW)
1888 _supla_int_t power_reactive[3]; // * 0.00001 var (0.00001 kvar WHEN
1889 // EM_VAR_POWER_REACTIVE_KVAR)
1890 _supla_int_t power_apparent[3]; // * 0.00001 VA (0.00001 kVA WHEN
1891 // EM_VAR_POWER_APPARENT_KVA)
1892 _supla_int16_t power_factor[3]; // * 0.001
1893 _supla_int16_t phase_angle[3]; // * 0.1 degree
1894} TElectricityMeter_Measurement; // v. >= 10
1895
1896#define EM_VAR_FREQ 0x0001
1897#define EM_VAR_VOLTAGE 0x0002
1898#define EM_VAR_CURRENT 0x0004
1899#define EM_VAR_POWER_ACTIVE 0x0008
1900#define EM_VAR_POWER_REACTIVE 0x0010
1901#define EM_VAR_POWER_APPARENT 0x0020
1902#define EM_VAR_POWER_FACTOR 0x0040
1903#define EM_VAR_PHASE_ANGLE 0x0080
1904#define EM_VAR_FORWARD_ACTIVE_ENERGY 0x0100
1905#define EM_VAR_REVERSE_ACTIVE_ENERGY 0x0200
1906#define EM_VAR_FORWARD_REACTIVE_ENERGY 0x0400
1907#define EM_VAR_REVERSE_REACTIVE_ENERGY 0x0800
1908#define EM_VAR_CURRENT_OVER_65A 0x1000
1909#define EM_VAR_FORWARD_ACTIVE_ENERGY_BALANCED 0x2000
1910#define EM_VAR_REVERSE_ACTIVE_ENERGY_BALANCED 0x4000
1911
1912#define EM_VAR_VOLTAGE_PHASE_ANGLE_12 0x10000 // ver. >= 25
1913#define EM_VAR_VOLTAGE_PHASE_ANGLE_13 0x20000 // ver. >= 25
1914#define EM_VAR_VOLTAGE_PHASE_SEQUENCE 0x40000 // ver. >= 25
1915#define EM_VAR_CURRENT_PHASE_SEQUENCE 0x80000 // ver. >= 25
1916
1917#define EM_VAR_POWER_ACTIVE_KW 0x100000
1918#define EM_VAR_POWER_REACTIVE_KVAR 0x200000
1919#define EM_VAR_POWER_APPARENT_KVA 0x400000
1920
1921#define EM_PHASE_SEQUENCE_VOLTAGE 0x01
1922#define EM_PHASE_SEQUENCE_CURRENT 0x02
1923
1924#if defined(__AVR__) || defined(ESP8266) || defined(ESP32) || \
1925 defined(ESP_PLATFORM) || defined(ARDUINO) || defined(SUPLA_DEVICE)
1926#define EM_MEASUREMENT_COUNT 1
1927#else
1928#define EM_MEASUREMENT_COUNT 5
1929#endif
1930
1931#ifdef USE_DEPRECATED_EMEV_V1
1932// [IODevice->Server->Client]
1933typedef struct {
1934 unsigned _supla_int64_t total_forward_active_energy[3]; // * 0.00001 kWh
1935 unsigned _supla_int64_t total_reverse_active_energy[3]; // * 0.00001 kWh
1936 unsigned _supla_int64_t total_forward_reactive_energy[3]; // * 0.00001 kvarh
1937 unsigned _supla_int64_t total_reverse_reactive_energy[3]; // * 0.00001 kvarh
1938
1939 // The price per unit, total cost and currency is overwritten by the server
1940 // total_cost == SUM(total_forward_active_energy[n] * price_per_unit
1941 _supla_int_t total_cost; // * 0.01
1942 _supla_int_t price_per_unit; // * 0.0001
1943 // Currency Code A https://www.nationsonline.org/oneworld/currencies.htm
1944 char currency[3];
1945
1946 _supla_int_t measured_values;
1947 _supla_int_t period; // Approximate period between measurements in seconds
1948 _supla_int_t m_count;
1949 TElectricityMeter_Measurement m[EM_MEASUREMENT_COUNT]; // Last variable in
1950 // struct!
1951} TElectricityMeter_ExtendedValue; // v. >= 10
1952#endif /*USE_DEPRECATED_EMEV_V1*/
1953
1954#ifdef USE_DEPRECATED_EMEV_V2
1955// [IODevice->Server->Client]
1956typedef struct {
1957 unsigned _supla_int64_t total_forward_active_energy[3]; // * 0.00001 kWh
1958 unsigned _supla_int64_t total_reverse_active_energy[3]; // * 0.00001 kWh
1959 unsigned _supla_int64_t total_forward_reactive_energy[3]; // * 0.00001 kvarh
1960 unsigned _supla_int64_t total_reverse_reactive_energy[3]; // * 0.00001 kvarh
1961 unsigned _supla_int64_t
1962 total_forward_active_energy_balanced; // * 0.00001 kWh
1963 // Vector phase-to-phase balancing
1964 unsigned _supla_int64_t
1965 total_reverse_active_energy_balanced; // * 0.00001 kWh
1966 // Vector phase-to-phase balancing
1967
1968 // The price per unit, total cost and currency is overwritten by the server
1969 // total_cost == SUM(total_forward_active_energy[n] * price_per_unit
1970 _supla_int_t total_cost; // * 0.01
1971 _supla_int_t total_cost_balanced; // * 0.01
1972 _supla_int_t price_per_unit; // * 0.0001
1973 // Currency Code A https://www.nationsonline.org/oneworld/currencies.htm
1974 char currency[3];
1975
1976 _supla_int_t measured_values;
1977 _supla_int_t period; // Approximate period between measurements in seconds
1978 _supla_int_t m_count;
1979 TElectricityMeter_Measurement m[EM_MEASUREMENT_COUNT]; // Last variable in
1980 // struct!
1981} TElectricityMeter_ExtendedValue_V2; // v. >= 12
1982#endif /*USE_DEPRECATED_EMEV_V2*/
1983
1984// [IODevice->Server->Client]
1985typedef struct {
1986 unsigned _supla_int64_t total_forward_active_energy[3]; // * 0.00001 kWh
1987 unsigned _supla_int64_t total_reverse_active_energy[3]; // * 0.00001 kWh
1988 unsigned _supla_int64_t total_forward_reactive_energy[3]; // * 0.00001 kvarh
1989 unsigned _supla_int64_t total_reverse_reactive_energy[3]; // * 0.00001 kvarh
1990 unsigned _supla_int64_t
1991 total_forward_active_energy_balanced; // * 0.00001 kWh
1992 // Vector phase-to-phase balancing
1993 unsigned _supla_int64_t
1994 total_reverse_active_energy_balanced; // * 0.00001 kWh
1995 // Vector phase-to-phase balancing
1996
1997 // Voltage phase angle between phase 1 and 2
1998 unsigned _supla_int16_t voltage_phase_angle_12; // * 0.1 degree, 0..360
1999 // Voltage phase angle between phase 1 and 3
2000 unsigned _supla_int16_t voltage_phase_angle_13; // * 0.1 degree, 0..360
2001 unsigned char phase_sequence; // bit 0x1 - voltage, bit 0x2 current
2002 // EM_PHASE_SEQUENCE_*
2003 // bit value: 0 - 123 (clockwise)
2004 // bit value: 1 - 132 (counter-clockwise)
2005
2006 // The price per unit, total cost and currency is overwritten by the server
2007 // total_cost == SUM(total_forward_active_energy[n] * price_per_unit
2008 _supla_int_t total_cost; // * 0.01
2009 _supla_int_t total_cost_balanced; // * 0.01
2010 _supla_int_t price_per_unit; // * 0.0001
2011 // Currency Code A https://www.nationsonline.org/oneworld/currencies.htm
2012 char currency[3];
2013
2014 _supla_int_t measured_values;
2015 _supla_int_t period; // Approximate period between measurements in seconds
2016 _supla_int_t m_count;
2017 TElectricityMeter_Measurement m[EM_MEASUREMENT_COUNT]; // Last variable in
2018 // struct!
2020
2021#define EM_VALUE_FLAG_PHASE1_ON 0x01
2022#define EM_VALUE_FLAG_PHASE2_ON 0x02
2023#define EM_VALUE_FLAG_PHASE3_ON 0x04
2024
2025// [IODevice->Server->Client]
2026typedef struct {
2027 char flags;
2028 unsigned _supla_int_t total_forward_active_energy; // * 0.01 kW
2029} TElectricityMeter_Value; // v. >= 10
2030
2031typedef struct {
2032 // The price per unit, total cost and currency is overwritten by the server
2033 // total_cost = calculated_value * price_per_unit
2034 _supla_int_t total_cost; // * 0.01
2035 _supla_int_t price_per_unit; // * 0.0001
2036 // Currency Code A https://www.nationsonline.org/oneworld/currencies.htm
2037 char currency[3];
2038 char custom_unit[9]; // UTF8 including the terminating null byte ('\0')
2039
2040 _supla_int_t impulses_per_unit;
2041 unsigned _supla_int64_t counter;
2042 _supla_int64_t calculated_value; // * 0.001
2044
2045typedef struct {
2046 unsigned _supla_int64_t counter;
2048
2049#define RS_VALUE_FLAG_TILT_IS_SET 0x1
2050#define RS_VALUE_FLAG_CALIBRATION_FAILED 0x2
2051#define RS_VALUE_FLAG_CALIBRATION_LOST 0x4
2052#define RS_VALUE_FLAG_MOTOR_PROBLEM 0x8
2053#define RS_VALUE_FLAG_CALIBRATION_IN_PROGRESS 0x10
2054
2055#define SUPLA_TILT_CONTROL_TYPE_UNKNOWN 0
2056#define SUPLA_TILT_CONTROL_TYPE_STANDS_IN_POSITION_WHILE_TILTING 1
2057#define SUPLA_TILT_CONTROL_TYPE_CHANGES_POSITION_WHILE_TILTING 2
2058#define SUPLA_TILT_CONTROL_TYPE_TILTS_ONLY_WHEN_FULLY_CLOSED 3
2059
2060// Roller shutter channel value payload
2061// Device -> Server -> Client
2062typedef struct {
2063 signed char position; // -1 == calibration. -1, 0% (open) - 100% (closed) DSC
2064 char reserved1;
2065 signed char bottom_position; // Percentage points to the windowsill, SC
2066 _supla_int16_t flags; // DSC
2067 char reserved2;
2068 char reserved3;
2069 char reserved4;
2071
2072typedef TDSC_RollerShutterValue TDSC_TerraceAwningValue;
2073typedef TDSC_RollerShutterValue TDSC_ProjectorScreen;
2074typedef TDSC_RollerShutterValue TDSC_CurtainValue;
2075typedef TDSC_RollerShutterValue TDSC_RollerGarageDoor;
2076
2077// Roller shutter channel value payload
2078// Client -> Server -> Device
2079typedef struct {
2080 signed char position; // 0 - STOP
2081 // 1 - DOWN (CLOSE)
2082 // 2 - UP (OPEN)
2083 // 3 - DOWN_OR_STOP (CLOSE_OR_STOP)
2084 // 4 - UP_OR_STOP (OPEN_OR_STOP)
2085 // 5 - STEP_BY_STEP
2086 // 10-110 - target position + 10 (0 open, 100 closed)
2087 char reserved[7];
2089
2090typedef TCSD_RollerShutterValue TCSD_TerraceAwningValue;
2091typedef TCSD_RollerShutterValue TCSD_ProjectorScreen;
2092typedef TCSD_RollerShutterValue TCSD_CurtainValue;
2093typedef TCSD_RollerShutterValue TCSD_RollerGarageDoor;
2094
2095// Facade blind channel value payload
2096// Device -> Server -> Client
2097typedef struct {
2098 signed char position; // -1 == calibration. -1, 0% (open) - 100% (closed) DSC
2099 signed char tilt; // -1 == not used/calibration, -1, 0% - 100%, DSC
2100 char reserved;
2101 _supla_int16_t flags; // DSC
2102 char reserved2[3];
2104
2105typedef TDSC_FacadeBlindValue TDSC_VerticalBlindValue;
2106
2107// Facade blind channel value payload
2108// Client -> Server -> Device
2109typedef struct {
2110 signed char position; // -1 - not set (actual behavior is device specific)
2111 // 0 - STOP
2112 // 1 - DOWN (CLOSE)
2113 // 2 - UP (OPEN)
2114 // 3 - DOWN_OR_STOP (CLOSE_OR_STOP)
2115 // 4 - UP_OR_STOP (OPEN_OR_STOP)
2116 // 5 - STEP_BY_STEP
2117 // 10-110 - target position + 10 (0 open, 100 closed)
2118 signed char tilt; // -1 - not set (actual behavior is device specific)
2119 // 10-110 - target position + 10
2120 char reserved[6];
2122
2123typedef TCSD_FacadeBlindValue TCSD_VerticalBlindValue;
2124
2125typedef struct {
2126 unsigned _supla_int64_t calculated_value; // * 0.001
2127} TSC_ImpulseCounter_Value; // v. >= 10
2128
2129typedef struct {
2130 char Email[SUPLA_EMAIL_MAXSIZE]; // UTF8
2131 char Password[SUPLA_PASSWORD_MAXSIZE]; // UTF8
2133
2134typedef struct {
2135 _supla_int_t Result;
2137
2138#define SUPLA_CALCFG_RESULT_FALSE 0 // ver. >= 12
2139#define SUPLA_CALCFG_RESULT_TRUE 1 // ver. >= 12
2140#define SUPLA_CALCFG_RESULT_DONE 2 // ver. >= 12
2141#define SUPLA_CALCFG_RESULT_IN_PROGRESS 3 // ver. >= 12
2142#define SUPLA_CALCFG_RESULT_NODE_FOUND 4 // ver. >= 12
2143#define SUPLA_CALCFG_RESULT_SENDER_CONFLICT 100 // ver. >= 12
2144#define SUPLA_CALCFG_RESULT_TIMEOUT 101 // ver. >= 12
2145#define SUPLA_CALCFG_RESULT_NOT_SUPPORTED 102 // ver. >= 12
2146#define SUPLA_CALCFG_RESULT_ID_NOT_EXISTS 103 // ver. >= 12
2147#define SUPLA_CALCFG_RESULT_UNAUTHORIZED 104 // ver. >= 12
2148#define SUPLA_CALCFG_RESULT_DEBUG 105 // ver. >= 12
2149#define SUPLA_CALCFG_RESULT_NOT_SUPPORTED_IN_SLAVE_MODE 106 // ver. >= 12
2150
2151#define SUPLA_CALCFG_CMD_GET_CHANNEL_FUNCLIST 1000 // v. >= 11
2152#define SUPLA_CALCFG_CMD_CANCEL_ALL_CLIENT_COMMANDS 1010 // v. >= 12
2153#define SUPLA_CALCFG_CMD_ZWAVE_RESET_AND_CLEAR 2000 // v. >= 12
2154#define SUPLA_CALCFG_CMD_ZWAVE_ADD_NODE 2010 // v. >= 12
2155#define SUPLA_CALCFG_CMD_ZWAVE_REMOVE_NODE 2020 // v. >= 12
2156#define SUPLA_CALCFG_CMD_ZWAVE_GET_NODE_LIST 2030 // v. >= 12
2157#define SUPLA_CALCFG_CMD_ZWAVE_GET_ASSIGNED_NODE_ID 2040 // v. >= 12
2158#define SUPLA_CALCFG_CMD_ZWAVE_ASSIGN_NODE_ID 2050 // v. >= 12
2159#define SUPLA_CALCFG_CMD_ZWAVE_GET_WAKE_UP_SETTINGS 2060 // v. >= 12
2160#define SUPLA_CALCFG_CMD_ZWAVE_SET_WAKE_UP_TIME 2070 // v. >= 12
2161#define SUPLA_CALCFG_CMD_ZWAVE_CONFIG_MODE_ACTIVE 4000 // v. >= 12
2162#define SUPLA_CALCFG_CMD_DEBUG_STRING 5000 // v. >= 12
2163#define SUPLA_CALCFG_CMD_PROGRESS_REPORT 5001 // v. >= 12
2164#define SUPLA_CALCFG_CMD_SET_LIGHTSOURCE_LIFESPAN 6000 // v. >= 12
2165#define SUPLA_CALCFG_CMD_RESET_COUNTERS 7000 // v. >= 15
2166#define SUPLA_CALCFG_CMD_RECALIBRATE 8000 // v. >= 15
2167#define SUPLA_CALCFG_CMD_ENTER_CFG_MODE 9000 // v. >= 17
2168#define SUPLA_CALCFG_CMD_RESET_TO_FACTORY_SETTINGS 9010 // v. >= 28
2169#define SUPLA_CALCFG_CMD_CHECK_FIRMWARE_UPDATE 9020 // v. >= 28
2170#define SUPLA_CALCFG_CMD_START_FIRMWARE_UPDATE 9030 // v. >= 28
2171#define SUPLA_CALCFG_CMD_START_SECURITY_UPDATE 9040 // v. >= 28
2172#define SUPLA_CALCFG_CMD_SET_CFG_MODE_PASSWORD 9050 // v. >= 28
2173#define SUPLA_CALCFG_CMD_SET_TIME 9100 // v. >= 21
2174#define SUPLA_CALCFG_CMD_START_SUBDEVICE_PAIRING 9200 // v. >= 25
2175#define SUPLA_CALCFG_CMD_IDENTIFY_DEVICE 9300 // v. >= 25
2176#define SUPLA_CALCFG_CMD_IDENTIFY_SUBDEVICE 9310 // v. >= 25
2177#define SUPLA_CALCFG_CMD_RESTART_DEVICE 9400 // v. >= 25
2178#define SUPLA_CALCFG_CMD_RESTART_SUBDEVICE 9410 // v. >= 25
2179#define SUPLA_CALCFG_CMD_TAKE_OCR_PHOTO 9420 // v. >= 25
2180#define SUPLA_CALCFG_CMD_MUTE_ALARM_SOUND 9430 // v. >= 26
2181
2182#define SUPLA_CALCFG_DATATYPE_RS_SETTINGS 1000
2183#define SUPLA_CALCFG_DATATYPE_FB_SETTINGS 1100 // v. >= 17
2184
2185#define CALCFG_ZWAVE_SCREENTYPE_UNKNOWN 0
2186#define CALCFG_ZWAVE_SCREENTYPE_MULTILEVEL 1
2187#define CALCFG_ZWAVE_SCREENTYPE_BINARY 2
2188#define CALCFG_ZWAVE_SCREENTYPE_MULTILEVEL_AUTOSHADE 3
2189#define CALCFG_ZWAVE_SCREENTYPE_MULTILEVEL_COLOR_CONTROL 4
2190#define CALCFG_ZWAVE_SCREENTYPE_BINARY_COLOR_CONTROL 5
2191#define CALCFG_ZWAVE_SCREENTYPE_SENSOR 6
2192
2193#define ZWAVE_NODE_NAME_MAXSIZE 50
2194
2195#define ZWAVE_NODE_FLAG_CHANNEL_ASSIGNED 0x1
2196#define ZWAVE_NODE_FLAG_WAKEUP_TIME_SETTABLE 0x2
2197
2198typedef struct {
2199 unsigned char Id;
2200 unsigned char Flags;
2201 union {
2202 unsigned char ChannelNumber;
2203 _supla_int_t ChannelID;
2204 };
2205 unsigned char ScreenType;
2206 unsigned char NameSize; // including the terminating null byte ('\0')
2207 char Name[ZWAVE_NODE_NAME_MAXSIZE]; // UTF8. Last variable in struct!
2208} TCalCfg_ZWave_Node; // v. >= 12
2209
2210typedef struct {
2211 unsigned _supla_int_t MinimumSec : 24;
2212 unsigned _supla_int_t MaximumSec : 24;
2213 unsigned _supla_int_t ValueSec : 24;
2214 unsigned _supla_int_t IntervalStepSec : 24;
2216
2217typedef struct {
2218 unsigned _supla_int_t TimeSec : 24;
2220
2221typedef struct {
2222 _supla_int_t Command;
2223 unsigned char Progress; // 0 - 100%
2225
2226typedef struct {
2227 unsigned char ResetCounter; // 0 - NO, 1 - YES
2228 unsigned char SetTime; // 0 - NO, 1 - YES
2229 unsigned _supla_int16_t LightSourceLifespan; // 0 - 65535 hours
2231
2232#define SUPLA_CALCFG_SUBDEVICE_NAME_MAXSIZE 120
2233
2234// Subdevice Pairing result is send in TDS_DeviceCalCfgResult. Possible values:
2235// SUPLA_CALCFG_RESULT_TRUE - paring result/status is in Data
2236// SUPLA_CALCFG_RESULT_UNAUTHORIZED - unauthorized
2237// SUPLA_CALCFG_RESULT_NOT_SUPPORTED - not supported
2238// Only in case of TRUE, TCalCfg_SubdevicePairingResult is included in
2239// TDS_DeviceCalCfgResult.
2240#define SUPLA_CALCFG_PAIRINGRESULT_PROCEDURE_STARTED 0
2241#define SUPLA_CALCFG_PAIRINGRESULT_ONGOING 1
2242#define SUPLA_CALCFG_PAIRINGRESULT_NO_NEW_DEVICE_FOUND 2
2243#define SUPLA_CALCFG_PAIRINGRESULT_SUCCESS 3
2244#define SUPLA_CALCFG_PAIRINGRESULT_DEVICE_NOT_SUPPORTED 4
2245#define SUPLA_CALCFG_PAIRINGRESULT_RESOURCES_LIMIT_EXCEEDED 5
2246#define SUPLA_CALCFG_PAIRINGRESULT_NOT_STARTED_NOT_READY 6
2247#define SUPLA_CALCFG_PAIRINGRESULT_NOT_STARTED_BUSY 7
2248
2249typedef struct {
2250 unsigned _supla_int16_t
2251 ElapsedTimeSec; // Time in seconds since procedure was started
2252 unsigned _supla_int16_t MaximumDurationSec; // Time in seconds
2253 unsigned char PairingResult; // SUPLA_CALCFG_PAIRINGRESULT_
2254 unsigned char NameSize; // including the terminating null byte ('\0')
2255 char Name[SUPLA_CALCFG_SUBDEVICE_NAME_MAXSIZE]; // UTF8. Last variable in
2256 // struct!
2257} TCalCfg_SubdevicePairingResult; // v. >= 25
2258
2259// CALCFG == CALIBRATION / CONFIG
2260typedef struct {
2261 _supla_int_t ChannelID;
2262 _supla_int_t Command;
2263 _supla_int_t DataType;
2264 unsigned _supla_int_t DataSize;
2265 char Data[SUPLA_CALCFG_DATA_MAXSIZE]; // Last variable in struct!
2266} TCS_DeviceCalCfgRequest; // v. >= 10
2267
2268// CALCFG == CALIBRATION / CONFIG
2269typedef struct {
2270 _supla_int_t Id;
2271 char Target; // SUPLA_TARGET_
2272 _supla_int_t Command;
2273 _supla_int_t DataType;
2274 unsigned _supla_int_t DataSize;
2275 char Data[SUPLA_CALCFG_DATA_MAXSIZE]; // Last variable in struct!
2276} TCS_DeviceCalCfgRequest_B; // v. >= 11
2277
2278typedef struct {
2279 _supla_int_t ChannelID;
2280 _supla_int_t Command;
2281 _supla_int_t Result;
2282 unsigned _supla_int_t DataSize;
2283 char Data[SUPLA_CALCFG_DATA_MAXSIZE]; // Last variable in struct!
2284} TSC_DeviceCalCfgResult; // v. >= 10
2285
2286typedef struct {
2287 _supla_int_t SenderID;
2288 _supla_int_t ChannelNumber;
2289 _supla_int_t Command;
2290 char SuperUserAuthorized;
2291 _supla_int_t DataType;
2292 unsigned _supla_int_t DataSize;
2293 char Data[SUPLA_CALCFG_DATA_MAXSIZE]; // Last variable in struct!
2294} TSD_DeviceCalCfgRequest; // v. >= 10
2295
2296typedef struct {
2297 _supla_int_t ReceiverID;
2298 _supla_int_t ChannelNumber;
2299 _supla_int_t Command;
2300 _supla_int_t Result;
2301 unsigned _supla_int_t DataSize;
2302 char Data[SUPLA_CALCFG_DATA_MAXSIZE]; // Last variable in struct!
2303} TDS_DeviceCalCfgResult; // v. >= 10
2304
2305// Used in CALCFG recalibrate command
2306typedef struct {
2307 _supla_int_t FullOpeningTimeMS;
2308 _supla_int_t FullClosingTimeMS;
2310
2311#define SUPLA_FIRMWARE_CHECK_RESULT_UPDATE_NOT_AVAILABLE 0
2312#define SUPLA_FIRMWARE_CHECK_RESULT_UPDATE_AVAILABLE 1
2313#define SUPLA_FIRMWARE_CHECK_RESULT_ERROR 2
2314
2315typedef struct {
2316 unsigned char Result; // SUPLA_FIRMWARE_CHECK_RESULT_
2317 char SoftVer[SUPLA_SOFTVER_MAXSIZE];
2318 char ChangelogUrl[SUPLA_URL_PATH_MAXSIZE];
2319} TCalCfg_FirmwareCheckResult; // v. >= 28
2320
2321// SetCfgModePassword result is send in TDS_DeviceCalCfgResult. Possible values:
2322// SUPLA_CALCFG_RESULT_TRUE - password successfully changed
2323// SUPLA_CALCFG_RESULT_UNAUTHORIZED - unauthorized
2324// SUPLA_CALCFG_RESULT_NOT_SUPPORTED - not supported
2325// SUPLA_CALCFG_RESULT_FALSE - password change failed (i.e. don't meet security
2326// requirements)
2327
2328typedef struct {
2329 // New password should be at least 8 characters long, at least one uppercase
2330 // letter, one lowercase letter and one number
2331 char NewPassword[SUPLA_PASSWORD_MAXSIZE];
2332} TCalCfg_SetCfgModePassword; // v. >= 28
2333
2334#define RGBW_BRIGHTNESS_ONOFF 0x1
2335#define RGBW_COLOR_ONOFF 0x2
2336
2337// Values from other fields are applied in a standard way
2338#define RGBW_COMMAND_NOT_SET 0
2339// Ignores all other bytes and turns on the dimmer
2340#define RGBW_COMMAND_TURN_ON_DIMMER 1
2341// Ignores all other bytes and turns off the dimmer
2342#define RGBW_COMMAND_TURN_OFF_DIMMER 2
2343// Ignores all other bytes and toggles the dimmer
2344#define RGBW_COMMAND_TOGGLE_DIMMER 3
2345// Ignores all other bytes and turns on the RGB
2346#define RGBW_COMMAND_TURN_ON_RGB 4
2347// Ignores all other bytes and turns off the RGB
2348#define RGBW_COMMAND_TURN_OFF_RGB 5
2349// Ignores all other bytes and toggles the RGB
2350#define RGBW_COMMAND_TOGGLE_RGB 6
2351// Ignores all other bytes and turns on the RGB and Dimmer
2352#define RGBW_COMMAND_TURN_ON_ALL 7
2353// Ignores all other bytes and turns off the RGB and Dimmer
2354#define RGBW_COMMAND_TURN_OFF_ALL 8
2355// Ignores all other bytes and toggles the RGB and Dimmer (with sync, so both
2356// will be off or both will be on)
2357#define RGBW_COMMAND_TOGGLE_ALL 9
2358// Stores brightness value and ignores all other bytes, if dimmer is off, it
2359// stays off
2360#define RGBW_COMMAND_SET_BRIGHTNESS_WITHOUT_TURN_ON 10
2361// Stores colorBrightness value and ignores all other bytes.
2362// If RGB is off, it stays off
2363#define RGBW_COMMAND_SET_COLOR_BRIGHTNESS_WITHOUT_TURN_ON 11
2364// Stores color value (R, G, B) and ignores all other bytes.
2365// If RGB is off, it stays off
2366#define RGBW_COMMAND_SET_RGB_WITHOUT_TURN_ON 12
2367// Start brightness dimmer adjustment (0..100..0 etc)
2368#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_DIMMER_START 13
2369// Start color brightness adjustment
2370#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_COLOR_START 14
2371// Start dimmer and rgb brightness adjustment
2372#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_ALL_START 15
2373// Stop brightness dimmer adjustment
2374#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_DIMMER_STOP 16
2375// Stop color brightness adjustment
2376#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_COLOR_STOP 17
2377// Stop dimmer and rgb brightness adjustment
2378#define RGBW_COMMAND_BRIGHTNESS_ADJUSTMENT_ALL_STOP 18
2379// Store dimmer white temperature value and ignores all other bytes
2380#define RGBW_COMMAND_SET_WHITE_TEMPERATURE_WITHOUT_TURN_ON 19
2381
2382typedef struct {
2383 char brightness; // 0..100
2384 char colorBrightness; // 0..100
2385 unsigned char B; // 0..255
2386 unsigned char G; // 0..255
2387 unsigned char R; // 0..255
2388 char onOff;
2389 char command; // RGBW_COMMAND_, requires
2390 // SUPLA_CHANNEL_FLAG_RGBW_COMMANDS_SUPPORTED v. >= 21
2391 char whiteTemperature; // v. >= 25, 0..100 (0 warm, 50 neutral, 100 cold)
2392} TRGBW_Value; // v. >= 10
2393
2394#define SUPLA_RELAY_FLAG_OVERCURRENT_RELAY_OFF 0x1
2395
2396typedef struct {
2397 char hi; // actual state of relay - 0 turned off, >= 1 - turned on
2398 unsigned _supla_int16_t flags; // SUPLA_RELAY_FLAG_*
2399} TRelayChannel_Value; // v. >= 15
2400
2401#define DIGIGLASS_TOO_LONG_OPERATION_WARNING 0x1
2402#define DIGIGLASS_PLANNED_REGENERATION_IN_PROGRESS 0x2
2403#define DIGIGLASS_REGENERATION_AFTER_20H_IN_PROGRESS 0x4
2404
2405typedef struct {
2406 unsigned char flags;
2407 unsigned char sectionCount; // 1 - 16 Filled by server
2408 unsigned _supla_int16_t mask; // bit mask. 0 - opaque, 1 - transparent
2409} TDigiglass_Value; // v. >= 14
2410
2411typedef struct {
2412 unsigned _supla_int16_t mask; // Bit mask. 0 - opaque, 1 - transparent
2413 unsigned _supla_int16_t
2414 active_bits; // Specifies which bits of the mask are not skipped
2415} TCSD_Digiglass_NewValue; // v. >= 14
2416
2417#define CONTAINER_FLAG_WARNING_LEVEL (1 << 0)
2418#define CONTAINER_FLAG_ALARM_LEVEL (1 << 1)
2419#define CONTAINER_FLAG_INVALID_SENSOR_STATE (1 << 2)
2420#define CONTAINER_FLAG_SOUND_ALARM_ON (1 << 3)
2421
2422typedef struct {
2423 unsigned char level; // 0 - unknown; 1-101 - container fill level 0-100%
2424 unsigned _supla_int16_t flags; // CONTAINER_FLAG_*
2425} TContainerChannel_Value; // v. >= 26
2426
2427typedef struct {
2428 unsigned char sec; // 0-59
2429 unsigned char min; // 0-59
2430 unsigned char hour; // 0-24
2431 unsigned char dayOfWeek; // 1 = Sunday, 2 = Monday, …, 7 = Saturday
2432} TThermostat_Time; // v. >= 11
2433
2434#define THERMOSTAT_SCHEDULE_DAY_SUNDAY 0x01
2435#define THERMOSTAT_SCHEDULE_DAY_MONDAY 0x02
2436#define THERMOSTAT_SCHEDULE_DAY_TUESDAY 0x04
2437#define THERMOSTAT_SCHEDULE_DAY_WEDNESDAY 0x08
2438#define THERMOSTAT_SCHEDULE_DAY_THURSDAY 0x10
2439#define THERMOSTAT_SCHEDULE_DAY_FRIDAY 0x20
2440#define THERMOSTAT_SCHEDULE_DAY_SATURDAY 0x40
2441#define THERMOSTAT_SCHEDULE_DAY_ALL 0xFF
2442
2443#define THERMOSTAT_SCHEDULE_HOURVALUE_TYPE_TEMPERATURE 0
2444#define THERMOSTAT_SCHEDULE_HOURVALUE_TYPE_PROGRAM 1
2445
2446typedef struct {
2447 unsigned char ValueType; // THERMOSTAT_SCHEDULE_HOURVALUE_TYPE_
2448 char HourValue[7][24]; // 7 days x 24h
2449 // 0 = Sunday, 1 = Monday, …, 6 = Saturday
2450} TThermostat_Schedule; // v. >= 11
2451
2452typedef struct {
2453 unsigned char ValueType; // THERMOSTAT_SCHEDULE_HOURVALUE_TYPE_
2454 unsigned char WeekDays; // THERMOSTAT_SCHEDULE_DAY_
2455 char HourValue[24];
2456} TThermostatValueGroup; // v. >= 11
2457
2458// Used in Heatpol ESP8266 based thermostat
2459typedef struct {
2460 TThermostatValueGroup Group[4];
2461} TThermostat_ScheduleCfg; // v. >= 11
2462
2463// Temperature definitions for Heatpol ESP8266 based thermostat
2464// TThermostatTemperatureCfg
2465#define TEMPERATURE_INDEX1 0x0001
2466#define TEMPERATURE_INDEX2 0x0002
2467#define TEMPERATURE_INDEX3 0x0004
2468#define TEMPERATURE_INDEX4 0x0008
2469#define TEMPERATURE_INDEX5 0x0010
2470#define TEMPERATURE_INDEX6 0x0020
2471#define TEMPERATURE_INDEX7 0x0040
2472#define TEMPERATURE_INDEX8 0x0080
2473#define TEMPERATURE_INDEX9 0x0100
2474#define TEMPERATURE_INDEX10 0x0200
2475// TThermostatTemperatureCfg has only 10 fields
2476
2477// Used in Heatpol ESP8266 based thermostat
2478typedef struct {
2479 _supla_int16_t Index; // BIT0 Temperature[0], BIT1 Temperature[1] etc...
2480 unsigned _supla_int16_t Temperature[10];
2482
2483// Temperature definitions for HVAC
2484// THVACTemperatureCfg
2485// Below values are settable by user in UI
2486// Temperature below which heating will be enabled as a freeze protection
2487#define TEMPERATURE_FREEZE_PROTECTION (1ULL << 0)
2488// Economic temperaturey
2489#define TEMPERATURE_ECO (1ULL << 1)
2490// Comfort temperature
2491#define TEMPERATURE_COMFORT (1ULL << 2)
2492#define TEMPERATURE_BOOST (1ULL << 3)
2493// Temperature above which cooling will be enabled as an overheating protection.
2494#define TEMPERATURE_HEAT_PROTECTION (1ULL << 4)
2495// Histeresis value - i.e. heating will be enabled when current temperature
2496// is histeresis/2 lower than current setpoint.
2497#define TEMPERATURE_HISTERESIS (1ULL << 5)
2498// AUX histeresis value - used to determine heating based on AUX temperature
2499// If aux histeresis is missing, then TEMPERATURE_HISTERESIS is used
2500#define TEMPERATURE_AUX_HISTERESIS (1ULL << 18)
2501// Turns on "alarm" when temperature is below this value. Can be visual effect
2502// or sound (if device is capable). It can also send AT to server (TBD)
2503#define TEMPERATURE_BELOW_ALARM (1ULL << 6)
2504// As above, but for tempertatures above threshold
2505#define TEMPERATURE_ABOVE_ALARM (1ULL << 7)
2506// Minimum temperature to be kept on heat/cold source (i.e. keeps floor always
2507// at least 19 degrees)
2508#define TEMPERATURE_AUX_MIN_SETPOINT (1ULL << 8)
2509// Maximum temperature to be kept on heat/cold source (i.e. protect floor
2510// from overheating and keep at most 28 degrees)
2511#define TEMPERATURE_AUX_MAX_SETPOINT (1ULL << 9)
2512
2513// Below values are readonly for user
2514// Minimum room (main thermometer) temperature to be set by user
2515#define TEMPERATURE_ROOM_MIN (1ULL << 10)
2516// Maximum room (main thermometer) temperature to be set by user
2517#define TEMPERATURE_ROOM_MAX (1ULL << 11)
2518// Minimum allowed temperature for heat/cold source (used with second
2519// thermomter for floor/water/etc.)
2520#define TEMPERATURE_AUX_MIN (1ULL << 12)
2521// Maximum allowed temperature for heat/cold source
2522#define TEMPERATURE_AUX_MAX (1ULL << 13)
2523// Minimum histereis value
2524#define TEMPERATURE_HISTERESIS_MIN (1ULL << 14)
2525// Maximum histereis value
2526#define TEMPERATURE_HISTERESIS_MAX (1ULL << 15)
2527// Minimum temperature offset in HEAT_COOL mode
2528#define TEMPERATURE_HEAT_COOL_OFFSET_MIN (1ULL << 16)
2529// Maximum temperature offset in HEAT_COOL mode
2530#define TEMPERATURE_HEAT_COOL_OFFSET_MAX (1ULL << 17)
2531// 5 values left for future use (value << 18 is defined earlier)
2532
2533#define SUPLA_TEMPERATURE_INVALID_INT16 -32768
2534
2535// Used in Supla Thermostat
2536typedef struct {
2537 unsigned _supla_int_t Index; // BIT0 Temperature[0], BIT1 Temperature[1]
2538 // etc...
2539 _supla_int16_t Temperature[24];
2541
2542// Heatpol ESP8266 based: Thermostat configuration commands - ver. >= 11
2543#define SUPLA_THERMOSTAT_CMD_TURNON 1
2544#define SUPLA_THERMOSTAT_CMD_SET_MODE_AUTO 2
2545#define SUPLA_THERMOSTAT_CMD_SET_MODE_COOL 3
2546#define SUPLA_THERMOSTAT_CMD_SET_MODE_HEAT 4
2547#define SUPLA_THERMOSTAT_CMD_SET_MODE_NORMAL 5
2548#define SUPLA_THERMOSTAT_CMD_SET_MODE_ECO 6
2549#define SUPLA_THERMOSTAT_CMD_SET_MODE_TURBO 7
2550#define SUPLA_THERMOSTAT_CMD_SET_MODE_DRY 8
2551#define SUPLA_THERMOSTAT_CMD_SET_MODE_FANONLY 9
2552#define SUPLA_THERMOSTAT_CMD_SET_MODE_PURIFIER 10
2553#define SUPLA_THERMOSTAT_CMD_SET_SCHEDULE 11
2554#define SUPLA_THERMOSTAT_CMD_SET_TIME 12
2555#define SUPLA_THERMOSTAT_CMD_SET_TEMPERATURE 13
2556
2557// Heatpol ESP8266 based: Thermostat value flags - ver. >= 11
2558#define SUPLA_THERMOSTAT_VALUE_FLAG_ON 0x0001
2559#define SUPLA_THERMOSTAT_VALUE_FLAG_AUTO_MODE 0x0002
2560#define SUPLA_THERMOSTAT_VALUE_FLAG_COOL_MODE 0x0004
2561#define SUPLA_THERMOSTAT_VALUE_FLAG_HEAT_MODE 0x0008
2562#define SUPLA_THERMOSTAT_VALUE_FLAG_ECO_MODE 0x0010
2563#define SUPLA_THERMOSTAT_VALUE_FLAG_DRY_MODE 0x0020
2564#define SUPLA_THERMOSTAT_VALUE_FLAG_FANONLY_MODE 0x0040
2565#define SUPLA_THERMOSTAT_VALUE_FLAG_PURIFIER_MODE 0x0080
2566
2567// Heatpol ESP8266 based: Thermostat fields - ver. >= 11
2568#define THERMOSTAT_FIELD_MeasuredTemperatures 0x01
2569#define THERMOSTAT_FIELD_PresetTemperatures 0x02
2570#define THERMOSTAT_FIELD_Flags 0x04
2571#define THERMOSTAT_FIELD_Values 0x08
2572#define THERMOSTAT_FIELD_Time 0x10
2573#define THERMOSTAT_FIELD_Schedule 0x20
2574
2575// Used in Heatpol ESP8266 based only
2576typedef struct {
2577 unsigned char Fields;
2578 _supla_int16_t MeasuredTemperature[10]; // * 0.01
2579 _supla_int16_t PresetTemperature[10]; // * 0.01
2580 _supla_int16_t Flags[8];
2581 _supla_int16_t Values[8];
2582 TThermostat_Time Time;
2583 TThermostat_Schedule Schedule; // 7 days x 24h (4bit/hour)
2584} TThermostat_ExtendedValue; // v. >= 11
2585
2586// Used in Heatpol ESP8266 based only
2587typedef struct {
2588 unsigned char IsOn;
2589 unsigned char Flags;
2590 _supla_int16_t MeasuredTemperature; // * 0.01
2591 _supla_int16_t PresetTemperature; // * 0.01
2592} TThermostat_Value; // v. >= 11
2593
2594typedef struct {
2595 unsigned _supla_int16_t year;
2596 unsigned char month;
2597 unsigned char day;
2598 unsigned char dayOfWeek; // 1 = Sunday, 2 = Monday, …, 7 = Saturday
2599 unsigned char hour;
2600 unsigned char min;
2601 unsigned char sec;
2602 unsigned _supla_int_t
2603 timezoneSize; // including the terminating null byte ('\0')
2604 char timezone[SUPLA_TIMEZONE_MAXSIZE]; // Last variable in struct!
2606
2607typedef struct {
2608 _supla_int_t SenderID;
2609 union {
2610 _supla_int_t ChannelID; // Client -> Server
2611 unsigned char ChannelNumber; // Server -> Device
2612 };
2613} TCSD_ChannelStateRequest; // v. >= 12 Client -> Server -> Device
2614
2615#define SUPLA_CHANNELSTATE_FIELD_IPV4 0x0001
2616#define SUPLA_CHANNELSTATE_FIELD_MAC 0x0002
2617#define SUPLA_CHANNELSTATE_FIELD_BATTERYLEVEL 0x0004
2618#define SUPLA_CHANNELSTATE_FIELD_BATTERYPOWERED 0x0008
2619#define SUPLA_CHANNELSTATE_FIELD_WIFIRSSI 0x0010
2620#define SUPLA_CHANNELSTATE_FIELD_WIFISIGNALSTRENGTH 0x0020
2621#define SUPLA_CHANNELSTATE_FIELD_BRIDGENODESIGNALSTRENGTH 0x0040
2622#define SUPLA_CHANNELSTATE_FIELD_UPTIME 0x0080
2623#define SUPLA_CHANNELSTATE_FIELD_CONNECTIONUPTIME 0x0100
2624#define SUPLA_CHANNELSTATE_FIELD_BATTERYHEALTH 0x0200
2625#define SUPLA_CHANNELSTATE_FIELD_BRIDGENODEONLINE 0x0400
2626#define SUPLA_CHANNELSTATE_FIELD_LASTCONNECTIONRESETCAUSE 0x0800
2627// When LIGHTSOURCELIFESPAN is set then LightSourceLifespan field is used.
2628// Additionally when LIGHTSOURCEOPERATINGTIME and OPERATINGTIME are NOT set,
2629// then LightSourceLifespanLeft is also used.
2630#define SUPLA_CHANNELSTATE_FIELD_LIGHTSOURCELIFESPAN 0x1000
2631// LIGHTSOURCEOPERATINGTIME, and OPERATINGTIME are mutually exclusive. Use only
2632// one of them.
2633#define SUPLA_CHANNELSTATE_FIELD_LIGHTSOURCEOPERATINGTIME 0x2000
2634// OPERATINGTIME is not implemented in apps
2635#define SUPLA_CHANNELSTATE_FIELD_OPERATINGTIME 0x4000
2636// SWITCHCYCLECOUNT and defualtIconField are mutually exclusive. Use only one
2637// of them.
2638#define SUPLA_CHANNELSTATE_FIELD_SWITCHCYCLECOUNT 0x8000
2639#define SUPLA_CHANNELSTATE_FIELD_DEVICE_BATTERYLEVEL 0x10000
2640
2641#define SUPLA_LASTCONNECTIONRESETCAUSE_UNKNOWN 0
2642#define SUPLA_LASTCONNECTIONRESETCAUSE_ACTIVITY_TIMEOUT 1
2643#define SUPLA_LASTCONNECTIONRESETCAUSE_WIFI_CONNECTION_LOST 2
2644#define SUPLA_LASTCONNECTIONRESETCAUSE_SERVER_CONNECTION_LOST 3
2645
2646typedef struct {
2647 _supla_int_t ReceiverID; // Not used in extended values
2648 union {
2649 // Not used in extended values
2650 _supla_int_t ChannelID; // Server -> Client
2651 unsigned char ChannelNumber; // Device -> Server
2652 };
2653 _supla_int_t Fields; // SUPLA_CHANNELSTATE_FIELD_*
2654 union {
2655 _supla_int_t defaultIconField;
2656 unsigned _supla_int_t SwitchCycleCount;
2657 };
2658 unsigned _supla_int_t IPv4;
2659 unsigned char MAC[6];
2660 unsigned char BatteryLevel; // 0 - 100%
2661 unsigned char BatteryPowered; // true(1)/false(0)
2662 char WiFiRSSI;
2663 unsigned char WiFiSignalStrength; // 0 - 100%
2664 unsigned char BridgeNodeOnline; // 0/1
2665 unsigned char BridgeNodeSignalStrength; // 0 - 100%
2666 unsigned _supla_int_t Uptime; // sec.
2667 unsigned _supla_int_t ConnectionUptime; // sec.
2668 unsigned char BatteryHealth;
2669 unsigned char LastConnectionResetCause; // SUPLA_LASTCONNECTIONRESETCAUSE_*
2670 unsigned _supla_int16_t LightSourceLifespan; // 0 - 65535 hours
2671 union {
2672 _supla_int16_t LightSourceLifespanLeft; // valid range: -32767 - 10000,
2673 // unit 0.01%, so 10000 = 100%
2674 // -32767 = -327.67%
2675 _supla_int_t LightSourceOperatingTime; // -3932100sec. - 3932100sec.
2676 // OperatingTime is not implemented in apps
2677 unsigned _supla_int_t OperatingTime; // time in seconds
2678 };
2679 char EOL; // End Of List // v. >= 26
2680 char EmptySpace[1]; // Empty space for future use
2681} TDSC_ChannelState; // v. >= 12 Device -> Server -> Client
2682
2683#define TChannelState_ExtendedValue TDSC_ChannelState
2684
2685typedef struct {
2686 _supla_int_t ChannelID;
2687} TCS_ChannelBasicCfgRequest; // v. >= 12
2688
2689typedef struct {
2690 union {
2691 // Remaining time to turn off
2692 unsigned _supla_int_t RemainingTimeMs;
2693 unsigned _supla_int_t RemainingTimeS;
2694 unsigned _supla_int_t CountdownEndsAt; // Unix timestamp - Filled by server
2695 };
2696
2697 unsigned char TargetValue[SUPLA_CHANNELVALUE_SIZE];
2698
2699 _supla_int_t SenderID;
2700 unsigned _supla_int_t
2701 SenderNameSize; // including the terminating null byte ('\0')
2702 char SenderName[SUPLA_SENDER_NAME_MAXSIZE]; // Last variable in struct!
2703 // UTF8 | Filled by server
2705
2706typedef struct {
2707 TChannelState_ExtendedValue Channel;
2708 TTimerState_ExtendedValue Timer; // Last variable in struct!
2710
2711typedef struct {
2712 char DeviceName[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8
2713 char DeviceSoftVer[SUPLA_SOFTVER_MAXSIZE];
2714 _supla_int_t DeviceID;
2715 _supla_int_t DeviceFlags;
2716 _supla_int16_t ManufacturerID;
2717 _supla_int16_t ProductID;
2718
2719 _supla_int_t ID;
2720 unsigned char Number;
2721 _supla_int_t Type;
2722 _supla_int_t Func;
2723 _supla_int_t FuncList;
2724
2725 unsigned _supla_int_t ChannelFlags;
2726 unsigned _supla_int_t
2727 CaptionSize; // including the terminating null byte ('\0')
2728 char Caption[SUPLA_CHANNEL_CAPTION_MAXSIZE]; // Last variable in struct!
2729} TSC_ChannelBasicCfg; // v. >= 12
2730
2731typedef struct {
2732 _supla_int_t ChannelID;
2733 _supla_int_t Func;
2734} TCS_SetChannelFunction; // v. >= 12
2735
2736typedef struct {
2737 _supla_int_t ChannelID;
2738 _supla_int_t Func;
2739 unsigned char ResultCode;
2740} TSC_SetChannelFunctionResult; // v. >= 12
2741
2742typedef struct {
2743 union {
2744 unsigned char ChannelNumber;
2745 _supla_int_t ID;
2746 };
2747
2748 unsigned _supla_int_t
2749 CaptionSize; // including the terminating null byte ('\0')
2750 char Caption[SUPLA_CAPTION_MAXSIZE]; // Last variable in struct!
2751} TDCS_SetCaption; // v. >= 12
2752
2753typedef struct {
2754 union {
2755 unsigned char ChannelNumber;
2756 _supla_int_t ID;
2757 };
2758
2759 unsigned char ResultCode;
2760 unsigned _supla_int_t
2761 CaptionSize; // including the terminating null byte ('\0')
2762 char Caption[SUPLA_CAPTION_MAXSIZE]; // Last variable in struct!
2763} TSCD_SetCaptionResult; // v. >= 12
2764
2765typedef struct {
2766 unsigned char ResultCode;
2768
2769typedef struct {
2770 // Disabled: 0
2771 // Ignore: <0
2772 _supla_int_t IODeviceRegistrationTimeSec;
2773 _supla_int_t ClientRegistrationTimeSec;
2774} TCS_SetRegistrationEnabled; // v. >= 12
2775
2776typedef struct {
2777 unsigned char ResultCode;
2779
2780typedef struct {
2781 _supla_int_t DeviceID;
2782} TCS_DeviceReconnectRequest; // v. >= 12
2783
2784typedef struct {
2785 _supla_int_t DeviceID;
2786 unsigned char ResultCode;
2788
2789typedef struct {
2790 // server -> device
2791
2792 unsigned char ChannelCount;
2793 _supla_int_t Functions[SUPLA_CHANNELMAXCOUNT]; // Last variable in struct!
2794 // Functions[ChannelNumber]
2795} TSD_ChannelFunctions; // ver. >= 12
2796
2797typedef struct {
2798 unsigned char ChannelNumber;
2800
2801typedef struct {
2802 unsigned char ChannelNumber;
2803 _supla_int_t Param1;
2804 _supla_int_t Param2;
2805 _supla_int_t Param3;
2807
2808#define SUPLA_CHANNEL_CONFIG_MAXSIZE 512 // v. <= 19 - 128; v. >= 21 - 512
2809#define SUPLA_DEVICE_CONFIG_MAXSIZE 512
2810
2811// Default type is used for standard channel config (user modifiable)
2812#define SUPLA_CONFIG_TYPE_DEFAULT 0
2813// Weekly schedule
2814#define SUPLA_CONFIG_TYPE_WEEKLY_SCHEDULE 2
2815// For SUPLA_CHANNELFNC_HVAC_THERMOSTAT, ALT weekly schedule is used for
2816// cooling subfuction, while standard weelkly schedule is used for heating
2817#define SUPLA_CONFIG_TYPE_ALT_WEEKLY_SCHEDULE 3
2818#define SUPLA_CONFIG_TYPE_OCR 4
2819#define SUPLA_CONFIG_TYPE_EXTENDED 5
2820
2821/********************************************
2822 * DEVICE CONFIG STRUCTURES
2823 ********************************************/
2824
2825// SUPLA_DS_CALL_SET_DEVICE_CONFIG
2826// SUPLA_SD_CALL_SET_DEVICE_CONFIG
2827// Config field should contain fields stored in order as they appear in
2828// Fields parameter. Size of parameter depends on Field type.
2829typedef struct {
2830 unsigned char EndOfDataFlag; // 1 - last message; 0 - more messages will come
2831 unsigned char zero[8]; // for future use
2832 unsigned _supla_int64_t
2833 AvailableFields; // bit map of SUPLA_DEVICE_CONFIG_FIELD_
2834 unsigned _supla_int64_t Fields; // bit map of SUPLA_DEVICE_CONFIG_FIELD_
2835 unsigned _supla_int16_t ConfigSize;
2836 char Config[SUPLA_DEVICE_CONFIG_MAXSIZE]; // Last variable in struct!
2837} TSDS_SetDeviceConfig; // v. >= 21
2838
2839// SUPLA_SD_CALL_SET_DEVICE_CONFIG_RESULT
2840// SUPLA_DS_CALL_SET_DEVICE_CONFIG_RESULT
2841typedef struct {
2842 unsigned char Result; // SUPLA_CONFIG_RESULT_*
2843 unsigned char zero[9]; // for future use
2845
2846typedef struct {
2847 _supla_int_t DeviceId;
2848 unsigned char EndOfDataFlag; // 1 - last message; 0 - more messages will come
2849 unsigned char zero[8]; // for future use
2850 unsigned _supla_int64_t
2851 AvailableFields; // bit map of SUPLA_DEVICE_CONFIG_FIELD_
2852 unsigned _supla_int64_t Fields; // bit map of SUPLA_DEVICE_CONFIG_FIELD_
2853 unsigned _supla_int16_t ConfigSize;
2854 char Config[SUPLA_DEVICE_CONFIG_MAXSIZE]; // Last variable in struct!
2855} TSCS_DeviceConfig; // v. >= 21
2856
2857// SUPLA_SC_CALL_DEVICE_CONFIG_UPDATE_OR_RESULT
2858typedef struct {
2859 unsigned char Result; // SUPLA_CONFIG_RESULT_*. It matters when it is a
2860 // response to SUPLA_CS_CALL_GET_DEVICE_CONFIG
2861 TSCS_DeviceConfig Config; // Last variable in struct!
2863
2864// SUPLA_CS_CALL_GET_DEVICE_CONFIG
2865typedef struct {
2866 _supla_int_t DeviceId;
2867 unsigned _supla_int64_t Fields; // bit map of SUPLA_DEVICE_CONFIG_FIELD_
2868 unsigned char zero[8]; // for future use
2870
2871#define SUPLA_DEVCFG_STATUS_LED_ON_WHEN_CONNECTED 0
2872#define SUPLA_DEVCFG_STATUS_LED_OFF_WHEN_CONNECTED 1
2873#define SUPLA_DEVCFG_STATUS_LED_ALWAYS_OFF 2
2874
2875typedef struct {
2876 unsigned char StatusLedType; // SUPLA_DEVCFG_STATUS_LED_
2877} TDeviceConfig_StatusLed; // v. >= 21
2878
2879typedef struct {
2880 unsigned char Disabled; // 1 - true; 0 - false
2881} TDeviceConfig_PowerStatusLed; // v. >= 25
2882
2883typedef struct {
2884 unsigned char ScreenBrightness; // 0-100%
2885 unsigned char Automatic; // 0 - false; 1 - true
2886 signed char AdjustmentForAutomatic;
2887} TDeviceConfig_ScreenBrightness; // v. >= 21
2888
2889typedef struct {
2890 unsigned char Volume; // 0-100%
2891} TDeviceConfig_ButtonVolume; // v. >= 21
2892
2893typedef struct {
2894 unsigned char DisableUserInterface; // 0 - false (local UI enabled)
2895 // 1 - true (local UI disabled)
2896 // 2 - partial
2897 // min/max allowed parameters are mandatory for "partial" variant
2898 unsigned _supla_int16_t minAllowedTemperatureSetpointFromLocalUI;
2899 unsigned _supla_int16_t maxAllowedTemperatureSetpointFromLocalUI;
2901
2902typedef struct {
2903 unsigned char AutomaticTimeSync; // 0 - disabled
2904 // 1 - enabled
2906
2907typedef struct {
2908 unsigned _supla_int16_t HomeScreenOffDelayS; // delay in seconds
2909 // 0 - disabled
2911
2912#define SUPLA_DEVCFG_HOME_SCREEN_OFF_DELAY_TYPE_ALWAYS_ENABLED 0
2913#define SUPLA_DEVCFG_HOME_SCREEN_OFF_DELAY_TYPE_ENABLED_WHEN_DARK 1
2914typedef struct {
2915 unsigned char
2916 HomeScreenOffDelayType; // SUPLA_DEVCFG_HOME_SCREEN_OFF_DELAY_TYPE_
2918
2919#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_NONE (1ULL << 0)
2920#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_TEMPERATURE (1ULL << 1)
2921#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_TEMPERATURE_AND_HUMIDITY (1ULL << 2)
2922#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_TIME (1ULL << 3)
2923#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_TIME_DATE (1ULL << 4)
2924#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_TEMPERATURE_TIME (1ULL << 5)
2925#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_MAIN_AND_AUX_TEMPERATURE (1ULL << 6)
2926#define SUPLA_DEVCFG_HOME_SCREEN_CONTENT_MODE_OR_TEMPERATURE (1ULL << 7)
2927
2928typedef struct {
2929 // bit field with all available modes (reported by device, readonly for other
2930 // components)
2931 unsigned _supla_int64_t ContentAvailable;
2932 // configured mode (settable)
2933 unsigned _supla_int64_t
2934 HomeScreenContent; // SUPLA_DEVCFG_HOME_SCREEN_CONTENT_
2936
2937// type: TDeviceConfig_Modbus
2938#define MODBUS_SERIAL_MODE_DISABLED 0
2939#define MODBUS_SERIAL_MODE_RTU 1
2940#define MODBUS_SERIAL_MODE_ASCII 2
2941
2942#define MODBUS_SERIAL_STOP_BITS_ONE 0
2943#define MODBUS_SERIAL_STOP_BITS_ONE_AND_HALF 1
2944#define MODBUS_SERIAL_STOP_BITS_TWO 2
2945
2946typedef struct {
2947 unsigned char Mode; // MODBUS_SERIAL_MODE_*
2948 _supla_int_t Baudrate; // 19200 (default and mandatory by modbus)
2949 unsigned char StopBits; // MODBUS_SERIAL_STOP_BITS_*
2950 unsigned char Reserved[20];
2952
2953#define MODBUS_NETWORK_MODE_DISABLED 0
2954#define MODBUS_NETWORK_MODE_TCP 1
2955#define MODBUS_NETWORK_MODE_UDP 2
2956
2957typedef struct {
2958 unsigned char Mode; // MODBUS_NETWORK_MODE_*
2959 unsigned int Port; // Default: 502
2960 unsigned char Reserved[20];
2962
2963// Readonly Modbus properties, which tells which functions/modes are
2964// available
2965typedef struct {
2966 struct {
2967 unsigned char Master : 1;
2968 unsigned char Slave : 1;
2969 unsigned char Rtu : 1;
2970 unsigned char Ascii : 1;
2971 unsigned char Tcp : 1;
2972 unsigned char Udp : 1;
2973 unsigned char Reserved : 2;
2974 unsigned char Reserved2 : 8;
2975 } Protocol;
2976 struct {
2977 unsigned char B4800 : 1;
2978 unsigned char B9600 : 1; // modbus mandatory
2979 unsigned char B19200 : 1; // modbus mandatory
2980 unsigned char B38400 : 1;
2981 unsigned char B57600 : 1;
2982 unsigned char B115200 : 1;
2983 unsigned char Reserved : 2;
2984 unsigned char Reserved2 : 8;
2985 } Baudrate;
2986 struct {
2987 unsigned char One : 1;
2988 unsigned char OneAndHalf : 1;
2989 unsigned char Two : 1;
2990 unsigned char Reserved : 5;
2991 } StopBits;
2992 unsigned char Reserved[20];
2994
2995#define MODBUS_ROLE_NOT_SET 0
2996#define MODBUS_ROLE_MASTER 1
2997#define MODBUS_ROLE_SLAVE 2
2998
2999typedef struct {
3000 unsigned char Role; // MODBUS_ROLE_*
3001 unsigned char ModbusAddress; // only for slave
3002 unsigned _supla_int_t SlaveTimeoutMs; // only for master
3003 ModbusSerialConfig SerialConfig;
3004 ModbusNetworkConfig NetworkConfig;
3005 ModbusConfigProperties Properties;
3006 unsigned char Reserved[20];
3008
3009// type: TDeviceConfig_FirmwareUpdate
3010// Forced off - firmware update is disabled by user on device (via local web
3011// interface) and can't be changed remotely
3012// Disabled - firmware update is disabled by user and can be changed remotely
3013// Security only - firmware update is enabled only for security updates
3014// All enabled - firmware update is enabled for all updates
3015#define SUPLA_FIRMWARE_UPDATE_POLICY_FORCED_OFF 0
3016#define SUPLA_FIRMWARE_UPDATE_POLICY_DISABLED 1
3017#define SUPLA_FIRMWARE_UPDATE_POLICY_SECURITY_ONLY 2 // default
3018#define SUPLA_FIRMWARE_UPDATE_POLICY_ALL_ENABLED 3
3019
3020typedef struct {
3021 unsigned char Policy; // SUPLA_FIRMWARE_UPDATE_POLICY_
3022 unsigned char Reserved[20];
3024
3025/********************************************
3026 * CHANNEL CONFIG STRUCTURES
3027 ********************************************/
3028
3029#define SUPLA_CONFIG_RESULT_FALSE 0
3030#define SUPLA_CONFIG_RESULT_TRUE 1
3031#define SUPLA_CONFIG_RESULT_DATA_ERROR 2
3032#define SUPLA_CONFIG_RESULT_TYPE_NOT_SUPPORTED 3
3033#define SUPLA_CONFIG_RESULT_FUNCTION_NOT_SUPPORTED 4
3034#define SUPLA_CONFIG_RESULT_LOCAL_CONFIG_DISABLED 5
3035#define SUPLA_CONFIG_RESULT_NOT_ALLOWED 6
3036#define SUPLA_CONFIG_RESULT_DEVICE_NOT_FOUND 7
3037
3038// SUPLA_CS_CALL_GET_CHANNEL_CONFIG
3039typedef struct {
3040 _supla_int_t ChannelId;
3041 unsigned char ConfigType; // SUPLA_CONFIG_TYPE_
3042 unsigned _supla_int_t Flags;
3043} TCS_GetChannelConfigRequest; // v. >= 21
3044
3045// SUPLA_CS_CALL_SET_CHANNEL_CONFIG
3046typedef struct {
3047 _supla_int_t ChannelId;
3048 _supla_int_t Func;
3049 unsigned char ConfigType; // SUPLA_CONFIG_TYPE_
3050 unsigned _supla_int16_t ConfigSize;
3051 char Config[SUPLA_CHANNEL_CONFIG_MAXSIZE]; // Last variable in struct!
3052 // v. >= 21
3053 // TChannelConfig_*
3055
3056// SUPLA_SC_CALL_CHANNEL_CONFIG_UPDATE
3057typedef struct {
3058 unsigned char Result; // SUPLA_CONFIG_RESULT_*. It matters when it is a
3059 // response to SUPLA_CS_CALL_GET_CHANNEL_CONFIG or
3060 // SUPLA_CS_CALL_SET_CHANNEL_CONFIG
3061 TSCS_ChannelConfig Config; // Last variable in struct!
3063
3064// SUPLA_DS_CALL_GET_CHANNEL_CONFIG
3065typedef struct {
3066 unsigned char ChannelNumber;
3067 unsigned char ConfigType; // SUPLA_CONFIG_TYPE_
3068 unsigned _supla_int_t Flags;
3069} TDS_GetChannelConfigRequest; // v. >= 16
3070
3071// SUPLA_SD_CALL_GET_CHANNEL_CONFIG_RESULT
3072// SUPLA_DS_CALL_SET_CHANNEL_CONFIG
3073// SUPLA_SD_CALL_SET_CHANNEL_CONFIG
3074typedef struct {
3075 unsigned char ChannelNumber;
3076 _supla_int_t Func;
3077 unsigned char ConfigType; // SUPLA_CONFIG_TYPE_
3078 unsigned _supla_int16_t ConfigSize;
3079 char Config[SUPLA_CHANNEL_CONFIG_MAXSIZE]; // Last variable in struct!
3080 // v. >= 16
3081 // TChannelConfig_*
3083
3084// SUPLA_DS_CALL_SET_CHANNEL_CONFIG
3085// SUPLA_SD_CALL_SET_CHANNEL_CONFIG
3086typedef TSD_ChannelConfig TSDS_SetChannelConfig; // v. >= 21
3087
3088// SUPLA_SD_CALL_SET_CHANNEL_CONFIG_RESULT
3089// SUPLA_DS_CALL_SET_CHANNEL_CONFIG_RESULT
3090typedef struct {
3091 unsigned char Result; // SUPLA_CONFIG_RESULT_*
3092 unsigned char ConfigType; // SUPLA_CONFIG_TYPE_
3093 unsigned char ChannelNumber;
3095
3096// SUPLA_SD_CALL_CHANNEL_CONFIG_FINISHED
3097typedef struct {
3098 unsigned char ChannelNumber;
3100
3101typedef struct {
3102 _supla_int_t TimeMS;
3103} TChannelConfig_StaircaseTimer; // v. >= 16
3104
3105typedef struct {
3106 _supla_int_t ClosingTimeMS;
3107 _supla_int_t OpeningTimeMS;
3108 unsigned char MotorUpsideDown; // 0 - not set/not used, 1 - false, 2 - true
3109 unsigned char ButtonsUpsideDown; // 0 - not set/not used, 1 - false, 2 - true
3110 signed char TimeMargin; // -1 default (device specific), 0 - not set/not used
3111 // 1 - no margin,
3112 // > 1 - 51% of opening/closing time added on extreme
3113 // positions - value should be decremented by 1.
3114 unsigned char VisualizationType; // 0 - default, other values depends on
3115 // Cloud and App support
3116 unsigned char Reserved[32];
3117} TChannelConfig_RollerShutter; // v. >= 16
3118
3119typedef TChannelConfig_RollerShutter TChannelConfig_TerraceAwning;
3120typedef TChannelConfig_RollerShutter TChannelConfig_ProjectorScreen;
3121typedef TChannelConfig_RollerShutter TChannelConfig_Curtain;
3122typedef TChannelConfig_RollerShutter TChannelConfig_RollerGarageDoor;
3123
3124typedef struct {
3125 _supla_int_t ClosingTimeMS;
3126 _supla_int_t OpeningTimeMS;
3127 _supla_int_t TiltingTimeMS;
3128 unsigned char MotorUpsideDown; // 0 - not set/not used, 1 - false, 2 - true
3129 unsigned char ButtonsUpsideDown; // 0 - not set/not used, 1 - false, 2 - true
3130 signed char TimeMargin; // -1 default (device specific), 0 - not set/not used
3131 // 1 - no margin,
3132 // > 1 - 51% of opening/closing time added on extreme
3133 // positions - value should be decremented by 1.
3134 unsigned _supla_int16_t
3135 Tilt0Angle; // 0 - 180 - degree corresponding to tilt 0
3136 unsigned _supla_int16_t
3137 Tilt100Angle; // 0 - 180 - degree corresponding to tilt 100
3138 unsigned char TiltControlType; // SUPLA_TILT_CONTROL_TYPE_
3139 unsigned char VisualizationType; // 0 - default, other values depends on
3140 // Cloud and App support
3141 unsigned char Reserved[32];
3142} TChannelConfig_FacadeBlind; // v. >= 24
3143
3144typedef TChannelConfig_FacadeBlind TChannelConfig_VerticalBlind;
3145
3146typedef struct {
3147 unsigned _supla_int_t ActiveActions;
3148} TChannelConfig_ActionTrigger; // v. >= 16
3149
3150// Weekly schedule definition for HVAC channel
3151typedef struct {
3152 unsigned char Mode; // for HVAC: SUPLA_HVAC_MODE_
3153 union {
3154 _supla_int16_t SetpointTemperatureHeat; // * 0.01 - used for heating
3155 _supla_int16_t Value1;
3156 };
3157 union {
3158 _supla_int16_t SetpointTemperatureCool; // * 0.01 - used for cooling
3159 _supla_int16_t Value2;
3160 };
3162
3163#define SUPLA_WEEKLY_SCHEDULE_PROGRAMS_MAX_SIZE 4
3164#define SUPLA_WEEKLY_SCHEDULE_VALUES_SIZE (7 * 24 * 4)
3165
3166typedef struct {
3167 // 4*5 = 20 B
3168 TWeeklyScheduleProgram Program[SUPLA_WEEKLY_SCHEDULE_PROGRAMS_MAX_SIZE];
3169 // "Quarters" contain Program setting for each 15 min. One 15 min program is
3170 // set on 4 bits, so in one byte we have settings for two 2x 15 min. 0 - off
3171 // 1 - program 1
3172 // 2 - program 2
3173 // 3 - program 3
3174 // 4 - program 4
3175 // (Quarter[0] & 0x0F) is Sunday, 0:00 to 0:14
3176 // (Quarter[0] & 0xF0) >> 4 is Sunday, 0:15 to 0:29
3177 // Days of week are numbered: 0 - Sunday, 1 - Monday, etc.
3178 unsigned char Quarters[SUPLA_WEEKLY_SCHEDULE_VALUES_SIZE / 2]; // 336 B
3179} TChannelConfig_WeeklySchedule; // v. >= 21
3180
3181// Config used for thermometers, humidity sensors, and thermometers with
3182// humidity channels.
3183// Correction is always applied by io device. Parameter
3184// AdjustmentAppliedByDevice is added in order to handle older versions where
3185// correction was applied by server. Devices supporting this setting will
3186// retreive config from server and if AdjustmentAppliedByDevice is set to 0,
3187// then they will store new correction value, set AdjustmentAppliedByDevice to 1
3188// and send it to server, so server will no longer apply correction.
3189typedef struct {
3190 _supla_int16_t TemperatureAdjustment; // * 0.01
3191 _supla_int16_t HumidityAdjustment; // * 0.01
3192 unsigned char AdjustmentAppliedByDevice; // 1/true - by device
3193 // 0/false - by server
3194 // Min/Max allowed adjustment values that channel supports. If set to 0, then
3195 // field is not supported by device and Cloud should use default -10..10 range
3196 // for correction. Otherwise, Cloud should use these values.
3197 _supla_int16_t MinTemperatureAdjustment; // * 0.01
3198 _supla_int16_t MaxTemperatureAdjustment; // * 0.01
3199 _supla_int16_t MinHumidityAdjustment; // * 0.01
3200 _supla_int16_t MaxHumidityAdjustment; // * 0.01
3201 unsigned char Reserved[27 - 4 * sizeof(_supla_int16_t)];
3203
3204// ChannelConfig for all binary sensors (all functions valid for
3205// SUPLA_CHANNELTYPE_BINARYSENSOR)
3206// Device doesn't apply this inverted logic on communication towards server.
3207// It is used only for interanal purposes and for other external interfaces
3208// like MQTT
3209//
3210// FilteringTimeMs is used to configure how long device should wait for stable
3211// input signal before changing it's state. If value is set to 0, then field
3212// is not used by device and server should ignore it. Device may impose minimum
3213// and maximum values for this field.
3214//
3215// Timeout is used to configure how long device should wait since last "1"
3216// detection before it sets "0". If value is set to 0, then field is not used
3217//
3218// Sensitivity is used to configure how sensitive device should be.
3219// Sensitivity 1 % (value == 2) is the lowest possible sensitivity.
3220// Sensitivity 100 % (value == 101) is the highest possible sensitivity.
3221// If value is set to 0, then field is not used
3222// Value 1 (0 %) means "OFF"
3223typedef struct {
3224 unsigned char InvertedLogic; // 0 - not inverted, 1 - inverted
3225 unsigned _supla_int16_t FilteringTimeMs; // 0 - not used, > 0 - time in ms
3226 unsigned _supla_int16_t
3227 Timeout; // 0 - not used, > 0 - time in 0.1 s, max 36000
3228 unsigned char Sensitivity; // 0 - not used, 1..101 - sensitivity 0..100 %
3229 // value 1 (0 %) means "OFF"
3230 unsigned char
3231 Reserved[29 - sizeof(unsigned char) - sizeof(unsigned _supla_int16_t)];
3232} TChannelConfig_BinarySensor; // v. >= 21
3233
3234// Not set is set when there is no thermometer for "AUX" available
3235// at all.
3236// Disabled is set when thermometer is available (i.e. we can read it and show
3237// to user), but it is not used by thermostat for any other purpose
3238// Other values are mainly for UI adjustement (i.e. show temperature as floor,
3239// as water, generic heater or cooler device)
3240#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_NOT_SET 0
3241#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_DISABLED 1
3242#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_FLOOR 2
3243#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_WATER 3
3244#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_GENERIC_HEATER 4
3245#define SUPLA_HVAC_AUX_THERMOMETER_TYPE_GENERIC_COOLER 5
3246
3247#define SUPLA_HVAC_ALGORITHM_NOT_SET 0
3248#define SUPLA_HVAC_ALGORITHM_ON_OFF_SETPOINT_MIDDLE (1ULL << 0)
3249#define SUPLA_HVAC_ALGORITHM_ON_OFF_SETPOINT_AT_MOST (1ULL << 1)
3250#define SUPLA_HVAC_ALGORITHM_PID (1ULL << 2)
3251
3252// HVAC channel validation rules for thermometers:
3253// - MainThermometerChannelNo must be set
3254// - AuxThermometerChannelNo is validated and used only when
3255// AuxThermometerType != SUPLA_HVAC_AUX_THERMOMETER_TYPE_NOT_SET
3256// - AuxThermometerChannelNo != MainThermometerChannelNo
3257// - AuxThermometerChannelNo must be set for
3258// SUPLA_CHANNELFNC_HVAC_THERMOSTAT_DIFFERENTIAL. For other functions it is
3259// optional.
3260// - MainThermometerChannelNo and AuxThermometerChannelNo have to be
3261// SUPLA_CHANNELTYPE_HUMIDITYANDTEMPSENSOR or SUPLA_CHANNELTYPE_THERMOMETER
3262// - When AuxThermometerType == SUPLA_HVAC_AUX_THERMOMETER_TYPE_NOT_SET,
3263// AuxThermometerChannelNo is ignored, it can be set to 0.
3264
3265// HVAC channel validation for AntiFreezeAndOverheatProtectionEnabled:
3266// - function is available for channel functions: HEAT, COOL, HEAT_COOL
3267// - for other channel functions, this parameter is ignored
3268// - AntiFreeze/Overheat protection always use MainThermometerChannelNo as
3269// temperature source
3270
3271// HVAC channel validation for Algorithms:
3272// - AvailableAlgorithms is set only by device
3273// - UsedAlgorithm == 0 may be reported by device for incorrectly configured
3274// thermostat (i.e. there AvailableAlgorithms == 0), this shouldn't happen
3275// for devices with proper SW.
3276// - UsedAlgorithm & AvailableAlgorithms should evaluate to true
3277// - UsedAlgorithm should contain only one bit set
3278
3279// MinOnTimeS and MinOffTimeS:
3280// - function is always available
3281// - time is given in seconds
3282// - allowed range: 0 - 600 sec
3283
3284// OutputValueOnError:
3285// - function is always available
3286// - allowed values: -100 .. 100
3287// - it is recommended to use only -100 (cool), 0 (off), 100 (heat).
3288// - info: this range comes from assumption that cooling and heating may
3289// be enabled with gradients (i.e. for some thermostat with PWM output), but
3290// majority of thermostats are on/off, so only -100 (cool), 0 (off), and 100
3291// (heat) are proposed here.
3292
3293// Temperature validation rules:
3294// - Temperature in "Room Constrain" means:
3295// TEMPERATURE_ROOM_MIN <= t <= TEMPERATURE_ROOM_MAX
3296// - Temperature in "Aux Constrain" means:
3297// TEMPERATURE_AUX_MIN <= t <= TEMPERATURE_AUX_MAX
3298// - Temperatures (t_min, t_max) in "Auto Constrain" means:
3299// TEMPERATURE_ROOM_MIN <= t_min <= TEMPERATURE_ROOM_MAX AND
3300// TEMPERATURE_ROOM_MIN <= t_max <= TEMPERATURE_ROOM_MAX AND
3301// (t_max - t_min >= TEMPERATURE_HEAT_COOL_OFFSET_MIN) AND
3302// (t_max - t_min <= TEMPERATURE_HEAT_COOL_OFFSET_MAX)
3303
3304// TEMPERATURE_FREEZE_PROTECTION - has to be in Room Constrain when
3305// AntiFreezeAndOverheatProtectionEnabled is set
3306// TEMPERATURE_ECO - has to be in Room Constrain
3307// TEMPERATURE_COMFORT - has to be in Room Constrain
3308// TEMPERATURE_BOOST - has to be in Room Constrain
3309// TEMPERATURE_HEAT_PROTECTION - has to be in Room Constrain when function
3310// is COOL or HEAT_COOL
3311// TEMPERATURE_HISTERESIS and TEMPERATURE_AUX_HISTERESIS - has to be
3312// TEMPERATURE_HISTERESIS_MIN <= t <= TEMPERATURE_HISTERESIS_MAX
3313// TEMPERATURE_BELOW_ALARM - has to be in Room Constrain
3314// TEMPERATURE_ABOVE_ALARM - has to be in Room Constrain
3315// TEMPERATURE_AUX_MIN_SETPOINT - has to be in Aux Constrain and has
3316// to be < TEMPERATURE_AUX_MAX_SETPOINT
3317// TEMPERATURE_AUX_MAX_SETPOINT - has to be in Aux Constrain and has
3318// to be > TEMPERATURE_AUX_MIN_SETPOINT
3319
3320// Below values are readonly and defines device capabilities for current
3321// function:
3322// TEMPERATURE_ROOM_MIN < TEMPERATURE_ROOM_MAX
3323// TEMPERATURE_AUX_MIN < TEMPERATURE_AUX_MAX
3324// TEMPERATURE_HISTERESIS_MIN < TEMPERATURE_HISTERESIS_MAX
3325// TEMPERATURE_HEAT_COOL_OFFSET_MIN < TEMPERATURE_HEAT_COOL_OFFSET_MAX
3326
3327// Subfunction for SUPLA_CHANNELFNC_HVAC_THERMOSTAT
3328// Other channel functions dont' use subfunction setting (yet)
3329#define SUPLA_HVAC_SUBFUNCTION_NOT_SET 0
3330#define SUPLA_HVAC_SUBFUNCTION_HEAT 1
3331#define SUPLA_HVAC_SUBFUNCTION_COOL 2
3332
3333#define SUPLA_HVAC_TEMPERATURE_CONTROL_TYPE_NOT_SUPPORTED 0
3334#define SUPLA_HVAC_TEMPERATURE_CONTROL_TYPE_ROOM_TEMPERATURE 1
3335#define SUPLA_HVAC_TEMPERATURE_CONTROL_TYPE_AUX_HEATER_COOLER_TEMPERATURE 2
3336
3337#define LOCAL_UI_LOCK_FULL 0x1
3338#define LOCAL_UI_LOCK_TEMPERATURE 0x2
3339
3340typedef struct {
3341 unsigned _supla_int_t MainThermometerChannelNoReadonly : 1;
3342 unsigned _supla_int_t MainThermometerChannelNoHidden : 1;
3343 unsigned _supla_int_t AuxThermometerChannelNoReadonly : 1;
3344 unsigned _supla_int_t AuxThermometerChannelNoHidden : 1;
3345 unsigned _supla_int_t BinarySensorChannelNoReadonly : 1;
3346 unsigned _supla_int_t BinarySensorChannelNoHidden : 1;
3347 unsigned _supla_int_t AuxThermometerTypeReadonly : 1;
3348 unsigned _supla_int_t AuxThermometerTypeHidden : 1;
3349 unsigned _supla_int_t AntiFreezeAndOverheatProtectionEnabledReadonly : 1;
3350 unsigned _supla_int_t AntiFreezeAndOverheatProtectionEnabledHidden : 1;
3351 unsigned _supla_int_t UsedAlgorithmReadonly : 1;
3352 unsigned _supla_int_t UsedAlgorithmHidden : 1;
3353 unsigned _supla_int_t MinOnTimeSReadonly : 1;
3354 unsigned _supla_int_t MinOnTimeSHidden : 1;
3355 unsigned _supla_int_t MinOffTimeSReadonly : 1;
3356 unsigned _supla_int_t MinOffTimeSHidden : 1;
3357 unsigned _supla_int_t OutputValueOnErrorReadonly : 1;
3358 unsigned _supla_int_t OutputValueOnErrorHidden : 1;
3359 unsigned _supla_int_t SubfunctionReadonly : 1;
3360 unsigned _supla_int_t SubfunctionHidden : 1;
3361 unsigned _supla_int_t
3362 TemperatureSetpointChangeSwitchesToManualModeReadonly : 1;
3363 unsigned _supla_int_t TemperatureSetpointChangeSwitchesToManualModeHidden : 1;
3364 unsigned _supla_int_t AuxMinMaxSetpointEnabledReadonly : 1;
3365 unsigned _supla_int_t AuxMinMaxSetpointEnabledHidden : 1;
3366 unsigned _supla_int_t UseSeparateHeatCoolOutputsReadonly : 1;
3367 unsigned _supla_int_t UseSeparateHeatCoolOutputsHidden : 1;
3368 unsigned _supla_int_t TemperaturesFreezeProtectionReadonly : 1;
3369 unsigned _supla_int_t TemperaturesFreezeProtectionHidden : 1;
3370 unsigned _supla_int_t TemperaturesEcoReadonly : 1;
3371 unsigned _supla_int_t TemperaturesEcoHidden : 1;
3372 unsigned _supla_int_t TemperaturesComfortReadonly : 1;
3373 unsigned _supla_int_t TemperaturesComfortHidden : 1;
3374 unsigned _supla_int_t TemperaturesBoostReadonly : 1;
3375 unsigned _supla_int_t TemperaturesBoostHidden : 1;
3376 unsigned _supla_int_t TemperaturesHeatProtectionReadonly : 1;
3377 unsigned _supla_int_t TemperaturesHeatProtectionHidden : 1;
3378 unsigned _supla_int_t TemperaturesHisteresisReadonly : 1;
3379 unsigned _supla_int_t TemperaturesHisteresisHidden : 1;
3380 unsigned _supla_int_t TemperaturesBelowAlarmReadonly : 1;
3381 unsigned _supla_int_t TemperaturesBelowAlarmHidden : 1;
3382 unsigned _supla_int_t TemperaturesAboveAlarmReadonly : 1;
3383 unsigned _supla_int_t TemperaturesAboveAlarmHidden : 1;
3384 unsigned _supla_int_t TemperaturesAuxMinSetpointReadonly : 1;
3385 unsigned _supla_int_t TemperaturesAuxMinSetpointHidden : 1;
3386 unsigned _supla_int_t TemperaturesAuxMaxSetpointReadonly : 1;
3387 unsigned _supla_int_t TemperaturesAuxMaxSetpointHidden : 1;
3388 unsigned _supla_int_t MasterThermostatChannelNoReadonly : 1;
3389 unsigned _supla_int_t MasterThermostatChannelNoHidden : 1;
3390 unsigned _supla_int_t HeatOrColdSourceSwitchReadonly : 1;
3391 unsigned _supla_int_t HeatOrColdSourceSwitchHidden : 1;
3392 unsigned _supla_int_t PumpSwitchReadonly : 1;
3393 unsigned _supla_int_t PumpSwitchHidden : 1;
3394 unsigned _supla_int_t TemperaturesAuxHisteresisReadonly : 1;
3395 unsigned _supla_int_t TemperaturesAuxHisteresisHidden : 1;
3396 unsigned _supla_int_t Reserved : 10;
3398
3399typedef struct {
3400 union {
3401 _supla_int_t MainThermometerChannelId;
3402 // Channel numbers for thermometer config. Channels have to be local and
3403 // numbering is the same as for registration message
3404 unsigned char MainThermometerChannelNo;
3405 };
3406
3407 union {
3408 _supla_int_t AuxThermometerChannelId;
3409 unsigned char
3410 AuxThermometerChannelNo; // If the channel number points to itself, it
3411 // means that the aux thermometer is not set.
3412 };
3413
3414 union {
3415 _supla_int_t BinarySensorChannelId;
3416 unsigned char
3417 BinarySensorChannelNo; // If the channel number points to itself, it
3418 // means that the binary sensor is not set.
3419 };
3420
3421 // SUPLA_HVAC_AUX_THERMOMETER_TYPE_
3422 unsigned char AuxThermometerType;
3423 unsigned char AntiFreezeAndOverheatProtectionEnabled;
3424 // bit map SUPLA_HVAC_ALGORITHM_ (readonly)
3425 unsigned _supla_int16_t AvailableAlgorithms;
3426 // only one value of SUPLA_HVAC_ALGORITHM_
3427 unsigned _supla_int16_t UsedAlgorithm;
3428 // Below Min TimeS parameters defines minimum time of relay/output to be
3429 // be disabled or enabled in seconds. It is used to prevent to frequent relay
3430 // state change.
3431 // Allowed values are 0-600 (10 minutes)
3432 unsigned _supla_int16_t MinOnTimeS; // minimum allowed time for output to
3433 // be enabled
3434 unsigned _supla_int16_t MinOffTimeS; // minimum allowed time for output to
3435 // be disabled
3436 signed char OutputValueOnError; // -100 cool, 0 off (default), 100 heat
3437 unsigned char Subfunction; // SUPLA_HVAC_SUBFUNCTION_
3438 unsigned char TemperatureSetpointChangeSwitchesToManualMode; // 0 - off,
3439 // 1 - on (def)
3440 unsigned char AuxMinMaxSetpointEnabled; // 0 - off (default), 1 - on
3441 // For HEAT_COOL thermostats we have two outpus. They can either use
3442 // shared output for heating/cooling action and second output for heat vs
3443 // cool mode selection, or they can use separate outputs - one for heating
3444 // and one for cooling
3445 unsigned char UseSeparateHeatCoolOutputs; // 0 - off (default), 1 - on
3446 HvacParameterFlags ParameterFlags;
3447
3448 union {
3449 _supla_int_t MasterThermostatChannelId;
3450 struct {
3451 unsigned char MasterThermostatIsSet; // 0 - no; 1 - yes
3452 unsigned char MasterThermostatChannelNo;
3453 }; // v. >= 25
3454 };
3455
3456 union {
3457 _supla_int_t HeatOrColdSourceSwitchChannelId;
3458 struct {
3459 unsigned char HeatOrColdSourceSwitchIsSet; // 0 - no; 1 - yes
3460 unsigned char HeatOrColdSourceSwitchChannelNo;
3461 }; // v. >= 25
3462 };
3463
3464 union {
3465 _supla_int_t PumpSwitchChannelId;
3466 struct {
3467 unsigned char PumpSwitchIsSet; // 0 - no; 1 - yes
3468 unsigned char PumpSwitchChannelNo;
3469 }; // v. >= 25
3470 };
3471
3472 // TemperatureControlType allows to switch between work based on main
3473 // thermometer (room) and aux thermometer (heater/cooler).
3474 // Option is available only for SUPLA_CHANNELFNC_HVAC_THERMOSTAT
3475 // If set to 0, then it is not supported.
3476 unsigned char TemperatureControlType; // SUPLA_HVAC_TEMPERATURE_CONTROL_TYPE_
3477
3478 unsigned char LocalUILockingCapabilities; // LOCAL_UI_LOCK_*
3479 unsigned char LocalUILock; // LOCAL_UI_LOCK_*
3480
3481 // min/max allowed parameters are used only with LocalUILock &
3482 // LOCAL_UI_LOCK_TEMPERATURE
3483 _supla_int16_t MinAllowedTemperatureSetpointFromLocalUI;
3484 _supla_int16_t MaxAllowedTemperatureSetpointFromLocalUI;
3485 unsigned char Reserved[48 - sizeof(HvacParameterFlags) -
3486 sizeof(_supla_int_t) - sizeof(_supla_int_t) -
3487 sizeof(_supla_int_t) - sizeof(unsigned char) -
3488 sizeof(unsigned char) - sizeof(unsigned char) -
3489 sizeof(_supla_int16_t) - sizeof(_supla_int16_t)];
3490 THVACTemperatureCfg Temperatures;
3491} TChannelConfig_HVAC; // v. >= 21
3492
3493#define SUPLA_GENERAL_PURPOSE_MEASUREMENT_CHART_TYPE_LINEAR 0
3494#define SUPLA_GENERAL_PURPOSE_MEASUREMENT_CHART_TYPE_BAR 1
3495#define SUPLA_GENERAL_PURPOSE_MEASUREMENT_CHART_TYPE_CANDLE 2
3496
3497#define SUPLA_GENERAL_PURPOSE_UNIT_SIZE 15
3498
3499// General Purpose Mesurement channel config:
3500// Calculated value is: (value / ValueDivider) * ValueMultiplier + ValueAdded
3501typedef struct {
3502 // Value divider
3503 _supla_int_t ValueDivider; // 0.001 units; 0 is considered as 1
3504 // Value multiplier
3505 _supla_int_t ValueMultiplier; // 0.001 units; 0 is considered as 1
3506 // Value added
3507 _supla_int64_t ValueAdded; // 0.001 units
3508 // Display precicion
3509 unsigned char ValuePrecision; // 0 - 4 decimal points
3510 // Display unit (before value) - UTF8 including the terminating null byte '\0'
3511 char UnitBeforeValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3512 // Display unit (after value) - UTF8 including the terminating null byte '\0'
3513 char UnitAfterValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3514 unsigned char
3515 NoSpaceBeforeValue; // 0 - with space (default), 1 - without space
3516 unsigned char
3517 NoSpaceAfterValue; // 0 - with space (default), 1 - without space
3518 // Keep history on server
3519 unsigned char KeepHistory; // 0 - no (default), 1 - yes
3520 // Chart type linear/bar/candle
3521 unsigned char ChartType; // SUPLA_GENERAL_PURPOSE_MEASUREMENT_CHART_TYPE_*
3522 // Channel refresh interval [ms], allowed range 1 .. 65535
3523 // Actual channel implementation may enforce minimum value
3524 // 0 - default - implementation dependent
3525 unsigned _supla_int16_t RefreshIntervalMs;
3526
3527 // Readonly and default parameters
3528 // Default value divider
3529 _supla_int_t DefaultValueDivider; // 0.001 units; 0 is considered as 1
3530 // Default value multiplier
3531 _supla_int_t DefaultValueMultiplier; // 0.001 units; 0 is considered as 1
3532 // Default value added
3533 _supla_int64_t DefaultValueAdded; // 0.001 units
3534 // Default display precicion
3535 unsigned char DefaultValuePrecision; // 0 - 4 decimal points
3536 // Default unit (before value) - UTF8 including the terminating null byte '\0'
3537 char DefaultUnitBeforeValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3538 // Default unit (after value) - UTF8 including the terminating null byte '\0'
3539 char DefaultUnitAfterValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3540
3541 unsigned char Reserved[8];
3543
3544#define SUPLA_GENERAL_PURPOSE_METER_COUNTER_TYPE_INCREMENT_DECREMENT 0
3545#define SUPLA_GENERAL_PURPOSE_METER_COUNTER_TYPE_ALWAYS_INCREMENT 1
3546#define SUPLA_GENERAL_PURPOSE_METER_COUNTER_TYPE_ALWAYS_DECREMENT 2
3547
3548#define SUPLA_GENERAL_PURPOSE_METER_CHART_TYPE_BAR 0
3549#define SUPLA_GENERAL_PURPOSE_METER_CHART_TYPE_LINEAR 1
3550
3551// General Purpose Meter channel config:
3552// Calculated value is: (value / ValueDivider) * ValueMultiplier + ValueAdded
3553typedef struct {
3554 // Counter type
3555 unsigned char CounterType; // SUPLA_GENERAL_PURPOSE_METER_COUNTER_TYPE_*
3556
3557 // Value divider
3558 _supla_int_t ValueDivider; // 0.001 units; 0 is considered as 1
3559 // Value multiplier
3560 _supla_int_t ValueMultiplier; // 0.001 units; 0 is considered as 1
3561 // Value added
3562 _supla_int64_t ValueAdded; // 0.001 units
3563 // Display precicion
3564 unsigned char ValuePrecision; // 0 - 4 decimal points
3565 // Display unit (before value) - UTF8 including the terminating null byte '\0'
3566 char UnitBeforeValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3567 // Display unit (after value) - UTF8 including the terminating null byte '\0'
3568 char UnitAfterValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3569 unsigned char
3570 NoSpaceBeforeValue; // 0 - with space (default), 1 - without space
3571 unsigned char
3572 NoSpaceAfterValue; // 0 - with space (default), 1 - without space
3573 // Keep history on server
3574 unsigned char KeepHistory; // 0 - no (default), 1 - yes
3575 // Chart type linear/bar/candle
3576 unsigned char ChartType; // SUPLA_GENERAL_PURPOSE_METER_CHART_TYPE_*
3577 // Include value added in history
3578 unsigned char IncludeValueAddedInHistory; // 0 - no (default), 1 - yes
3579 // Fill missing data
3580 unsigned char FillMissingData; // 0 - no (default), 1 - yes
3581 // Channel refresh interval [ms], allowed range 1 .. 65535
3582 // Actual channel implementation may enforce minimum value
3583 // 0 - default - implementation dependent
3584 unsigned _supla_int16_t RefreshIntervalMs;
3585
3586 // Readonly and default parameters
3587 // Default value divider
3588 _supla_int_t DefaultValueDivider; // 0.001 units; 0 is considered as 1
3589 // Default value multiplier
3590 _supla_int_t DefaultValueMultiplier; // 0.001 units; 0 is considered as 1
3591 // Default value added
3592 _supla_int64_t DefaultValueAdded; // 0.001 units
3593 // Default display precicion
3594 unsigned char DefaultValuePrecision; // 0 - 4 decimal points
3595 // Default unit (before value) - UTF8 including the terminating null byte '\0'
3596 char DefaultUnitBeforeValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3597 // Default unit (after value) - UTF8 including the terminating null byte '\0'
3598 char DefaultUnitAfterValue[SUPLA_GENERAL_PURPOSE_UNIT_SIZE];
3599
3600 unsigned char Reserved[8];
3602
3603#define EM_CT_TYPE_100A_33mA (1ULL << 0)
3604#define EM_CT_TYPE_200A_66mA (1ULL << 1)
3605#define EM_CT_TYPE_400A_133mA (1ULL << 2)
3606
3607#define EM_PHASE_LED_TYPE_OFF (1ULL << 0)
3608#define EM_PHASE_LED_TYPE_VOLTAGE_PRESENCE (1ULL << 1)
3609#define EM_PHASE_LED_TYPE_VOLTAGE_PRESENCE_INVERTED (1ULL << 2)
3610// Voltage level:
3611// - PhaseLedParam1 - "low threshold", units 0.01 V.
3612// When voltage < low threshold -> blue LED
3613// - PhaseLedParam2 - "high threshold", units 0.01 V.
3614// When voltage > high threshold -> red LED
3615// - Voltage between low and high threshold -> green LED
3616#define EM_PHASE_LED_TYPE_VOLTAGE_LEVEL (1ULL << 3)
3617// Active power direction:
3618// - PhaseLedParam1 - "low threshold", units 0.01 W.
3619// When power < low threshold -> green LED.
3620// - PhaseLedParam2 - "high threshold", units 0.01 W.
3621// When power > high threshold -> red LED
3622#define EM_PHASE_LED_TYPE_POWER_ACTIVE_DIRECTION (1ULL << 4)
3623
3624// Electricity meter channel config
3625typedef struct {
3626 // Selected CT type
3627 unsigned _supla_int64_t UsedCTType; // EM_CT_TYPE_
3628 // Selected phase LED type
3629 unsigned _supla_int64_t UsedPhaseLedType; // EM_PHASE_LED_TYPE_*
3630
3631 // Phase LED params (actual meaning depends on phase LED type)
3632 _supla_int_t PhaseLedParam1;
3633 _supla_int_t PhaseLedParam2;
3634
3635 // readonly, device capabilities
3636 unsigned _supla_int64_t AvailableCTTypes;
3637 unsigned _supla_int64_t AvailablePhaseLedTypes;
3638
3639 unsigned char Reserved[32];
3641
3642typedef struct {
3643 _supla_int_t PricePerUnit; // * 0.0001
3644 // Currency Code A https://www.nationsonline.org/oneworld/currencies.htm
3645 char Currency[3];
3646 char CustomUnit[9]; // UTF8 including the terminating null byte ('\0')
3647
3648 _supla_int_t ImpulsesPerUnit;
3649 _supla_int64_t InitialValue; // 0.001 units
3650 unsigned char AddToHistory; // 0 - False, 1 - True
3651
3652 unsigned char Reserved[32];
3653} TChannelConfig_ImpulseCounter; // v. >= 25
3654
3655typedef struct {
3656 unsigned char FillLevel; // Fill level in 0-100 %
3657 union {
3658 _supla_int_t ChannelId;
3659 struct {
3660 unsigned char IsSet; // 0 - no; 1 - yes
3661 unsigned char ChannelNo;
3662 };
3663 };
3665
3666typedef struct {
3667 unsigned char WarningAboveLevel; // 0 - not set, 1-101 for 0-100%
3668 unsigned char AlarmAboveLevel; // 0 - not set, 1-101 for 0-100%
3669 unsigned char WarningBelowLevel; // 0 - not set, 1-101 for 0-100%
3670 unsigned char AlarmBelowLevel; // 0 - not set, 1-101 for 0-100%
3671
3672 unsigned char MuteAlarmSoundWithoutAdditionalAuth; // 0 - admin login is
3673 // required, 1 - regular
3674 // user is allowed
3675
3676 TContainer_SensorInfo SensorInfo[10];
3677 unsigned char Reserved[32];
3678} TChannelConfig_Container; // v. >= 26
3679
3680typedef struct {
3681 union {
3682 _supla_int_t ChannelId;
3683 struct {
3684 unsigned char IsSet; // 0 - no; 1 - yes
3685 unsigned char ChannelNo;
3686 };
3687 };
3688} TValve_SensorInfo; // v. >= 27
3689
3690#define SUPLA_VALVE_CLOSE_ON_FLOOD_TYPE_NONE 0
3691#define SUPLA_VALVE_CLOSE_ON_FLOOD_TYPE_ALWAYS 1
3692#define SUPLA_VALVE_CLOSE_ON_FLOOD_TYPE_ON_CHANGE 2
3693
3694typedef struct {
3696 SensorInfo[20]; // Flood sensors can be attached only if
3697 // SUPLA_CHANNEL_FLAG_FLOOD_SENSORS_SUPPORTED is set
3698 unsigned char CloseValveOnFloodType; // SUPLA_VALVE_CLOSE_ON_FLOOD_TYPE_*
3699 unsigned char Reserved[31];
3700} TChannelConfig_Valve; // v. >= 27
3701
3702#define SUPLA_OCR_AUTHKEY_SIZE 33
3703
3704#define OCR_LIGHTING_MODE_OFF (1ULL << 0)
3705#define OCR_LIGHTING_MODE_ALWAYS_ON (1ULL << 1)
3706#define OCR_LIGHTING_MODE_AUTO (1ULL << 2)
3707
3708typedef struct {
3709 char AuthKey[SUPLA_OCR_AUTHKEY_SIZE]; // Set by the server. Alphanumeric null
3710 // terminated string.
3711 char Host[SUPLA_URL_HOST_MAXSIZE]; // Set by the server. Including the
3712 // terminating null byte ('\0').
3713
3714 unsigned _supla_int_t
3715 PhotoIntervalSec; // 0 - Disabled. The server may discard the
3716 // value if it considers the frequency to be
3717 // too high or too low. The server can set
3718 // the accepted value.
3719 unsigned _supla_int64_t LightingMode; // OCR_LIGHTING_MODE *
3720 unsigned char LightingLevel; // 1-100%
3721 unsigned _supla_int64_t MaximumIncrement; // Maximum impulse increment
3722 // between shots. 0 == Unspecified
3723
3724 // readonly, device capabilities
3725 unsigned _supla_int64_t AvailableLightingModes;
3726 unsigned char Reserved[128];
3727} TChannelConfig_OCR; // v. >= 25
3728
3729typedef struct {
3730 // If OvercurrentMaxAllowed == 0, then overcurrent settings are not available.
3731 // If OvercurrentThreshold == 0, then overcurrent protection is disabled.
3732 unsigned _supla_int_t OvercurrentThreshold; // in 0.01 A
3733 unsigned _supla_int_t OvercurrentMaxAllowed; // in 0.01 A, readonly
3734 unsigned char DefaultRelatedMeterIsSet; // readonly, 1 - true, 0 - false
3735 unsigned char
3736 DefaultRelatedMeterChannelNo; // readonly, provides channel number of
3737 // related meter if RelatedMeterIsSet
3738 unsigned char Reserved[32];
3739} TChannelConfig_PowerSwitch; // v. >= 25
3740
3741typedef TChannelConfig_PowerSwitch TChannelConfig_LightSwitch;
3742
3743// Staircase timer ext use SUPLA_CONFIG_TYPE_EXTENDED
3744typedef TChannelConfig_PowerSwitch TChannelConfig_StaircaseTimer_Ext;
3745
3746typedef struct {
3747 _supla_int_t ChannelID;
3748 union {
3749 unsigned _supla_int_t DurationMS;
3750 unsigned _supla_int_t DurationSec; // ver. >= 21. Applies to HVAC
3751 };
3752 unsigned char On;
3753} TCS_TimerArmRequest; // v. >= 17
3754
3755// Recommended for bistable buttons
3756#define SUPLA_ACTION_CAP_TURN_ON (1 << 0)
3757#define SUPLA_ACTION_CAP_TURN_OFF (1 << 1)
3758#define SUPLA_ACTION_CAP_TOGGLE_x1 (1 << 2)
3759#define SUPLA_ACTION_CAP_TOGGLE_x2 (1 << 3)
3760#define SUPLA_ACTION_CAP_TOGGLE_x3 (1 << 4)
3761#define SUPLA_ACTION_CAP_TOGGLE_x4 (1 << 5)
3762#define SUPLA_ACTION_CAP_TOGGLE_x5 (1 << 6)
3763
3764// Recommended for monostable buttons
3765#define SUPLA_ACTION_CAP_HOLD (1 << 10)
3766#define SUPLA_ACTION_CAP_SHORT_PRESS_x1 (1 << 11)
3767#define SUPLA_ACTION_CAP_SHORT_PRESS_x2 (1 << 12)
3768#define SUPLA_ACTION_CAP_SHORT_PRESS_x3 (1 << 13)
3769#define SUPLA_ACTION_CAP_SHORT_PRESS_x4 (1 << 14)
3770#define SUPLA_ACTION_CAP_SHORT_PRESS_x5 (1 << 15)
3771
3772// Other Action Trigger events
3773#define SUPLA_ACTION_CAP_ROTATE_RIGHT (1 << 7)
3774#define SUPLA_ACTION_CAP_ROTATE_LEFT (1 << 8)
3775
3776#define SUPLA_VALVE_FLAG_FLOODING 0x1
3777#define SUPLA_VALVE_FLAG_MANUALLY_CLOSED 0x2
3778#define SUPLA_VALVE_FLAG_MOTOR_PROBLEM 0x4
3779
3780// Valve channel value
3781// Device -> Server -> Client
3782typedef struct {
3783 union {
3784 unsigned char closed; // 0 - open, 1 - closed
3785 unsigned char closed_percent;
3786 };
3787
3788 unsigned char flags; // see SUPLA_VALVE_FLAG_
3789} TValve_Value;
3790
3791// Valve channel value payload
3792// Client -> Server -> Device
3793typedef struct {
3794 unsigned char command; // 0 - close
3795 // 1 - open
3796 char reserved[7];
3797} TCSD_Valve;
3798
3799typedef struct {
3800 unsigned char ChannelNumber;
3801 _supla_int_t ActionTrigger;
3802 unsigned char zero[10]; // Place for future variables
3804
3805#define SUPLA_PN_TITLE_MAXSIZE 101
3806#define SUPLA_PN_BODY_MAXSIZE 256
3807#define SUPLA_PN_PROFILE_NAME_MAXSIZE 51
3808
3809#define PN_SERVER_MANAGED_TITLE (1 << 0)
3810#define PN_SERVER_MANAGED_BODY (1 << 1)
3811#define PN_SERVER_MANAGED_SOUND (1 << 2)
3812
3813typedef struct {
3814 unsigned char
3815 ServerManagedFields; // Specifies the fields that will be managed by the
3816 // server. This value is only considered for the
3817 // first notification within a given context and
3818 // applies to all subsequent notifications.
3819
3820 _supla_int16_t Context; // >= 0 Channel, -1 Device
3821 signed char Reserved[8];
3823
3824typedef struct {
3825 _supla_int16_t Context; // >= 0 Channel, -1 Device
3826 signed char Reserved[32];
3827 _supla_int_t SoundId;
3828 unsigned _supla_int16_t
3829 TitleSize; // Including the terminating null byte ('\0').
3830 unsigned _supla_int16_t
3831 BodySize; // Including the terminating null byte ('\0').
3832 signed char TitleAndBody[SUPLA_PN_TITLE_MAXSIZE +
3833 SUPLA_PN_BODY_MAXSIZE]; // Last variable in struct!
3835
3836#define SUPLA_SUBDEVICE_PRODUCT_CODE_MAXSIZE 51
3837#define SUPLA_SUBDEVICE_SERIAL_NUMBER_MAXSIZE 51
3838
3839typedef struct {
3840 // device -> server
3841 unsigned char SubDeviceId;
3842
3843 char Name[SUPLA_DEVICE_NAME_MAXSIZE]; // UTF8 - 201 B including the
3844 // terminating null byte ('\0').
3845 char SoftVer[SUPLA_SOFTVER_MAXSIZE]; // 21 B including the terminating null
3846 // byte ('\0').
3847 char ProductCode[SUPLA_SUBDEVICE_PRODUCT_CODE_MAXSIZE]; // 51 B including the
3848 // terminating null
3849 // byte ('\0').
3850 char
3851 SerialNumber[SUPLA_SUBDEVICE_SERIAL_NUMBER_MAXSIZE]; // 51 B including
3852 // the terminating
3853 // null byte ('\0').
3855
3856#define SUPLA_PN_CLIENT_TOKEN_MAXSIZE 256
3857#define PLATFORM_UNKNOWN 0
3858#define PLATFORM_IOS 1
3859#define PLATFORM_ANDROID 2
3860#define PLATFORM_HOMEGRAPH 3 // v. >= 23
3861
3862typedef struct {
3863 unsigned char DevelopmentEnv;
3864 _supla_int_t Platform;
3865 _supla_int_t AppId;
3866 signed char
3867 ProfileName[SUPLA_PN_PROFILE_NAME_MAXSIZE]; // Including the terminating
3868 // null byte ('\0').
3869 unsigned _supla_int16_t
3870 RealTokenSize; // It allows you to determine if the maximum size of the
3871 // Token variable is sufficient.
3872 unsigned _supla_int16_t
3873 TokenSize; // Including the terminating null byte ('\0'). Size
3874 // <= 1 removes the token
3875 signed char Token[SUPLA_PN_CLIENT_TOKEN_MAXSIZE]; // Last variable in struct!
3877
3878typedef struct {
3880 TCS_PnClientToken Token; // Last variable in struct!
3882
3883typedef struct {
3884 _supla_int_t ResultCode;
3886
3887typedef struct {
3888 _supla_int_t count;
3889 _supla_int_t total_left;
3891 items[SUPLA_CHANNEL_STATE_PACK_MAXCOUNT]; // Last variable in struct!
3893
3894#pragma pack(pop)
3895
3896void *PROTO_ICACHE_FLASH sproto_init(void);
3897void PROTO_ICACHE_FLASH sproto_free(void *spd_ptr);
3898
3899#ifndef SPROTO_WITHOUT_OUT_BUFFER
3900char PROTO_ICACHE_FLASH sproto_out_buffer_append(void *spd_ptr,
3901 TSuplaDataPacket *sdp);
3902unsigned _supla_int_t sproto_pop_out_data(void *spd_ptr, char *buffer,
3903 unsigned _supla_int_t buffer_size);
3904#endif /*SPROTO_WITHOUT_OUT_BUFFER*/
3905char PROTO_ICACHE_FLASH sproto_out_dataexists(void *spd_ptr);
3906char PROTO_ICACHE_FLASH sproto_in_buffer_append(
3907 void *spd_ptr, char *data, unsigned _supla_int_t data_size);
3908
3909char PROTO_ICACHE_FLASH sproto_pop_in_sdp(void *spd_ptr, TSuplaDataPacket *sdp);
3910char PROTO_ICACHE_FLASH sproto_in_dataexists(void *spd_ptr);
3911
3912unsigned char PROTO_ICACHE_FLASH sproto_get_version(void *spd_ptr);
3913void PROTO_ICACHE_FLASH sproto_set_version(void *spd_ptr,
3914 unsigned char version);
3915void PROTO_ICACHE_FLASH sproto_sdp_init(void *spd_ptr, TSuplaDataPacket *sdp);
3916char PROTO_ICACHE_FLASH sproto_set_data(TSuplaDataPacket *sdp, char *data,
3917 unsigned _supla_int_t data_size,
3918 unsigned _supla_int_t call_id);
3919TSuplaDataPacket *PROTO_ICACHE_FLASH sproto_sdp_malloc(void *spd_ptr);
3920void PROTO_ICACHE_FLASH sproto_sdp_free(TSuplaDataPacket *sdp);
3921
3922void PROTO_ICACHE_FLASH sproto_log_summary(void *spd_ptr);
3923void PROTO_ICACHE_FLASH sproto_buffer_dump(void *spd_ptr, unsigned char in);
3924
3925void PROTO_ICACHE_FLASH sproto_set_null_terminated_string(
3926 const char *src, char *dest, unsigned _supla_int_t *dest_size,
3927 unsigned int max_size);
3928
3929void PROTO_ICACHE_FLASH sproto__set_null_terminated_string(
3930 const char *src, char *dest, unsigned _supla_int16_t *dest_size,
3931 unsigned int max_size);
3932
3933#ifdef __cplusplus
3934}
3935#endif
3936
3937#endif /* supla_proto_H_ */
Definition proto.h:3340
Definition proto.h:2965
Definition proto.h:2957
Definition proto.h:2946
Definition proto.h:833
Definition proto.h:1648
Definition proto.h:1636
Definition proto.h:1629
Definition proto.h:2607
Definition proto.h:2411
Definition proto.h:2109
Definition proto.h:2079
Definition proto.h:3793
Definition proto.h:1675
Definition proto.h:1658
Definition proto.h:2685
Definition proto.h:1666
Definition proto.h:2269
Definition proto.h:2260
Definition proto.h:2780
Definition proto.h:3039
Definition proto.h:1697
Definition proto.h:2865
Definition proto.h:3862
Definition proto.h:3878
Definition proto.h:2731
Definition proto.h:2769
Definition proto.h:2129
Definition proto.h:1816
Definition proto.h:1810
Definition proto.h:1822
Definition proto.h:1713
Definition proto.h:1726
Definition proto.h:1739
Definition proto.h:1702
Definition proto.h:3746
Definition proto.h:2315
Definition proto.h:2226
Definition proto.h:2221
Definition proto.h:2306
Definition proto.h:2328
Definition proto.h:2249
Definition proto.h:2198
Definition proto.h:2217
Definition proto.h:2210
Definition proto.h:3146
Definition proto.h:3223
Definition proto.h:3666
Definition proto.h:3625
Definition proto.h:3124
Definition proto.h:3553
Definition proto.h:3399
Definition proto.h:3642
Definition proto.h:3708
Definition proto.h:3729
Definition proto.h:3105
Definition proto.h:3101
Definition proto.h:3694
Definition proto.h:3166
Definition proto.h:2422
Definition proto.h:3655
Definition proto.h:2742
Definition proto.h:720
Definition proto.h:709
Definition proto.h:730
Definition proto.h:2646
Definition proto.h:2097
Definition proto.h:2062
Definition proto.h:3799
Definition proto.h:2296
Definition proto.h:1842
Definition proto.h:3065
Definition proto.h:2797
Definition proto.h:2045
Definition proto.h:3824
Definition proto.h:3813
Definition proto.h:3839
Definition proto.h:1224
Definition proto.h:1174
Definition proto.h:1182
Definition proto.h:1167
Definition proto.h:821
Definition proto.h:897
Definition proto.h:944
Definition proto.h:970
Definition proto.h:799
Definition proto.h:1076
Definition proto.h:1003
Definition proto.h:1018
Definition proto.h:1036
Definition proto.h:1054
Definition proto.h:1096
Definition proto.h:1118
Definition proto.h:806
Definition proto.h:2902
Definition proto.h:2889
Definition proto.h:2893
Definition proto.h:3020
Definition proto.h:2928
Definition proto.h:2907
Definition proto.h:2999
Definition proto.h:2879
Definition proto.h:2883
Definition proto.h:2875
Definition proto.h:2405
Definition proto.h:1985
Definition proto.h:1880
Definition proto.h:2026
Definition proto.h:2536
Definition proto.h:887
Definition proto.h:2382
Definition proto.h:2396
Definition proto.h:2753
Definition proto.h:3046
Definition proto.h:2846
Definition proto.h:1680
Definition proto.h:2711
Definition proto.h:3057
Definition proto.h:2765
Definition proto.h:2278
Definition proto.h:2858
Definition proto.h:2784
Definition proto.h:1687
Definition proto.h:2031
Definition proto.h:2125
Definition proto.h:1875
Definition proto.h:1868
Definition proto.h:3883
Definition proto.h:2736
Definition proto.h:2776
Definition proto.h:2134
Definition proto.h:1278
Definition proto.h:1251
Definition proto.h:1485
Definition proto.h:1476
Definition proto.h:1502
Definition proto.h:1494
Definition proto.h:1460
Definition proto.h:1445
Definition proto.h:1333
Definition proto.h:1418
Definition proto.h:1427
Definition proto.h:1436
Definition proto.h:1305
Definition proto.h:1533
Definition proto.h:1526
Definition proto.h:3887
Definition proto.h:1268
Definition proto.h:1258
Definition proto.h:1241
Definition proto.h:1231
Definition proto.h:1314
Definition proto.h:1342
Definition proto.h:1367
Definition proto.h:1392
Definition proto.h:1289
Definition proto.h:1829
Definition proto.h:791
Definition proto.h:782
Definition proto.h:1765
Definition proto.h:1779
Definition proto.h:1794
Definition proto.h:1753
Definition proto.h:1554
Definition proto.h:1576
Definition proto.h:1562
Definition proto.h:1540
Definition proto.h:1863
Definition proto.h:696
Definition proto.h:725
Definition proto.h:703
Definition proto.h:2594
Definition proto.h:3090
Definition proto.h:2841
Definition proto.h:2829
Definition proto.h:3097
Definition proto.h:3074
Definition proto.h:2789
Definition proto.h:2801
Definition proto.h:2286
Definition proto.h:1858
Definition proto.h:1851
Definition proto.h:1211
Definition proto.h:1199
Definition proto.h:1153
Definition proto.h:1140
Definition proto.h:776
Definition proto.h:747
Definition proto.h:742
Definition proto.h:687
Definition proto.h:2478
Definition proto.h:2452
Definition proto.h:2576
Definition proto.h:2459
Definition proto.h:2446
Definition proto.h:2427
Definition proto.h:2587
Definition proto.h:2689
Definition proto.h:3680
Definition proto.h:3782
Definition proto.h:3151
Definition proto.h:715