aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRomain Forlot <romain.forlot@iot.bzh>2017-09-28 20:10:45 +0200
committerRomain Forlot <romain.forlot@iot.bzh>2017-12-14 11:00:25 +0100
commit8364673ab93eb484e25c7c4776e5d705b73330b4 (patch)
tree950b7c184325dc4b03e0b255ee2717da61b1eeb2
parent0aa66b2b00593db8b545384bbf084bc1d0acee64 (diff)
Add default receive action
Change-Id: Icc23f135d4e65d6de131a60b978677e549738d78 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh>
-rw-r--r--signal-composer-binding/signal.cpp70
-rw-r--r--signal-composer-binding/signal.hpp2
2 files changed, 71 insertions, 1 deletions
diff --git a/signal-composer-binding/signal.cpp b/signal-composer-binding/signal.cpp
index c9d4e81..019cbe7 100644
--- a/signal-composer-binding/signal.cpp
+++ b/signal-composer-binding/signal.cpp
@@ -166,6 +166,54 @@ void Signal::update(Signal* sig)
AFB_NOTICE("Got an update from observed signal %s", sig->id().c_str());
}
+/// @brief
+///
+/// @param[in] queryJ - json_object containing event data to process
+///
+/// @return 0 if ok, -1 or others if not
+int Signal::defaultReceivedCB(json_object *queryJ)
+{
+ uint64_t ts = 0;
+ struct signalValue sv = {0,0,0,0,0,""};
+ json_object_iterator iter = json_object_iter_begin(queryJ);
+ json_object_iterator iterEnd = json_object_iter_end(queryJ);
+ while(!json_object_iter_equal(&iter, &iterEnd))
+ {
+ std::string name = json_object_iter_peek_name(&iter);
+ std::transform(name.begin(), name.end(), name.begin(), ::tolower);
+ json_object *value = json_object_iter_peek_value(&iter);
+ if (name.find("value") || name.find(id_))
+ {
+ if(json_object_is_type(value, json_type_double))
+ {sv = {0,0,true,json_object_get_double(value),0,""};}
+ else if(json_object_is_type(value, json_type_boolean))
+ {sv = {true,json_object_get_int(value),0,0,0,""};}
+ else if(json_object_is_type(value, json_type_string))
+ {sv = {0,0,0,0,true,json_object_get_string(value)};}
+ }
+ else if (name.find("timestamp"))
+ {
+ ts = json_object_is_type(value, json_type_int) ? json_object_get_int64(value):ts;
+ }
+ json_object_iter_next(&iter);
+ }
+
+ if(!sv.hasBool && !sv.hasNum && !sv.hasStr)
+ {
+ AFB_ERROR("No data found to set signal %s in %s", id_.c_str(), json_object_to_json_string(queryJ));
+ return -1;
+ }
+ else if(ts == 0)
+ {
+ struct timespec t_usec;
+ if(!::clock_gettime(CLOCK_MONOTONIC, &t_usec))
+ ts = (t_usec.tv_nsec / 1000ll) + (t_usec.tv_sec* 1000000ll);
+ }
+
+ set(ts, sv);
+ return 0;
+}
+
/// @brief Notify observers that there is a change and execute callback defined
/// when signal is received
///
@@ -174,7 +222,27 @@ void Signal::update(Signal* sig)
/// @return 0 if OK, -1 or other if not.
int Signal::onReceivedCB(json_object *queryJ)
{
- int err = onReceived_ ? ActionExecOne(onReceived_, queryJ) : 0;
+ if(onReceived_ && onReceived_->type == CTL_TYPE_LUA)
+ {
+ json_object_iterator iter = json_object_iter_begin(queryJ);
+ json_object_iterator iterEnd = json_object_iter_end(queryJ);
+ while(!json_object_iter_equal(&iter, &iterEnd))
+ {
+ const char *name = ::strdup(json_object_iter_peek_name(&iter));
+ json_object *value = json_object_iter_peek_value(&iter);
+ if(json_object_is_type(value, json_type_int))
+ {
+ int64_t newVal = json_object_get_int64(value);
+ newVal = newVal > USEC_TIMESTAMP_FLAG ? newVal/MICRO:newVal;
+ json_object_object_del(queryJ, name);
+ json_object* luaVal = json_object_new_int64(newVal);
+ json_object_object_add(queryJ, name, luaVal);
+ }
+ json_object_iter_next(&iter);
+ }
+ }
+ AFB_NOTICE("JSON %s", json_object_to_json_string(queryJ));
+ int err = onReceived_ ? ActionExecOne(onReceived_, queryJ) : defaultReceivedCB(queryJ);
notify();
return err;
}
diff --git a/signal-composer-binding/signal.hpp b/signal-composer-binding/signal.hpp
index 66b14e5..3d373fa 100644
--- a/signal-composer-binding/signal.hpp
+++ b/signal-composer-binding/signal.hpp
@@ -78,6 +78,8 @@ public:
void set(uint64_t timestamp, struct signalValue& value);
void update(Signal* sig);
+ static int defaultOnReceivedCB(CtlSourceT* source, json_object* argsJ, json_object *queryJ);
+ int defaultReceivedCB(json_object *queryJ);
int onReceivedCB(json_object *queryJ);
void attachToSourceSignals(Composer& composer);