-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCEM2_Softlink
118 lines (101 loc) · 4.65 KB
/
CEM2_Softlink
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
-- CEM2 Softlink connector dzVents Script
-- Martin Saidl (c) 2022
local version = '0.2' -- current version of script
------------------------------------------------------------------------
local LOGGING = false -- true or false LOGGING info to domoticz log.
local cemApiUrl = 'https://cemapi.unimonitor.eu/api'
local user = 'UserName'
local pass = 'Password'
local sensors = {}
sensors['CEM2_id1'] = DZ_id1
sensors['CEM2_id2'] = DZ_id2
sensors['sum'] = DZ_id3
local maxTime = 7200 -- Maximul time interval
local timeZone = 3600 -- CEM2 Time zone
local mult = 100 -- m3 -> 10l
------------------------------------------------------------------------
local sum = 0
local updateSum = true
local unixEpoch = os.time(os.date("!*t")) + timeZone
local function log(domoticz, text, lvlError)
local lvlLog = domoticz.LOG_INFO
if lvlError ~= nil and lvlError == true then lvlLog = domoticz.LOG_ERROR end
if LOGGING or lvlError then domoticz.log(text, lvlLog) end
end
return {
logging = {
marker = 'CEM2_Softlink'
},
on = {
timer = { 'every 30 minutes' }, -- Start the script in every 30 minutes
httpResponses = { 'cemLoginResponse', 'cemDataResponse', 'cemLogoutResponse' },
},
execute = function(domoticz, item)
log(domoticz,'')
log(domoticz,'CEM Connector ver: '.. version)
-- Start the script in every N minutes
if item.isTimer then
log(domoticz,'Trigerred by timer')
log(domoticz,'Logging to API')
local url = cemApiUrl .. '?id=4&user=' .. user .. '&pass=' .. pass
domoticz.openURL({
url = url,
method = 'GET',
callback = 'cemLoginResponse'
})
-- HTTP Response handler
elseif item.isHTTPResponse then
log(domoticz,'Trigerred by HTTP Response')
log(domoticz,item.trigger)
if item.ok then
log(domoticz,'200 OK Continue')
if (item.trigger == 'cemLoginResponse') then
log(domoticz,'Login successful.')
local url = cemApiUrl .. '?id=21'
domoticz.openURL({
url = url,
method = 'GET',
callback = 'cemDataResponse'
})
elseif (item.trigger == 'cemDataResponse') then
log(domoticz,'Data downloaded.')
log(domoticz,item.data)
local json = domoticz.utils.fromJSON(item.data)
for i, sensorCem in pairs(json) do
local varId = sensorCem.var_id
local value = sensorCem.values[1]["value"]
local timestamp = sensorCem.values[1]["timestamp"]
local delay = (unixEpoch - tonumber(timestamp) / 1000)
local delayMinutes = math.floor(delay/60)
log(domoticz, 'Time since last measurement: ' .. delayMinutes .. ' minutes.')
if (delay < maxTime) then
sum = sum + value
domoticz.devices(sensors[varId]).updateCounter(value * mult)
log(domoticz,'Device value updated')
else
updateSum = false
log(domoticz,'Sensor value is too old! Time since last measurement:' .. delayMinutes .. ' minutes.', true)
end
end
if updateSum then
domoticz.devices(sensors['sum']).updateCounter(sum * mult)
end
local url = cemApiUrl .. '?id=5'
domoticz.openURL({
url = url,
method = 'GET',
callback = 'cemLogoutResponse'
})
elseif (item.trigger == 'cemLogoutResponse') then
log(domoticz,'Logout successful.')
else
log(domoticz,'Unknown trigger!', true)
end
else
log(domoticz,'Transaction Error!', true)
end
end
log(domoticz,'Done')
log(domoticz,'')
end
}