diff options
author | Frederic Marec <frederic.marec@iot.bzh> | 2019-06-28 11:22:11 +0200 |
---|---|---|
committer | Frédéric Marec <frederic.marec@iot.bzh> | 2019-07-04 08:31:24 +0000 |
commit | 244b28e3d8aacb033c2bd3e55efa53fa0df8e635 (patch) | |
tree | ae7c52f02d33fa25b75d11af056241766e2541c6 /helloworld-subscribe-event | |
parent | 8908a2b9a68df88ae9191ef8ab1baea95b145946 (diff) |
Initial commitguppy_7.0.4guppy/7.0.47.0.4guppy
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')
-rw-r--r-- | helloworld-subscribe-event/CMakeLists.txt | 28 | ||||
-rw-r--r-- | helloworld-subscribe-event/helloworld-service-binding.c | 133 |
2 files changed, 161 insertions, 0 deletions
diff --git a/helloworld-subscribe-event/CMakeLists.txt b/helloworld-subscribe-event/CMakeLists.txt new file mode 100644 index 0000000..131e8d4 --- /dev/null +++ b/helloworld-subscribe-event/CMakeLists.txt @@ -0,0 +1,28 @@ +########################################################################### +# Copyright 2015, 2016, 2017 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. +########################################################################### + +# Add target to project dependency list +PROJECT_TARGET_ADD(helloworld-subscribe-event) + # Define project Targets + ADD_LIBRARY(${TARGET_NAME} MODULE helloworld-service-binding.c) + + # Binder exposes a unique public entry point + SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES + PREFIX "afb-" + LABELS "BINDING" + LINK_FLAGS ${BINDINGS_LINK_FLAG} + OUTPUT_NAME ${TARGET_NAME} + ) 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 +}; |