summaryrefslogtreecommitdiffstats
path: root/conf.d/project/lua.d/onload-aaaa-02-timer.lua
blob: db7a93732c3dbff5878ab29f43bb58285afc8925 (plain)
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
--[[
  Copyright (C) 2016 "IoT.bzh"
  Author Fulup Ar Foll <fulup@iot.bzh>
 
  Licensed under the Apache License, Version 2.0 (the "License");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at
 
    http://www.apache.org/licenses/LICENSE-2.0
 
  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an "AS IS" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.
  
 
  Provide Sample Timer Handing to push event from LUA
--]]

-- Create event on Lua script load
local MyEventHandle=AFB:evtmake("MyTestEvent")

-- Call count time every delay/ms 
local function Timer_Test_CB (timer, context) 

   local evtinfo= AFB:timerget(timer)
   print ("timer=", Dump_Table(evtinfo))

   --send an event an event with count as value
   AFB:evtpush (MyEventHandle, {["label"]= evtinfo["label"], ["count"]=evtinfo["count"], ["info"]=context["info"]})
   
   -- note when timerCB return!=0 timer is kill
   return 0

end

-- sendback event depending on count and delay
function _Simple_Timer_Test (request, args)
 
    local context = {
        ["info"]="My 1st private Event",
    }
 
    -- if delay not defined default is 5s
    if (args["delay"]==nil) then args["delay"]=5000 end

    -- if count is not defined default is 10
    if (args["count"]==nil) then args["count"]=10 end

    -- we could use directly args but it is a sample
    local myTimer = {
       ["label"]=args["label"],
       ["delay"]=args["delay"],
       ["count"]=args["count"],
    }
    AFB:notice ("Test_Timer myTimer=%s", myTimer)

    -- subscribe to event
    AFB:subscribe (request, MyEventHandle)

    -- settimer take a table with delay+count as input (count==0 means infinite)
    AFB:timerset (myTimer, "Timer_Test_CB", context)

    -- nothing special to return send back args
    AFB:success (request, myTimer)

    return 0
end