summaryrefslogtreecommitdiffstats
path: root/helloworld-subscribe-event/helloworld-service-binding.c
diff options
context:
space:
mode:
authorFrederic Marec <frederic.marec@iot.bzh>2019-06-28 11:22:11 +0200
committerFrederic Marec <frederic.marec@iot.bzh>2019-07-04 10:30:12 +0200
commit4edf6cc629af725548430ea75af25fe9ca76ed33 (patch)
tree440835b826e610555085f7db9f65707d772ab3f3 /helloworld-subscribe-event/helloworld-service-binding.c
parent26f567fdd0255e4eb88b823f7af34313007e35ca (diff)
Initial commit
Bug-AGL: SPEC-2020 Create README.md add git submodule from app-templates Change-Id: I091f4e527a9713772356bdb2cf6e89e2ea5267a4 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> add sources and CMakelists Change-Id: I6b54d16764435c166e6ae261f48d1d6df34fdcad Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> CMakelists: fix config.cmake path Change-Id: I87d774cb09d41b4f83a1ebea92feef27791dfadc Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> conf.d: move to master branch Change-Id: Idd92d6aa5e136b1fd193ad4774204535bb423964 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> Add build instruction in README Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh> Add gitignore Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh> move config.cmake to subdir conf.d Change-Id: I329f858f0d5a56f6db4c7441cb9e8e2fa0a1a5f0 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> conf.d/default: add submodule to app-templates Change-Id: I201a35efe3ea9679d39f3f5e9e28e47bf88481ab Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> CMakeLists: fix path to use conf.d/default Change-Id: Ic6d5b467baa0e871466d893073687a396a2d0ccf Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> config.cmake: fix app-templates path Change-Id: I9e5c7cd0648a23c006642b4031cee5394551579f Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> config.cmake: update content entry point and mimetype Change-Id: I671633e3b10c540aa38c8ab160136be971d575a4 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> update gitignore for vim Change-Id: I7925ef65d3e35fd6458be58ec7e1130e74d02af1 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> README: updated Change-Id: I8af6297184c1633aa07dda4dcd5f37b261795e6b Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> bump app-templates Change-Id: I88353abd15bade3df0538e47a332b5ef10606587 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> config: add custom widget config; bump app-templates Change-Id: I1407d99ea9eced4f653c3b9ef78b5064266843a1 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> add RPM specfile; bump app-templates; fix conf.d/* paths Change-Id: I06cf8cae10f0783b45ef10c0891202347d8c7ec4 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> rename conf.d/default to conf.d/app-templates Change-Id: I3e91069c5f3019274f2b09255c783b240134faab Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> config.cmake: fix widget entry point Change-Id: I5a0c1fd2ac97c0643273e25d2cbb1d761b2af5d5 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> adjust config.xml (required-api); bump app-templates Change-Id: I8b68f239fa0ee7107ac211cda24060b0ba447300 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> fix binder api export mode; fix 'licence' typo Change-Id: I57c4f4480412850160e4b0d523a2b52b30567fc3 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> Allows kernel minimal version check Update submodule that allows the check to be performed against a Yocto generated SDK or current running kernel Change-Id: If5a1f312091d9ad0b9c80b4824c8e0081513aced Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Use latest app-templates version Change-Id: If485ae471590a529e038a1636708a7e819aa22ce Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> update cmake config file Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> fix build warning Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> Update packaging * Add debian packaging Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> Update to the latest app-templates version No more needs to call any macro and only include config.cmake file is mandatory. Common.cmake is include from config.cmake file Generation autobuild script in conf.d/autobuild dir Change-Id: I0b9bf73209e9ffbcab687024b6580f0a8c399597 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> update gitignore Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> Use latest version of conf.d/app-templates submodule. Changes of conf.d/app-templates: > Fix: idem... > Fix: Debian things triggered even when use the SDK > Merge "Add pkg-config for deb packaging" > Fix: wrong variable expands at configure_file time > Comments and README update > Autobuild scripts directory execution proof > Use variable to handle autobuild target directory > Fix: Debian detection, only valid in native env > Move variable definition to the right place. > change path etc/config.cmake to conf.d/cmake/config.cmake Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh> conf.d/autobuild: add generated autobuild script Change-Id: I79772a93e98e6f990890336728e356d6ddd2e3d0 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> Migration to binding version 2 Change-Id: I4dd1b0bf213a5b0d3d1751dbde781f88645f3f56 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Update app-templates Change-Id: Idbb3fe78aab559b5c81899861a07d01265f09867 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Fix: missing MimeType Change-Id: Ia114680759481cf8eefd795143760485026c8680 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Updated autobuild scripts. Change-Id: I7c16f07420eeb312061b5164a00dbd10a9325f5d Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Update to the latest version resolving yocto build Change-Id: I6ad988bc1ac457eaf24c0b586ab9d3754fa62bbf Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Fix widget type Use latest version of conf.d/app-templates submodule. Changes of conf.d/app-templates: (48149ac - Sebastien Douheret) Set scripts sh as executable (8c2d06a - Romain Forlot) Add configured file to files to clean up with make (e475d27 - Romain Forlot) Fix: wrong extension of configured files (e2fefbf - Romain Forlot) Add some reminder (6be72c1 - Romain Forlot) Fix: Yocto cross compile flag same the last commit Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh> Use latest version of conf.d/app-templates submodule. Changes of conf.d/app-templates: (70dc538 - Romain Forlot) Default execution flag on shell scripts templates. (be6f910 - Romain Forlot) Fix: also avoid cleaning generated packaging files (85ece74 - Romain Forlot) Fix: cleaning of autobuild script using make clean (747c39c - Romain Forlot) Fix: cleaning generated additionals files (48149ac - Sebastien Douheret) Set scripts sh as executable Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh> update app-templates Signed-off-by: Builder <devel@e24d0b5cccc1> update autobuild script Signed-off-by: Builder <devel@e24d0b5cccc1> update .gitignore Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> add security auth Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> update documentation Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> fix README Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> Update README.md Update For New App Template Set correct ldpaths in closing message. Git ignore private files/dirs (starting by __*) Add simple html page to test helloworld service. Add htdocs/assets to install Update version Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> update app-templates Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> update packaging Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh> app-templates: bump to 42e5f14 Change-Id: I33a3680db8109e2c817e564662d965ef22274a11 Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> bump submodule conf.d/app-templates Change-Id: I605aa515568dbbada37b3ff0a7f9ed21a2aed51a Signed-off-by: Stephane Desneux <stephane.desneux@iot.bzh> Update app-templates and autobuild script Change-Id: Ic8a2cb9b7e42d821a1452923a714280a432a508f Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Fix variable overlapping Issue #3 Change-Id: I0f0b81a59ab45bbb9a54350878553a4f4332d20f Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Fix typo ! C/C is the evil, C/C is the evil, C/C is the evil ! app-templates migration to cmake module Change-Id: I402cdc81f933201b6260fa72145e349b48b8c902 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Update readme about CMake module dependency Change-Id: Id7ee12069a47fcf05821d2338cf501fffb4cbbe2 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Switch to bindings V3 Aply automatic migration script. Update disclamer dates Remove dumb dependencies Signed-off-by: Jose Bollo <jose.bollo@iot.bzh> Reorganization, new helloworld variant - Add a new binding service example with subscription/unsubscription and event mechanisms implementation example. - Adding the autobuild scripts within the repository Change-Id: I53efc22ac868e47ea7cffd3f8916fe21528ab9c7 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh> Correct some errors in README.md Adding information about JSON library and HTTPD alternative package package. Signed-off-by: Marc-Antoine Riou <marc-antoine.riou@iot.bzh> readme: Update agl script name Since the commit https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-binder.git;a=commit;h=c80873f04c5122e579333b4cf363dd623200e822, AGL-app-framework-binder.sh script has been renamed. Signed-off-by: Pierre MARZIN <pierre.marzin@iot.bzh> conf.d: Correct name of the required-api Needed since the "Reorganization" of helloworld service (commit 2f2658dc9fe2abe2d059e52dc8fbb3ab531f8a9d). Signed-off-by: Pierre MARZIN <pierre.marzin@iot.bzh> test: Add test scripts to test hello binding Scripts come from the app-afb-test binding example. They have been added here to complete the demo example of helloworld binding. Use the official documentation to build and launch the test : http://docs.automotivelinux.org/master/docs/apis_services/en/dev/reference/afb-test/the-test-widget.html Signed-off-by: Pierre MARZIN <pierre.marzin@iot.bzh> test: Correct helloworld tests Correct API name. Correct some tests exemple. Delete event tests (event are not in helloworld-skeleton anymore). Signed-off-by: Pierre MARZIN <pierre.marzin@iot.bzh> binding: change api name Use a different api name to differenciate both helloworld example. Signed-off-by: Pierre MARZIN <pierre.marzin@iot.bzh> Remove redundant autobuild script. Signed-off-by: Li Xiaoming <lixm.fnst@cn.fujitsu.com> Change-Id: I7d694edc236ce918db54d1e830a26eb32b83de5a Signed-off-by: Frederic Marec <frederic.marec@iot.bzh>
Diffstat (limited to 'helloworld-subscribe-event/helloworld-service-binding.c')
-rw-r--r--helloworld-subscribe-event/helloworld-service-binding.c133
1 files changed, 133 insertions, 0 deletions
diff --git a/helloworld-subscribe-event/helloworld-service-binding.c b/helloworld-subscribe-event/helloworld-service-binding.c
new file mode 100644
index 0000000..ce525e7
--- /dev/null
+++ b/helloworld-subscribe-event/helloworld-service-binding.c
@@ -0,0 +1,133 @@
+/*
+ * Copyright (C) 2016-2018 "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.
+ */
+#define _GNU_SOURCE
+#include <stdio.h>
+#include <string.h>
+#include <json-c/json.h>
+
+#define AFB_BINDING_VERSION 3
+#include <afb/afb-binding.h>
+
+static afb_event_t event;
+
+static void pingSample(afb_req_t request)
+{
+ static int pingcount = 0;
+ int listeners = 0;
+
+ if(afb_event_is_valid(event))
+ listeners = afb_event_push(event, json_object_new_int(pingcount));
+
+ afb_req_success_f(request, json_object_new_int(pingcount), "Ping count = %d, Event listeners = %d", pingcount, listeners);
+
+ AFB_API_NOTICE(afbBindingV3root, "Verbosity macro at level notice invoked at ping invocation, count = %d, event listeners = %d", pingcount, listeners);
+
+ pingcount++;
+}
+
+static void subscribeSample(afb_req_t request)
+{
+ // Event not valid ? then creating one.
+ if(! afb_event_is_valid(event))
+ event = afb_api_make_event(request->api, "PingCount");
+
+
+ if(afb_req_subscribe(request, event) < 0) {
+ afb_req_fail(request, "Error", "Subscription operation failed");
+ return;
+ }
+
+ afb_req_success(request, NULL, NULL);
+
+ AFB_API_NOTICE(request->api, "Verbosity macro at level notice invoked at subscribe invocation");
+}
+
+static void unsubscribeSample(afb_req_t request)
+{
+ if(! afb_event_is_valid(event)) {
+ afb_req_fail(request, "Invalid", "Event not valid");
+ return;
+ }
+
+ if(afb_req_unsubscribe(request, event) < 0) {
+ afb_req_fail(request, "Error", "Unsubscription operation failed");
+ return;
+ }
+
+ afb_req_success(request, NULL, NULL);
+ AFB_API_NOTICE(request->api, "Verbosity macro at level notice invoked at unsubscribe invocation");
+}
+
+// testArgsSample - return success only if argument is set to {"cezam": "open"}
+static void testArgsSample(afb_req_t request)
+{
+ json_object *tmpJ;
+ json_object *res = json_object_new_object();
+ json_object *queryJ = afb_req_json(request);
+
+ json_bool success = json_object_object_get_ex(queryJ, "cezam", &tmpJ);
+ if (!success) {
+ afb_req_fail_f(request, "ERROR", "key cezam not found in '%s'", json_object_get_string(queryJ));
+ return;
+ }
+
+ if (json_object_get_type(tmpJ) != json_type_string) {
+ afb_req_fail(request, "ERROR", "key cezam not a string");
+ return;
+ }
+
+ if (strncmp(json_object_get_string(tmpJ), "open", 4) == 0) {
+ json_object_object_add(res, "code", json_object_new_int(123456789));
+ afb_req_success(request, res, NULL);
+ return;
+ }
+
+ afb_req_fail_f(request, "ERROR", "value of cezam (%s) is not the expected one.",
+ json_object_get_string(queryJ));
+}
+
+static const struct afb_auth _afb_auths_monitor[] = {
+ {.type = afb_auth_Permission, .text = "urn:AGL:permission:monitor:public:set"},
+ {.type = afb_auth_Permission, .text = "urn:AGL:permission:monitor:public:get"},
+ {.type = afb_auth_Or, .first = &_afb_auths_monitor[1], .next = &_afb_auths_monitor[0]}
+};
+
+static const afb_verb_t verbs[] = {
+ /*Without security*/
+ {.verb = "ping", .session = AFB_SESSION_NONE, .callback = pingSample, .auth = NULL},
+
+ /*With security "urn:AGL:permission:monitor:public:get"*/
+ /*{ .verb = "ping" , .session = AFB_SESSION_NONE, .callback = pingSample , .auth = &_afb_auths_monitor[1]},*/
+
+ {.verb = "subscribe", .session = AFB_SESSION_NONE, .callback = subscribeSample, .auth = NULL},
+ {.verb = "unsubscribe", .session = AFB_SESSION_NONE, .callback = unsubscribeSample, .auth = NULL},
+ {.verb = "testargs", .session = AFB_SESSION_NONE, .callback = testArgsSample, .auth = NULL},
+ {NULL}
+};
+
+const afb_binding_t afbBindingExport = {
+ .api = "helloworld-event",
+ .specification = NULL,
+ .verbs = verbs,
+ .preinit = NULL,
+ .init = NULL,
+ .onevent = NULL,
+ .userdata = NULL,
+ .provide_class = NULL,
+ .require_class = NULL,
+ .require_api = NULL,
+ .noconcurrency = 0
+};