From 8160b5cdc8547277f3f31ee1e41524754d5d987d Mon Sep 17 00:00:00 2001 From: =?utf8?q?Jan-Simon=20M=C3=B6ller?= Date: Wed, 26 Jan 2022 12:25:31 +0100 Subject: [PATCH] Update to documentation before Marlin MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit This is mostly a cleanup before the Magic Marlin Release. We do have the Application Framework chapter rewrite pending. Bug-AGL: SPEC-4236 Signed-off-by: Jan-Simon Möller Change-Id: I7e1f39667b4db417497b1d0c84065c173fa18439 Reviewed-on: https://gerrit.automotivelinux.org/gerrit/c/AGL/documentation/+/27097 --- .../1_Quickstart/Using_Ready_Made_Images.md | 2 +- .../3_Initializing_Your_Build_Environment.md | 130 +- .../5_1_x86_Emulation_and_Hardware.md | 47 +- docs/3_Developer_Guides/0_FIXME.md | 0 .../1_Application_Framework/0_Introduction.md | 261 -- .../1_Application_Framework/1_afm-daemons.md | 649 ----- .../1_Application_Framework/2_widgets.md | 11 - .../1_Application_Framework/3_widgets_overview.md | 158 -- .../4_Widget_configuration_file.md | 589 ----- .../1_Application_Framework/5_Permissions.md | 131 - .../1_Application_Framework/6_Quick-Tutorial.md | 267 --- .../images/AppFW-APP_install_sequences.svg | 408 ---- .../images/Security_model_history.svg | 149 -- .../1_Application_Framework/images/afm-daemons.svg | 237 -- .../1_Application_Framework/images/make-units.svg | 436 ---- docs/3_Developer_Guides/1_Setting_Up_AGL_SDK.md | 2 +- .../2_Application_Framework_Binder/0_Overview.md | 91 - .../1_Binder_daemon_vocabulary.md | 104 - .../2_How_to_write_a_binding.md | 444 ---- .../3_Binder_References.md | 2524 -------------------- .../4_Binder_events_guide.md | 291 --- .../5_Binder_Application_writing_guide.md | 319 --- .../7_Document_revisions.md | 17 - .../Annexes/1_Migration_to_bindings_v3.md | 199 -- .../Annexes/2_WebSocket_protocol_x-afb-ws-json1.md | 308 --- .../3_Installing_the_binder_on_a_desktop.md | 44 - .../Annexes/4_Options_of_afb-daemon.md | 355 --- .../Annexes/5_Debugging_binder_and_bindings.md | 38 - .../Annexes/6_LEGACY_Migration_from_v1_to_v2.md | 656 ----- .../Annexes/7_LEGACY_Binding_v2_references.md | 757 ------ .../images/basis.svg | 356 --- .../images/interconnection.svg | 854 ------- .../images/signaling-basis.svg | 145 -- .../3_Developer_Guides/2_Creating_a_New_Service.md | 507 +--- .../03-AGL-AppFW-Privileges-Management.pdf | Bin 1143778 -> 0 bytes .../AppFW-Privileges_Management.md | 8 - .../3_Creating_a_New_Application.md | 541 +---- .../4_AFB_Helper_Guide/1_Usage.md | 83 - .../4_AFB_Helper_Guide/2_AFB_Timer.md | 50 - .../4_AFB_Helper_Guide/3_CURL_wrapper.md | 113 - .../4_AFB_Helper_Guide/4_URL_Escaping.md | 39 - .../4_AFB_Helper_Guide/5_Filescan_Utils.md | 82 - .../6_Qt_AFB_Websocket_client.md | 41 - .../7_JSON_library_for_modern_C++.md | 894 ------- .../4_AFB_Helper_Guide/8_C_JSON_Wrapper.md | 341 --- .../1_Project_Architecture.md | 74 - .../2_Configuring_AGL_CMake_Templates.md | 136 -- .../3_Advanced_Usage.md | 305 --- .../4_Advanced_Customization.md | 112 - .../5_Autobuild.md | 152 -- ...6_Using_CMake_Templates_from_Bitbake_Recipes.md | 56 - docs/4_APIs_and_Services/0_API_Reference.md | 48 - docs/4_APIs_and_Services/FIXME.md | 0 .../{5_appfw.md => 5_application_framework.md} | 0 docs/5_Component_Documentation/6_cynagora.md | 7 - ...re_wireplumber.md => 6_pipewire_wireplumber.md} | 0 ...9_ic-sound-manager.md => 7_ic-sound-manager.md} | 0 docs/5_Component_Documentation/7_pyagl.md | 250 -- docs/index.md | 1 + 59 files changed, 96 insertions(+), 14723 deletions(-) create mode 100644 docs/3_Developer_Guides/0_FIXME.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/0_Introduction.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/1_afm-daemons.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/2_widgets.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/3_widgets_overview.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/4_Widget_configuration_file.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/5_Permissions.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/6_Quick-Tutorial.md delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/images/AppFW-APP_install_sequences.svg delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/images/Security_model_history.svg delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/images/afm-daemons.svg delete mode 100644 docs/3_Developer_Guides/1_Application_Framework/images/make-units.svg delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/0_Overview.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/1_Binder_daemon_vocabulary.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/2_How_to_write_a_binding.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/3_Binder_References.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/4_Binder_events_guide.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/5_Binder_Application_writing_guide.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/7_Document_revisions.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/1_Migration_to_bindings_v3.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/2_WebSocket_protocol_x-afb-ws-json1.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/3_Installing_the_binder_on_a_desktop.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/4_Options_of_afb-daemon.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/5_Debugging_binder_and_bindings.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/6_LEGACY_Migration_from_v1_to_v2.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/7_LEGACY_Binding_v2_references.md delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/images/basis.svg delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/images/interconnection.svg delete mode 100644 docs/3_Developer_Guides/2_Application_Framework_Binder/images/signaling-basis.svg delete mode 100644 docs/3_Developer_Guides/3_AppFW_Privileges_Management/03-AGL-AppFW-Privileges-Management.pdf delete mode 100644 docs/3_Developer_Guides/3_AppFW_Privileges_Management/AppFW-Privileges_Management.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/1_Usage.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/2_AFB_Timer.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/3_CURL_wrapper.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/4_URL_Escaping.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/5_Filescan_Utils.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/6_Qt_AFB_Websocket_client.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/7_JSON_library_for_modern_C++.md delete mode 100644 docs/3_Developer_Guides/4_AFB_Helper_Guide/8_C_JSON_Wrapper.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/1_Project_Architecture.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/2_Configuring_AGL_CMake_Templates.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/3_Advanced_Usage.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/4_Advanced_Customization.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/5_Autobuild.md delete mode 100644 docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/6_Using_CMake_Templates_from_Bitbake_Recipes.md delete mode 100644 docs/4_APIs_and_Services/0_API_Reference.md create mode 100644 docs/4_APIs_and_Services/FIXME.md rename docs/5_Component_Documentation/{5_appfw.md => 5_application_framework.md} (100%) delete mode 100644 docs/5_Component_Documentation/6_cynagora.md rename docs/5_Component_Documentation/{8_pipewire_wireplumber.md => 6_pipewire_wireplumber.md} (100%) rename docs/5_Component_Documentation/{9_ic-sound-manager.md => 7_ic-sound-manager.md} (100%) delete mode 100644 docs/5_Component_Documentation/7_pyagl.md diff --git a/docs/0_Getting_Started/1_Quickstart/Using_Ready_Made_Images.md b/docs/0_Getting_Started/1_Quickstart/Using_Ready_Made_Images.md index a10becd..eaae38e 100644 --- a/docs/0_Getting_Started/1_Quickstart/Using_Ready_Made_Images.md +++ b/docs/0_Getting_Started/1_Quickstart/Using_Ready_Made_Images.md @@ -44,7 +44,7 @@ AGL provides a number of pre-built ready-made images of various versions. ```sh $ ( sleep 5 && vinagre --vnc-scale localhost ) > /tmp/vinagre.log 2>&1 & - qemu-system-x86_64 -device virtio-net-pci,netdev=net0,mac=52:54:00:12:35:02 -netdev user,id=net0,hostfwd=tcp::2222-:22 \ + $ qemu-system-x86_64 -device virtio-net-pci,netdev=net0,mac=52:54:00:12:35:02 -netdev user,id=net0,hostfwd=tcp::2222-:22 \ -drive file=agl-demo-platform-crosssdk-qemux86-64.ext4,if=virtio,format=raw -show-cursor -usb -usbdevice tablet -device virtio-rng-pci \ -snapshot -vga virtio \ -vnc :0 -soundhw hda -machine q35 -cpu kvm64 -cpu qemu64,+ssse3,+sse4.1,+sse4.2,+popcnt -enable-kvm \ diff --git a/docs/0_Getting_Started/2_Building_AGL_Image/3_Initializing_Your_Build_Environment.md b/docs/0_Getting_Started/2_Building_AGL_Image/3_Initializing_Your_Build_Environment.md index 15ad5ed..efe7001 100644 --- a/docs/0_Getting_Started/2_Building_AGL_Image/3_Initializing_Your_Build_Environment.md +++ b/docs/0_Getting_Started/2_Building_AGL_Image/3_Initializing_Your_Build_Environment.md @@ -36,8 +36,6 @@ Available machines: bbe # BeagleBoneEnhanced beaglebone # BeagleBone cubox-i # multiple i.MX6 boards - cyclone5 # CycloneV - dra7xx-evm # TI DRA7xx-EVM 'vayu' dragonboard-410c # Qualcomm Dragonboard 410c dragonboard-820c # Qualcomm Dragonboard 820c ebisu # Renesas RCar Ebisu @@ -50,6 +48,7 @@ Available machines: imx8mqevk # i.MX8 w etnaviv imx8mqevk-viv # i.MX8 w vivante intel-corei7-64 # x86-64 (Intel flavour) + j7-evm # TI Jacinto 7 EVM m3-salvator-x # Renesas RCar Salvator/M3 m3ulcb # Renesas RCar M3 m3ulcb-kf # Renesas RCar M3 w Kingfisher Board @@ -59,6 +58,8 @@ Available machines: qemuarm64 # Qemu AArch 64 (ARM 64bit) * qemux86-64 # Qemu x86-64 raspberrypi4 # Raspberry Pi 4 + virtio-aarch64 # Virtio Guest + ``` ## AGL Features @@ -72,54 +73,50 @@ Following is a list of the available features: ```sh Available features: - [meta-agl] - agl-all-features :( agl-demo agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework agl-netboot ) - agl-appfw-smack - agl-archiver - agl-buildstats - agl-ci - agl-ci-change-features :( agl-demo agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework agl-devel agl-netboot agl-pipewire agl-cloudproxy agl-buildstats agl-ptest ) - agl-ci-change-features-nogfx :( agl-demo agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework agl-devel agl-netboot agl-pipewire agl-cloudproxy agl-buildstats agl-ptest ) - agl-ci-snapshot-features :( agl-demo agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework agl-devel agl-netboot agl-archiver agl-pipewire agl-buildstats agl-ptest ) - agl-ci-snapshot-features-nogfx :( agl-demo agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework agl-devel agl-netboot agl-archiver agl-pipewire agl-buildstats agl-ptest ) - agl-devel - agl-fossdriver - agl-gplv2 - agl-hmi-framework - agl-netboot - agl-pipewire - agl-profile-cluster :( agl-profile-graphical ) - agl-profile-cluster-qt5 :( agl-profile-graphical-qt5 agl-profile-graphical ) - agl-profile-graphical - agl-profile-graphical-html5 :( agl-profile-graphical ) - agl-profile-graphical-qt5 :( agl-profile-graphical ) - agl-profile-hud - agl-profile-telematics - agl-ptest - agl-sign-wgts - agl-sota - agl-virt - agl-virt-guest-xen - agl-virt-xen :( agl-virt ) - agl-weston-remoting :( agl-profile-graphical ) - [meta-agl-cluster-demo] - agl-cluster-demo :( agl-profile-cluster-qt5 agl-profile-graphical-qt5 agl-profile-graphical agl-hmi-framework ) - agl-cluster-demo-preload - [meta-agl-demo] - agl-cloudproxy - agl-cluster-demo-support :( agl-weston-remoting agl-profile-graphical ) - agl-demo :( agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-pipewire agl-speech-framework ) - agl-demo-preload - agl-demo-soundmanager :( agl-appfw-smack agl-hmi-framework agl-profile-graphical-qt5 agl-profile-graphical agl-audio-soundmanager-framework ) - [meta-agl-devel] - agl-jailhouse - agl-speech-framework - agl-voiceagent-alexa :( agl-speech-framework ) - agl-voiceagent-alexa-wakeword :( agl-voiceagent-alexa agl-speech-framework ) - [meta-agl-extra] - agl-localdev - [meta-agl-telematics-demo] - agl-telematics-demo :( agl-profile-telematics ) + + [meta-agl] # CORE layer + agl-all-features :( agl-demo agl-pipewire agl-app-framework agl-netboot ) + # For the usual demo image + agl-app-framework # Application Framework + agl-archiver # Source Archiver + agl-buildstats # Build Statistics + agl-devel :( agl-package-management ) # Developer Env (root login) + agl-fossdriver # Fossology integration + agl-gplv2 # GPLv2-only packages + agl-localdev # inclusion of local development folder + agl-netboot # network boot (e.g. CI) + agl-package-management # include package management (e.g. rpm) + agl-pipewire # include pipewire + agl-ptest # enable ptest pckages + agl-refhw-h3 # enable reference hardware + agl-virt # EG-Virt features + agl-virt-guest-xen # EG-Virt features + agl-virt-xen :( agl-virt ) # EG-Virt features + agl-weston-remoting :( agl-demo agl-pipewire agl-app-framework ) + agl-weston-waltham-remoting :( agl-demo agl-pipewire agl-app-framework ) + + [meta-agl-demo] # DEMO layer + agl-cluster-demo-support :( agl-weston-remoting agl-demo agl-pipewire agl-app-framework ) + # sample IVI demo + agl-demo :( agl-pipewire agl-app-framework ) # default IVI demo + agl-demo-preload # Add Tokens and sample files + + [meta-agl-devel] # Development layer + agl-basesystem # Toyota basesystem + agl-drm-lease # DRM lease support + agl-egvirt # EG-Virt feature + agl-flutter # Flutter support + agl-jailhouse # GSoC: jailhouse enablement + agl-lxc :( agl-drm-lease agl-pipewire ) # IC-EG container support + agl-ros2 # GSoC: ros2 enablement + +Specialized features (e.g. CI): + agl-ci # Tweaks for CI + agl-ci-change-features :( agl-demo agl-pipewire agl-app-framework agl-devel agl-package-management agl-netboot agl-pipewire agl-buildstats agl-ptest ) + agl-ci-change-features-nogfx :( agl-demo agl-pipewire agl-app-framework agl-devel agl-package-management agl-netboot agl-pipewire agl-buildstats agl-ptest ) + agl-ci-snapshot-features :( agl-demo agl-pipewire agl-app-framework agl-devel agl-package-management agl-netboot agl-archiver agl-pipewire agl-buildstats agl-ptest ) + agl-ci-snapshot-features-nogfx :( agl-demo agl-pipewire agl-app-framework agl-devel agl-package-management agl-netboot agl-archiver agl-pipewire agl-buildstats agl-ptest ) + ``` To find out exactly what a feature provides, check out the respective layer and its README. @@ -136,8 +133,7 @@ Following are brief descriptions of the AGL features you can specify on the * **agl-all-features**: A set of AGL default features. Do not think of this set of features as all the AGL features. -* **agl-appfw-smack**: Enables IoT.bzh Application Framework plus SMACK and - Cynara. +* **agl-app-framework**: Application Framework * **agl-archiver**: Enables the archiver class for releases. @@ -163,45 +159,15 @@ Following are brief descriptions of the AGL features you can specify on the Netboot is needed for CI and useful for development to avoid writing sdcards. Needs additional setup. - - * **agl-ptest**: Enables [Ptest](https://yoctoproject.org/docs/3.1.4/dev-manual/dev-manual.html#testing-packages-with-ptest) as part of the build. -* **agl-sota**: Enables Software Over-the-Air (SOTA) components and dependencies. - Includes meta-updater, meta-updater-qemux86-64, meta-filesystems, and meta-python. - * **agl-demo**: Enables the layers meta-agl-demo and meta-qt5. You need agl-demo if you are going to build the agl-demo-platform. -* **agl-sdl**: Enables or adds SDL to the build. - * **agl-pipewire**: Enables AGLs pipewire support. -* **agl-audio-soundmanager-framework**: Enables Soundmanager framework, which is an exclusive switch for audio framework. - * **agl-localdev**: Adds a local layer named "meta-localdev" in the meta directory and a local.dev.inc configuration file when that file is present. diff --git a/docs/0_Getting_Started/2_Building_AGL_Image/5_1_x86_Emulation_and_Hardware.md b/docs/0_Getting_Started/2_Building_AGL_Image/5_1_x86_Emulation_and_Hardware.md index 0f2121c..7282f66 100644 --- a/docs/0_Getting_Started/2_Building_AGL_Image/5_1_x86_Emulation_and_Hardware.md +++ b/docs/0_Getting_Started/2_Building_AGL_Image/5_1_x86_Emulation_and_Hardware.md @@ -18,7 +18,7 @@ using the `aglsetup.sh` script. If you are building the AGL demo image for emulation, you need to specify some specific options when you run the script: -**Qt based IVI demo :** +**Sample Qt based IVI demo :** ```sh $ source meta-agl/scripts/aglsetup.sh -f -m qemux86-64 -b qemux86-64 agl-demo agl-devel @@ -28,7 +28,7 @@ $ echo 'SSTATE_DIR = "$AGL_TOP/sstate-cache/"' >> $AGL_TOP/site.conf $ ln -sf $AGL_TOP/site.conf conf/ ``` -**HTML5 based IVI demo :** +**Sample HTML5 based IVI demo :** ```sh $ source meta-agl/scripts/aglsetup.sh -f -m qemux86-64 -b qemux86-64 agl-demo agl-devel agl-profile-graphical-html5 @@ -38,6 +38,26 @@ $ echo 'SSTATE_DIR = "$AGL_TOP/sstate-cache/"' >> $AGL_TOP/site.conf $ ln -sf $AGL_TOP/site.conf conf/ ``` +**IVI-EG Flutter based demo :** + +```sh +$ source meta-agl/scripts/aglsetup.sh -f -m qemux86-64 -b qemux86-64 agl-flutter agl-devel +$ echo '# reuse download directories' >> $AGL_TOP/site.conf +$ echo 'DL_DIR = "$HOME/downloads/"' >> $AGL_TOP/site.conf +$ echo 'SSTATE_DIR = "$AGL_TOP/sstate-cache/"' >> $AGL_TOP/site.conf +$ ln -sf $AGL_TOP/site.conf conf/ +``` + +**IC-EG container image :** +```sh +### TBD +``` + +**Virt-EG demo image :** +```sh +### TBD +``` + The "-m" option specifies the "qemux86-64" machine. The list of AGL features used with script are appropriate for development of the AGL demo image suited for either QEMU or VirtualBox. @@ -50,7 +70,7 @@ Start the build using the `bitbake` command. CPU and and Internet connection speeds. The build also takes approximately 100G-bytes of free disk space. -**Qt based IVI demo :** +**Sample Qt based IVI demo :** The target is `agl-demo-platform`. ```sh @@ -65,7 +85,7 @@ By default, the build process puts the resulting image in the Build Directory an $ export IMAGE_NAME=agl-demo-platform-qemux86-64.vmdk.xz ``` -**HTML5 based IVI demo :** +**Sample HTML5 based IVI demo :** The target is `agl-demo-platform-html5`. ```sh @@ -80,10 +100,29 @@ By default, the build process puts the resulting image in the Build Directory an $ export IMAGE_NAME=agl-demo-platform-html5-qemux86-64.vmdk.xz ``` +**IVI-EG Flutter based demo :** +The target is `agl-image-flutter`. + +```sh +$ time bitbake agl-image-flutter +``` + +**IC-EG container image :** +```sh +# TBD +``` + +**Virt-EG demo image :** +```sh +# TBD +``` + ## 3. Deploying the AGL Demo Image Deploying the image consists of decompressing the image and then booting it using either QEMU, VirtualBox or physical system. +The examples below are usually for the 'agl-demo-platform' target. +Please adapt accordingly to your target image. **3.1 QEMU** diff --git a/docs/3_Developer_Guides/0_FIXME.md b/docs/3_Developer_Guides/0_FIXME.md new file mode 100644 index 0000000..e69de29 diff --git a/docs/3_Developer_Guides/1_Application_Framework/0_Introduction.md b/docs/3_Developer_Guides/1_Application_Framework/0_Introduction.md deleted file mode 100644 index efc31ee..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/0_Introduction.md +++ /dev/null @@ -1,261 +0,0 @@ ---- -title: Introduction ---- - -## Foreword - -This document describes what we intend to do. -It may happen that our current implementation and the content of this document differ. - -In case of differences, it is assumed that this document is right and the implementation is wrong. - -## Introduction - -During the first works in having the security model of Tizen integrated in AGL -(Automotive Grade Linux) distribution, it became quickly obvious that the count -of components specific to Tizen to integrate was huge. - -Here is a minimal list of what was needed: - -- platform/appfw/app-installers -- platform/core/security/cert-svc -- platform/core/appfw/ail -- platform/core/appfw/aul-1 -- platform/core/appfw/libslp-db-util -- platform/core/appfw/pkgmgr-info -- platform/core/appfw/slp-pkgmgr - -But this list isn't complete because many dependencies are hidden. -Those hidden dependencies are including some common libraries but also many -tizen specific sub-components: - -- iniparser -- bundle -- dlog, -- libtzplatform-config -- db-util -- vconf-buxton -- ... - -This is an issue because AGL is not expected to be Tizen. -Taking it would either need to patch it for removing unwanted components or to take all of them. - -However, a careful study of the core components of the security framework -of Tizen showed that their dependencies to Tizen are light (and since some -of our work, there is no more dependency to tizen). -Those components are : - -- **cynara** -- **security-manager** -- **D-Bus aware of cynara** - -Luckily, these core security components of Tizen are provided -by [meta-intel-iot-security][meta-intel], a set of yocto layers. -These layers were created by Intel to isolate Tizen specific security -components from the initial port of Tizen to Yocto. -The 3 layers are providing components for: - -- Implementing Smack LSM -- Implementing Integrity Measurement Architecture -- Implementing Tizen Security Framework - -The figure below shows the history of these layers. - -![Security_model_history](./images/Security_model_history.svg) - -We took the decision to use these security layers that provide the -basis of the Tizen security, the security framework. - -For the components of the application framework, built top of -the security framework, instead of pulling the huge set of packages -from Tizen, we decided to refit it by developing a tiny set of -components that would implement the same behaviour but without all -the dependencies and with minor architectural improvements for AGL. - -These components are : - -- **afm-system-daemon** -- **afm-user-daemon** - -They provides infrastructure for installing, uninstalling, -launching, terminating, pausing and resuming applications in -a multi user secure environment. - -A third component exists in the framework, the binder **afb-daemon**. -The binder provides the easiest way to provide secured API for -any tier. -Currently, the use of the binder is not absolutely mandatory. - -This documentation explains the framework created by IoT.bzh -by rewriting the Tizen Application Framework. -Be aware of the previous foreword. - -## Overview - -The figure below shows the major components of the framework -and their interactions going through the following scenario: - -- APPLICATION installs an other application and then launch it. - ![AppFW-APP_install_sequences](./images/AppFW-APP_install_sequences.svg) - -Let follow the sequence of calls: - -1. APPLICATION calls its **binder** to install the OTHER application. - -1. The binding **afm-main-binding** of the **binder** calls, through - **D-Bus** system, the system daemon to install the OTHER application. - -1. The system **D-Bus** checks wether APPLICATION has the permission - or not to install applications by calling **CYNARA**. - -1. The system **D-Bus** transmits the request to **afm-system-daemon**. - - **afm-system-daemon** checks the application to install, its - signatures and rights and install it. - -1. **afm-system-daemon** calls **SECURITY-MANAGER** for fulfilling - security context of the installed application. - -1. **SECURITY-MANAGER** calls **CYNARA** to install initial permissions - for the application. - -1. APPLICATION call its binder to start the nearly installed OTHER application. - -1. The binding **afm-main-binding** of the **binder** calls, through - **D-Bus** session, the user daemon to launch the OTHER application. - -1. The session **D-Bus** checks wether APPLICATION has the permission - or not to start an application by calling **CYNARA**. - -1. The session **D-Bus** transmits the request to **afm-user-daemon**. - -1. **afm-user-daemon** checks wether APPLICATION has the permission - or not to start the OTHER application **CYNARA**. - -1. **afm-user-daemon** uses **SECURITY-MANAGER** features to set - the security context for the OTHER application. - -1. **afm-user-daemon** launches the OTHER application. - -This scenario does not cover all the features of the frameworks. -Shortly because details will be revealed in the next chapters, -the components are: - -- ***SECURITY-MANAGER***: in charge of setting Smack contexts and rules, - of setting groups, and, of creating initial content of *CYNARA* rules - for applications. - -- ***CYNARA***: in charge of handling API access permissions by users and by - applications. - -- ***D-Bus***: in charge of checking security of messaging. The usual D-Bus - security rules are enhanced by *CYNARA* checking rules. - -- ***afm-system-daemon***: in charge of installing and uninstalling applications. - -- ***afm-user-daemon***: in charge of listing applications, querying application details, - starting, terminating, pausing, resuming applications and their instances - for a given user context. - -- ***afb-binder***: in charge of serving resources and features through an - HTTP interface. - -- ***afm-main-binding***: This binding allows applications to use the API - of the AGL framework. - -## Links between the "Security framework" and the "Application framework" - -The security framework refers to the security model used to ensure -security and to the tools that are provided for implementing that model. - -The security model refers to how DAC (Discretionary Access Control), -MAC (Mandatory Access Control) and Capabilities are used by the system -to ensure security and privacy. -It also includes features of reporting using audit features and by managing -logs and alerts. - -The application framework manages the applications: - -- installing -- uninstalling -- starting -- pausing -- listing -- ... - -The application framework uses the security model/framework -to ensure the security and the privacy of the applications that -it manages. - -The application framework must be compliant with the underlying -security model/framework. -But it should hide it to the applications. - -## The security framework - -The implemented security model is the security model of Tizen 3. -This model is described [here][tizen-secu-3]. - -The security framework then comes from Tizen 3 but through -the [meta-intel]. -It includes: - -- **Security-Manager** -- **Cynara** -- **D-Bus** compliant to Cynara. - -Two patches are applied to the security-manager. -The goal of these patches is to remove specific dependencies with Tizen packages that are not needed by AGL. -None of these patches adds or removes any behaviour. - -**In theory, the security framework/model is an implementation details -that should not impact the layers above the application framework**. - -The security framework of Tizen provides "nice lad" a valuable component to -scan log files and analyse auditing. -This component is still in development. - -## The application framework - -The application framework on top of the security framework -provides the components to install and uninstall applications -and to run it in a secured environment. - -The goal is to manage applications and to hide the details of -the security framework to the applications. - -For the reasons explained in introduction, we did not used the -application framework of Tizen as is but used an adaptation of it. - -The basis is kept identical: - -- The applications are distributed in a digitally signed container that must - match the specifications of widgets (web applications). - -This is described by the technical recommendations [widgets] and -[widgets-digsig] of the W3 consortium. - -This model allows: - -- The distribution of HTML, QML and binary applications. -- The management of signatures of the widget packages. - -This basis is not meant as being rigid and it can be extended in the -future to include for example incremental delivery. - -[meta-intel]: https://github.com/01org/meta-intel-iot-security "A collection of layers providing security technologies" -[widgets]: http://www.w3.org/TR/widgets "Packaged Web Apps" -[widgets-digsig]: http://www.w3.org/TR/widgets-digsig "XML Digital Signatures for Widgets" -[libxml2]: http://xmlsoft.org/html/index.html "libxml2" -[openssl]: https://www.openssl.org "OpenSSL" -[xmlsec]: https://www.aleksey.com/xmlsec "XMLSec" -[json-c]: https://github.com/json-c/json-c "JSON-c" -[d-bus]: http://www.freedesktop.org/wiki/Software/dbus "D-Bus" -[libzip]: http://www.nih.at/libzip "libzip" -[cmake]: https://cmake.org "CMake" -[security-manager]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Security_Manager "Security-Manager" -[app-manifest]: http://www.w3.org/TR/appmanifest "Web App Manifest" -[tizen-security]: https://wiki.tizen.org/wiki/Security "Tizen security home page" -[tizen-secu-3]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Overview "Tizen 3 security overview" -[AppFW-APP_install_sequences]: images/AppFW-APP_install_sequences.svg -[Security_model_history]: images/Security_model_history.svg \ No newline at end of file diff --git a/docs/3_Developer_Guides/1_Application_Framework/1_afm-daemons.md b/docs/3_Developer_Guides/1_Application_Framework/1_afm-daemons.md deleted file mode 100644 index b8eb21b..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/1_afm-daemons.md +++ /dev/null @@ -1,649 +0,0 @@ ---- -title: The afm daemons ---- - -## Foreword - -This document describes application framework daemons -FCS (Fully Conform to Specification) implementation is still under development. -It may happen that current implementation somehow diverges with specifications. - -## Introduction - -Daemons ***afm-user-daemon*** and ***afm-system-daemon*** handle applications -life. -Understand that they will manage operations like: - -- ***installation*** -- ***uninstallation*** -- ***running*** -- ***suspend*** -- ***inventory*** -- ... - -In addition, they ensure that operations use the security framework as needed -and that applications are executed in the correct context. - -***D-Bus*** is in charge of transmitting orders to the appropriate daemon -depending upon ***D-Bus*** destination. - -The figure below summarizes the situation of both **afm-system-daemon** and -**afm-user-daemon** in the system. - -![afm-daemons][afm-daemons] - -## The D-Bus interface - -### Overview of the dbus interface - -The ***afm daemons*** takes theirs orders from the session instance -of D-Bus. -The use of D-Bus is great because it allows to implement -discovery and signaling. - -The dbus session is by default addressed by environment -variable *DBUS_SESSION_BUS_ADDRESS*. Using **systemd** -variable *DBUS_SESSION_BUS_ADDRESS* is automatically set for -user sessions. - -They are listening with the destination name ***org.AGL.afm.[user|system]*** -at the object of path ***/org/AGL/afm/[user|system]*** on the interface -***org.AGL.afm.[user|system]*** for the below detailed members for the -***afm-system-daemon***: - -- ***install*** -- ***uninstall*** - -And for ***afm-user-daemon***: - -- ***runnables*** -- ***detail*** -- ***start*** -- ***once*** -- ***terminate*** -- ***pause*** -- ***resume*** -- ***runners*** -- ***state*** -- ***install*** -- ***uninstall*** - -D-Bus is mainly used for signaling and discovery. -Its optimized typed protocol is not used except for transmitting - only one string in both directions. - -The client and the service are using JSON serialization to -exchange data. -Signature of any member of the D-Bus interface is -***string -> string*** for ***JSON -> JSON***. -This is the normal case, if there is an error, current implementation -returns a dbus error that is a string. - -Here are examples using *dbus-send*, here to install an application from a -widget file: - -```bash -dbus-send --session --print-reply \ - --dest=org.AGL.afm.system \ - /org/AGL/afm/system \ - org.AGL.afm.system.install 'string:"/tmp/appli.wgt" -``` - -And here, to query data on installed applications that can be run: - -```bash -dbus-send --session --print-reply \ - --dest=org.AGL.afm.user \ - /org/AGL/afm/user \ - org.AGL.afm.user.runnables string:true -``` - -### The protocol over D-Bus - -On all following sub-chapters we assume that we talk about either -***afm-system-daemon*** or ***afm-user-daemon***. Method and D-Bus parameters -are considered as self-explanatory. - -The D-Bus interface is defined by: - -- **DESTINATION**: org.AGL.afm.[user|system] -- **PATH**: /org/AGL/afm/[user|system] -- **INTERFACE**: org.AGL.afm.[user|system] - -#### Method org.AGL.afm.system.install - -**Description**: Install an application from a widget file. - -When an application with the same *id* and *version* already exists. Outside of -using *force=true* the application is not reinstalled. - -Applications are installed the subdirectories of applications common directory. -If *root* is specified, the application is installed under the -sub-directories of the *root* defined. - -Note that this methods is a simple accessor method of -***org.AGL.afm.system.install*** from ***afm-system-daemon***. - -After the installation and before returning to the sender, -***afm-system-daemon*** sends a signal ***org.AGL.afm.system.changed***. - -**Input**: The *path* of the widget file to install and, optionally, -a flag to *force* reinstallation, and, optionally, a *root* directory. - -Either just a string being the absolute path of the widget file: - -```bash -"/a/path/driving/to/the/widget" -``` - -Or an object: - -```json -{ - "wgt": "/a/path/to/the/widget", - "force": false, - "root": "/a/path/to/the/root" -} -``` - -"wgt" and "root" must be absolute paths. - -**output**: An object with the field "added" being the string for -the id of the added application. - -```json -{"added":"appli@x.y"} -``` - - - -#### Method org.AGL.afm.system.uninstall - -**Description**: Uninstall an application from its id. - -Note that this methods is a simple method accessor of -***org.AGL.afm.system.uninstall*** from ***afm-system-daemon***. - -After the uninstallation and before returning to the sender, -***afm-system-daemon*** sends a signal ***org.AGL.afm.system.changed***. - -**Input**: the *id* of the application and optionally the application *root* path. - -Either a string: - -```bash -"appli@x.y" -``` - -Or an object: - -```json -{ - "id": "appli@x.y", - "root": "/a/path/to/the/root" -} -``` - -**output**: the value 'true'. - - - -#### Method org.AGL.afm.user.detail - -**Description**: Get details about an application from its id. - -**Input**: the id of the application as below. - -Either just a string: - -```bash -"appli@x.y" -``` - -Or an object having the field "id" of type string: - -```json -{"id":"appli@x.y"} -``` - -**Output**: A JSON object describing the application containing -the fields described below. - -```json -{ - "id": string, the application id (id@version) - "version": string, the version of the application - "width": integer, requested width of the application - "height": integer, requested height of the application - "name": string, the name of the application - "description": string, the description of the application - "shortname": string, the short name of the application - "author": string, the author of the application -} -``` - - - -#### Method org.AGL.afm.user.runnables - -**Description**: Get the list of applications that can be run. - -**Input**: any valid json entry, can be anything except null. - -**output**: An array of description of the runnable applications. -Each item of the array contains an object containing the detail of -an application as described above for the method -*org.AGL.afm.user.detail*. - - - -#### Method org.AGL.afm.user.install - -**Description**: Install an application from its widget file. - -If an application of the same *id* and *version* exists, it is not -reinstalled except when *force=true*. - -Applications are installed in the subdirectories of the common directory -reserved for applications. -If *root* is specified, the application is installed under -sub-directories of defined *root*. - -Note that this methods is a simple accessor to the method -***org.AGL.afm.system.install*** of ***afm-system-daemon***. - -After the installation and before returning to the sender, -***afm-user-daemon*** sends the signal ***org.AGL.afm.user.changed***. - -**Input**: The *path* of widget file to be installed. Optionally, -a flag to *force* reinstallation and/or a *root* directory. - -Simple form a simple string containing the absolute widget path: - -```bash -"/a/path/driving/to/the/widget" -``` - -Or an object: - -```json -{ - "wgt": "/a/path/to/the/widget", - "force": false, - "root": "/a/path/to/the/root" -} -``` - -***wgt*** and ***root*** MUST be absolute paths. - -**output**: An object containing field "added" to use as application ID. - -```json -{"added":"appli@x.y"} -``` - - - -#### Method org.AGL.afm.user.uninstall - -**Description**: Uninstall an application from its id. - -Note that this methods is a simple accessor to -***org.AGL.afm.system.uninstall*** method from ***afm-system-daemon***. - -After the uninstallation and before returning to the sender, -***afm-user-daemon*** sends the signal ***org.AGL.afm.user.changed***. - -**Input**: the *id* of the application and, optionally, the path to -application *root*. - -Either a string: - -```bash -"appli@x.y" -``` - -Or an object: - -```json -{ - "id": "appli@x.y", - "root": "/a/path/to/the/root" -} -``` - -**output**: the value 'true'. - - - -#### Method org.AGL.afm.user.start - -**Description**: - -**Input**: the *id* of the application and, optionally, the -start *mode* as below. - -Either just a string: - -```bash -"appli@x.y" -``` - -Or an object containing field "id" of type string and -optionally a field mode: - -```json -{"id":"appli@x.y","mode":"local"} -``` - -The field "mode" is a string equal to either "local" or "remote". - -[Currently the mode is not available in the systemd version] - -**output**: The *runid* of the application launched. *runid* is an integer. - - - -#### Method org.AGL.afm.user.once - -**Description**: - -**Input**: the *id* of the application - -Either just a string: - -```bash -"appli@x.y" -``` - -Or an object containing field "id" of type string. - -```json -{"id":"appli@x.y"} -``` - -**output**: The *state* of the application retrieved or launched. -See *org.AGL.afm.user.state* to get a description of the returned -object. - - - -#### Method org.AGL.afm.user.terminate - -**Description**: Terminates the application attached to *runid*. - -**Input**: The *runid* (an integer) of running instance to terminate. - -**output**: the value 'true'. - - - -#### Method org.AGL.afm.user.stop - -Obsolete since 8th November 2016 (2016/11/08). -Kept for compatibility. - -Use **org.AGL.afm.user.pause** instead. - - - -#### Method org.AGL.afm.user.continue - -Obsolete since 8th November 2016 (2016/11/08). -Kept for compatibility. - -Use **org.AGL.afm.user.resume** instead. - - - -#### Method org.AGL.afm.user.pause - -[Currently not available in the systemd version] - -**Description**: Pauses the application attached to *runid* until terminate or resume. - -**Input**: The *runid* (integer) of the running instance to pause. - -**output**: the value 'true'. - - - -#### Method org.AGL.afm.user.resume - -[Currently not available in the systemd version] - -**Description**: Resumes the application attached to *runid* previously paused. - -**Input**: The *runid* (integer) of the running instance to resume. - -**output**: the value 'true'. - - - -#### Method org.AGL.afm.user.state - -**Description**: Get information about a running instance of *runid*. - -**Input**: The *runid* (integer) of the running instance inspected. - -**output**: An object describing instance state. -It contains: - -- the runid (integer) -- the pids of the processes as an array starting -- with the group leader -- the id of the running application (string) -- the state of the application (string either: "starting", "running", "paused"). - -Example of returned state: - -```json - { - "runid": 2, - "pids": [ 435, 436 ], - "state": "running", - "id": "appli@x.y" - } -``` - - - -#### Method org.AGL.afm.user.runners - -**Description**: Get the list of currently running instances. - -**Input**: anything. - -**output**: An array of states, one per running instance, as returned by -the method ***org.AGL.afm.user.state***. - -## Starting **afm daemons** - -***afm-system-daemon*** and ***afm-user-daemon*** are launched as systemd -services attached to system and user respectively. -Normally, service files are locatedat */lib/systemd/system/afm-system-daemon.service* and -*/usr/lib/systemd/user/afm-user-daemon.service*. - -### ***afm-system-daemon*** options - -The options for launching **afm-system-daemon** are: - -```bash - -r - --root directory - - Set the root application directory. - - Note that the default root directory is defined - to be /usr/share/afm/applications (may change). - - -d - --daemon - - Daemonizes the process. It is not needed by systemd. - - -q - --quiet - - Reduces the verbosity (can be repeated). - - -v - --verbose - - Increases the verbosity (can be repeated). - - -h - --help - - Prints a short help. -``` - -### ***afm-user-daemon*** options - -The options for launching **afm-user-daemon** are: - -```bash - -a - --application directory - - [Currently not available in the systemd version] - - Includes the given application directory to - the database base of applications. - - Can be repeated. - - -r - --root directory - - [Currently not available in the systemd version] - - Includes root application directory or directories when - passing multiple rootdir to - applications database. - - Note that default root directory for - applications is always added. In current version - /usr/share/afm/applications is used as default. - - -m - --mode (local|remote) - - [Currently not available in the systemd version] - - Set the default launch mode. - The default value is 'local' - - -d - --daemon - - Daemonizes the process. It is not needed by systemd. - - -q - --quiet - - Reduces the verbosity (can be repeated). - - -v - --verbose - - Increases the verbosity (can be repeated). - - -h - --help - - Prints a short help. -``` - -## Tasks of **afm-user-daemon** - -### Maintaining list of applications - -At start **afm-user-daemon** scans the directories containing -applications and load in memory a list of available applications -accessible by current user. - -When **afm-system-daemon** installs or removes an application. -On success it sends the signal *org.AGL.afm.system.changed*. -When receiving such a signal, **afm-user-daemon** rebuilds its -applications list. - -**afm-user-daemon** provides the data it collects about -applications to its clients. -Clients may either request the full list -of available applications or a more specific information about a -given application. - -### Launching application - -**afm-user-daemon** launches application by using systemd. -Systemd builds a secure environment for the application -before starting it. - -Once launched, running instances of application receive -a runid that identify them. -To make interface with systemd evident, the pid is the runid. - -### Managing instances of running applications - -**afm-user-daemon** manages the list of applications -that it launched. - -When owning the right permissions, a client can get the list -of running instances and details about a specific -running instance. -It can also terminate a given application. - -### Installing and uninstalling applications - -If the client own the right permissions, -**afm-user-daemon** delegates that task -to **afm-system-daemon**. - -## Using ***afm-util*** - -The command line tool ***afm-util*** uses dbus-send to send -orders to **afm-user-daemon**. -This small scripts allows to send command to ***afm-user-daemon*** either -interactively at shell prompt or scriptically. - -The syntax is simple: - -- it accept a command and when requires attached arguments. - -Here is the summary of ***afm-util***: - -- **afm-util runnables **: - list the runnable widgets installed - -- **afm-util install wgt **: - install the wgt file - -- **afm-util uninstall id **: - remove the installed widget of id - -- **afm-util detail id **: - print detail about the installed widget of id - -- **afm-util runners **: - list the running instance - -- **afm-util start id **: - start an instance of the widget of id - -- **afm-util once id **: - run once an instance of the widget of id - -- **afm-util terminate rid **: - terminate the running instance rid - -- **afm-util state rid **: - get status of the running instance rid - -Here is how to list applications using ***afm-util***: - -```bash - afm-util runnables -``` - -[afm-daemons]: images/afm-daemons.svg diff --git a/docs/3_Developer_Guides/1_Application_Framework/2_widgets.md b/docs/3_Developer_Guides/1_Application_Framework/2_widgets.md deleted file mode 100644 index 07edc52..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/2_widgets.md +++ /dev/null @@ -1,11 +0,0 @@ ---- -title: Widgets ---- - -# The widgets - -The widgets are described by the W3C's technical recommendations -[Packaged Web Apps (Widgets)](http://www.w3.org/TR/widgets) and [XML Digital Signatures for Widgets](http://www.w3.org/TR/widgets-digsig) - -In summary, **widgets are ZIP files that can be signed and -whose content is described by the file **. \ No newline at end of file diff --git a/docs/3_Developer_Guides/1_Application_Framework/3_widgets_overview.md b/docs/3_Developer_Guides/1_Application_Framework/3_widgets_overview.md deleted file mode 100644 index 28dbc60..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/3_widgets_overview.md +++ /dev/null @@ -1,158 +0,0 @@ ---- -title: Overview of widgets ---- - - -# Tools for managing widgets - -This project includes tools for managing widgets. -These tools are: - -- ***wgtpkg-info***: command line tool to display - informations about a widget file. - -- ***wgtpkg-install***: command line tool to - install a widget file. - -- ***wgtpkg-pack***: command line tool to create - a widget file from a widget directory. - -- ***wgtpkg-sign***: command line tool to add a signature - to a widget directory. - -For all these commands, a tiny help is available with -options **-h** or **--help**. - -There is no tool for unpacking a widget. -For doing such operation, you can use the command **unzip**. - -To list the files of a widget: - -```bash -unzip -l WIDGET -``` - -To extract a widget in some directory: - -```bash -unzip WIDGET -d DIRECTORY -``` - -*Note: that DIRECTORY will be created if needed*. - -## Getting data about a widget file - -The command **wgtpkg-info** opens a widget file, reads its **config.xml** -file and displays its content in a human readable way. - -## Signing and packing widget - -### Signing - -To sign a widget, you need a private key and its certificate. - -The tool **wgtpkg-sign** creates or replace a signature file in -the directory of the widget BEFORE its packaging. - -There are two types of signature files: author and distributor. - -Example 1: add an author signature - -```bash -wgtpkg-sign -a -k me.key.pem -c me.cert.pem DIRECTORY -``` - -Example 2: add a distributor signature - -```bash -wgtpkg-sign -k authority.key.pem -c authority.cert.pem DIRECTORY -``` - -### Packing - -This operation can be done using the command **zip** but -we provide the tool **wgtpkg-pack** that may add checking. - -Example: - -```bash -wgtpkg-pack DIRECTORY -o file.wgt -``` - -## Writing a widget - -### App directory organization - -There are few directories that are by default used in the binder. At the root -directory of the widget folder, here are the directories that could be used: - -- *lib* : default directory where lies external libraries needed for - the binding. Binding could be stored here too or in another directory of your - choice. -- *htdocs* : root HTTP directory if binding has web UI. - -### The steps for writing a widget - -1. make your application -2. create its configuration file **config.xml** -3. sign it -4. pack it - -Fairly easy, no? - -## Organization of directory of applications - -### Directory where are stored applications - -Applications can be installed in different places: - -- the system itself, extension device. - -On a phone application are typically installed on the sd card. - -This translates to: - -- /var/local/lib/afm/applications - -From here this path is referenced as: "APPDIR". - -The main path for applications is: APPDIR/PKGID/VER. - -Where: - -- APPDIR is as defined above -- PKGID is a directory whose name is the package identifier -- VER is the version of the package MAJOR.MINOR - -This organization has the advantage to allow several versions -to leave together. -This is needed for some good reasons (rolling back) and also for less good reasons (user habits). - -### Identity of installed files - -All files are installed as user "afm" and group "afm". -All files have rw(x) for user and r-(x) for group and others. - -This allows every user to read every file. - -### Labeling the directories of applications - -The data of a user are in its directory and are labelled by the security-manager using the application labels. - -[widgets]: http://www.w3.org/TR/widgets "Packaged Web Apps" -[widgets-digsig]: http://www.w3.org/TR/widgets-digsig "XML Digital Signatures for Widgets" -[app-manifest]: http://www.w3.org/TR/appmanifest "Web App Manifest" -[meta-intel]: https://github.com/01org/meta-intel-iot-security "A collection of layers providing security technologies" -[widgets]: http://www.w3.org/TR/widgets "Packaged Web Apps" -[widgets-digsig]: http://www.w3.org/TR/widgets-digsig "XML Digital Signatures for Widgets" -[libxml2]: http://xmlsoft.org/html/index.html "libxml2" -[openssl]: https://www.openssl.org "OpenSSL" -[xmlsec]: https://www.aleksey.com/xmlsec "XMLSec" -[json-c]: https://github.com/json-c/json-c "JSON-c" -[d-bus]: http://www.freedesktop.org/wiki/Software/dbus "D-Bus" -[libzip]: http://www.nih.at/libzip "libzip" -[cmake]: https://cmake.org "CMake" -[security-manager]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Security_Manager "Security-Manager" -[app-manifest]: http://www.w3.org/TR/appmanifest "Web App Manifest" -[tizen-security]: https://wiki.tizen.org/wiki/Security "Tizen security home page" -[tizen-secu-3]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Overview "Tizen 3 security overview" diff --git a/docs/3_Developer_Guides/1_Application_Framework/4_Widget_configuration_file.md b/docs/3_Developer_Guides/1_Application_Framework/4_Widget_configuration_file.md deleted file mode 100644 index f7acb23..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/4_Widget_configuration_file.md +++ /dev/null @@ -1,589 +0,0 @@ ---- -title: Widget configuration file ---- - -# Configuration file - config.xml - -The widgets are described by the W3C's technical recommendations -[Packaged Web Apps (Widgets)][widgets] and [XML Digital Signatures for -Widgets][widgets-digsig] -that specifies the configuration file **config.xml**. - -## Overview - -The file **config.xml** describes important data of the application -to the framework: - -- the unique identifier of the application -- the name of the application -- the type of the application -- the icon of the application -- the permissions linked to the application -- the services and dependencies of the application - -The file MUST be at the root of the widget and MUST be case sensitively name -***config.xml***. - -The file **config.xml** is a XML file described by the document -[widgets]. - -Here is the example of the config file for the QML application SmartHome. - -```xml - - - SmartHome - - - This is the Smarthome QML demo application. It shows some user interfaces for controlling an -automated house. The user interface is completely done with QML. - Qt team - GPL - -``` - -The most important items are: - -- ****: gives the id of the widget. It must be unique. - -- ****: gives the version of the widget - -- ****: gives a path to the icon of the application - (can be repeated with different sizes) - -- ****: this indicates the entry point and its type. - -## Standard elements of "config.xml" - -### The element widget - -#### the attribute id of widget - -The attribute *id* is mandatory (for version 2.x, blowfish) and must be unique. - -Values for *id* are any non empty string containing only latin letters, -arabic digits, and the three characters '.' (dot), '-' (dash) and -'\_' (underscore). - -Authors can use a mnemonic id or can pick a unique id using -command **uuid** or **uuidgen**. - -### the attribute version of widget - -The attribute *version* is mandatory (for version 2.x, blowfish). - -Values for *version* are any non empty string containing only latin letters, -arabic digits, and the three characters '.' (dot), '-' (dash) and -'\_' (underscore). - -Version values are dot separated fields MAJOR.MINOR.REVISION. -Such version would preferably follow guidelines of -[semantic versioning][semantic-version]. - -### The element content - -The element *content* is mandatory (for version 2.x, blowfish) and must designate a file -(subject to localization) with its attribute *src*. - -The content designed depends on its type. See below for the known types. - -### The element icon - -The element *icon* is mandatory (for version 2.x, blowfish) and must -be unique. It must designate an image file with its attribute *src*. - -## AGL features - -The AGL framework uses the feature tag for specifying security and binding -requirement of the widget. - -Since the migration of the framework to leverage systemd power, -the features are of important use to: - -- declare more than just an application -- declare the expected dependencies -- declare the expected permissions -- declare the exported apis - -The specification of [widgets][widgets] is intended to describe -only one application. -In the present case, we expect to describe more than just an application. -For example, a publisher could provide a widget containing a service, -an application for tuning that service, an application that -leverage the service. -Here, the term of service means a background application that -runs without IHM and whose public api can be accessed by other -applications. - -So the features are used to describe each of the possible -units of widgets. -The "standard" unit in the meaning of [widgets][widgets] -is called the "main" unit. - -### required-api: feature name="urn:AGL:widget:required-api" - -List of the api required by the widget. - -Each required api must be explicit using a `` entry. - -Example: - -```xml - - - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json -"required-api": [ - { "name": "gps", "value": "auto" }, - { "name": "afm-main", "value": "link" } - ] -``` - -#### required-api: param name="#target" - -OPTIONAL - -Declares the name of the unit requiring the listed apis. -Only one instance of the param "#target" is allowed. -When there is not instance of this param, it behave as if -the target main was specified. - -#### required-api: param name=[required api name] - -The name is the name of the required API. - -The value describes how to connect to the required api. -It is either: - -- local: OBSOLETE SINCE FF (AGL6), PROVIDED FOR COMPATIBILITY - Use the feature **urn:AGL:widget:required-binding** instead. - The binding is a local shared object. - In that case, the name is the relative path of the - shared object to be loaded. - -- auto: - The framework set automatically the kind of - the connection to the API - -- ws: - The framework connect using internal websockets - -- dbus: [OBSOLETE, shouldn't be used currently] - The framework connect using internal dbus - -- tcp: - In that case, the name is the URI to access the service. - The framework connect using a URI of type - HOST:PORT/API - API gives the name of the imported api. - -- cloud: [PROPOSAL - NOT IMPLEMENTED] - The framework connect externally using websock. - In that case, the name includes data to access the service. - Example: `` - -### required-binding: feature name="urn:AGL:widget:required-binding" - -List of the bindings required by the widget. - -Note: Since AGL 6 (FF - Funky Flounder), -the binder implements bindings version 3 that allow the declaration -of 0, 1 or more APIs by one binding. In other words, the equivalency -one binding = one API is lost. At the same time the framework added -the ability to use bindings exported by other widgets. - -Each required binding must be explicit using a `` entry. - -Example: - -```xml - - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json -"required-binding": [ - { "name": "libexec/binding-gps.so", "value": "local" }, - { "name": "extra", "value": "extern" } - ] -``` - -#### required-binding: param name=[name or path] - -The name or the path of the required BINDING. - -The value describes how to connect to the required binding. -It is either: - -- local: - The binding is a local shared object. - In that case, the name is the relative path of the - shared object to be loaded. - -- extern: - The binding is external. The name is the exported binding name. - See provided-binding. - -### provided-binding: feature name="urn:AGL:widget:provided-binding" - -This feature allows to export a binding to other binders. -The bindings whose relative name is given as value is exported to -other binders under the given name. - -Each provided binding must be explicit using a `` entry. - -Example: - -```xml - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json -"provided-binding": [ - { "name": "extra", "value": "export/binding-gps.so" } - ] -``` - -#### provided-binding: param name=[exported name] - -Exports a local binding to other applications. - -The value must contain the path to the exported binding. - -### required-permission: feature name="urn:AGL:widget:required-permission" - -List of the permissions required by the unit. - -Each required permission must be explicit using a `` entry. - -Example: - -```xml - - - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json -"required-permission":{ - "urn:AGL:permission:real-time":{ - "name":"urn:AGL:permission:real-time", - "value":"required" - }, - "urn:AGL:permission:syscall:*":{ - "name":"urn:AGL:permission:syscall:*", - "value":"required" - } -} -``` - -#### required-permission: param name="#target" - -OPTIONAL - -Declares the name of the unit requiring the listed permissions. -Only one instance of the param "#target" is allowed. -When there is not instance of this param, it behave as if -the target main was specified. - -#### required-permission: param name=[required permission name] - -The value is either: - -- required: the permission is mandatorily needed except if the feature - isn't required (required="false") and in that case it is optional. -- optional: the permission is optional - -### provided-unit: feature name="urn:AGL:widget:provided-unit" - -This feature is made for declaring new units -for the widget. -Using this feature, a software publisher -can provide more than one application in the same widget. - -Example: - -```xml - - - - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json - { - "#target":"geoloc", - "description":"binding of name geoloc", - "content":{ - "src":"index.html", - "type":"application\/vnd.agl.service" - }, - ... - } -``` - -#### provided-unit: param name="#target" - -REQUIRED - -Declares the name of the unit. The default unit, the unit -of the main of the widget, has the name "main". -The value given here must be unique within the widget file. -It will be used in other places of the widget config.xml file to -designate the unit. - -Only one instance of the param "#target" is allowed. -The value can't be "main". - -#### provided-unit: param name="content.type" - -REQUIRED - -The mimetype of the provided unit. - -#### provided-unit: param name="content.src" - -A path to the source - -#### other parameters - -The items that can be set for the main unit -can also be set using the params if needed. - -- description -- name.content -- name.short -- ... - -### provided-api: feature name="urn:AGL:widget:provided-api" - -Use this feature for exporting one or more API of a unit -to other widgets of the platform. - -This feature is an important feature of the framework. - -Example: - -```xml - - - - - -``` - -This will be *virtually* translated for mustaches to the JSON - -```json - "provided-api":[ - { - "name":"geoloc", - "value":"auto" - }, - { - "name":"moonloc", - "value":"auto" - } - ], -``` - -#### provided-api: param name="#target" - -OPTIONAL - -Declares the name of the unit exporting the listed apis. -Only one instance of the param "#target" is allowed. -When there is not instance of this param, it behave as if -the target main was specified. - -#### provided-api: param name=[name of exported api] - -The name give the name of the api that is exported. - -The value is one of the following values: - -- ws: - export the api using UNIX websocket - -- dbus: [OBSOLETE, shouldn't be used currently] - export the API using dbus - -- auto: - export the api using the default method(s). - -- tcp: - In that case, the name is the URI used for exposing the service. - The URI is of type - HOST:PORT/API - API gives the name of the exported api. - -### file-properties: feature name="urn:AGL:widget:file-properties" - -Use this feature for setting properties to files of the widget. -At this time, this feature only allows to set executable flag -for making companion program executable explicitly. - -Example: - -```xml - - - - -``` - -#### file-properties: param name="path" - -The name is the relative path of the file whose property -must be set. - -The value must be "executable" to make the file executable. - -## Known content types - -The configuration file ***/etc/afm/afm-unit.conf*** defines -how to create systemd units for widgets. - -Known types for the type of content are: - -- ***text/html***: - HTML application, - content.src designates the home page of the application - -- ***application/vnd.agl.native*** - AGL compatible native, - content.src designates the relative path of the binary. - -- ***application/vnd.agl.service***: - AGL service, content.src is not used. - -- ***application/x-executable***: - Native application, - content.src designates the relative path of the binary. - For such application, only security setup is made. - -Adding more types is easy, it just need to edit the configuration -file ***afm-unit.conf***. - -### Older content type currently not supported at the moment - -This types were defined previously when the framework was not -leveraging systemd. -The transition to systemd let these types out at the moment. - -- ***application/vnd.agl.url*** -- ***text/vnd.qt.qml***, ***application/vnd.agl.qml*** -- ***application/vnd.agl.qml.hybrid*** -- ***application/vnd.agl.html.hybrid*** - -## The configuration file afm-unit.conf - -The integration of the framework with systemd -mainly consists of creating the systemd unit -files corresponding to the need and requirements -of the installed widgets. - -This configuration file named `afm-unit.conf` installed -on the system with the path `/etc/afm/afm-unit.conf` -describes how to generate all units from the *config.xml* -configuration files of widgets. -The description uses an extended version of the templating -formalism of [mustache][] to describes all the units. - -Let present how it works using the following diagram that -describes graphically the workflow of creating the unit -files for systemd `afm-unit.conf` from the configuration -file of the widget `config.xml`: - -![make-units](pictures/make-units.svg) - -In a first step, and because [mustache][] is intended -to work on JSON representations, the configuration file is -translated to an internal JSON representation. -This representation is shown along the examples of the documentation -of the config files of widgets. - -In a second step, the mustache template `afm-unit.conf` -is instantiated using the C library [mustach][] that follows -the rules of [mustache][mustache] and with all its available -extensions: - -- use of colon (:) for explicit substitution -- test of values with = or =! - -In a third step, the result of instantiating `afm-unit.conf` -for the widget is split in units. -To achieve that goal, the lines containing specific directives are searched. -Any directive occupy one full line. -The directives are: - -- %nl - Produce an empty line at the end -- %begin systemd-unit -- %end systemd-unit - Delimit the produced unit, its begin and its end -- %systemd-unit user -- %systemd-unit system - Tells the kind of unit (user/system) -- %systemd-unit service NAME -- %systemd-unit socket NAME - Gives the name and type (service or socket) of the unit. - The extension is automatically computed from the type - and must not be set in the name. -- %systemd-unit wanted-by NAME - Tells to install a link to the unit in the wants of NAME - -Then the computed units are then written to the filesystem -and inserted in systemd. - -The generated unit files will contain variables for internal -use of the framework. -These variables are starting with `X-AFM-`. -The variables starting with `X-AFM-` but not with `X-AFM--` are -the public variables. -These variables will be returned by the -framework as the details of an application (see **afm-util detail ...**). - -Variables starting with `X-AFM--` are private to the framework. -By example, the variable `X-AFM--http-port` is used to -record the allocated port for applications. - -[mustach]: https://gitlab.com/jobol/mustach "basic C implementation of mustache" -[mustache]: http://mustache.github.io/mustache.5.html "mustache - Logic-less templates" -[widgets]: http://www.w3.org/TR/widgets "Packaged Web Apps" -[widgets-digsig]: http://www.w3.org/TR/widgets-digsig "XML Digital Signatures for Widgets" -[libxml2]: http://xmlsoft.org/html/index.html "libxml2" -[app-manifest]: http://www.w3.org/TR/appmanifest "Web App Manifest" -[meta-intel]: https://github.com/01org/meta-intel-iot-security "A collection of layers providing security technologies" -[openssl]: https://www.openssl.org "OpenSSL" -[xmlsec]: https://www.aleksey.com/xmlsec "XMLSec" -[json-c]: https://github.com/json-c/json-c "JSON-c" -[d-bus]: http://www.freedesktop.org/wiki/Software/dbus "D-Bus" -[libzip]: http://www.nih.at/libzip "libzip" -[cmake]: https://cmake.org "CMake" -[security-manager]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Security_Manager "Security-Manager" -[tizen-security]: https://wiki.tizen.org/wiki/Security "Tizen security home page" -[tizen-secu-3]: https://wiki.tizen.org/wiki/Security/Tizen_3.X_Overview "Tizen 3 security overview" -[semantic-version]: http://semver.org/ "Semantic versioning" diff --git a/docs/3_Developer_Guides/1_Application_Framework/5_Permissions.md b/docs/3_Developer_Guides/1_Application_Framework/5_Permissions.md deleted file mode 100644 index 8b149c0..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/5_Permissions.md +++ /dev/null @@ -1,131 +0,0 @@ ---- -title: Permissions ---- - -## Permission's names - -The proposal here is to specify a naming scheme for permissions -that allows the system to be as stateless as possible. -The current specification includes in the naming of permissions either -the name of the bound binding when existing and the level of the -permission itself. -Doing this, there is no real need for the -framework to keep installed permissions in a database. - -The permission names are [URN][URN] of the form: - -```bash - urn:AGL:permission::: -``` - -where "AGL" is the NID (the namespace identifier) dedicated to AGL. -(note: a RFC should be produced to standardize this name space) - -The permission names are made of NSS (the namespace specific string) -starting with "permission:" and followed by colon separated -fields. -The 2 first fields are `` and `` and the remaining -fields are grouped to form the ``. - -```bash - ::= [ ] - - ::= 1* - - ::= | | | - - ::= "-" | "." | "_" | "@" -``` - -The field `` can be made of any valid character for NSS except -the characters colon and star (:*). -This field designates the api providing the permission. -This scheme is used to deduce binding requirements -from permission requirements. -The field `` can be the empty string when the permission -is defined by the AGL system itself. - -[PROPOSAL 1] The field `` if starting with the character "@" represents -a transversal/cross permission not bound to any binding. - -[PROPOSAL 2]The field `` if starting with the 2 characters "@@" -in addition to a permission not bound to any binding, represents a -permission that must be set at installation and that can not be -revoked later. - - ::= 1* - -The field `` is made only of letters in lower case. -The field `` can only take some predefined values: - -- system -- platform -- partner -- tiers -- owner -- public - -The field `` is made of `` separated -by colons. - - ::= 0*(":" ) - -The names at left are hierarchically grouping the -names at right. -This hierarchical behaviour is intended to -be used to request permissions using hierarchical grouping. - -## Permission value - -In some case, it could be worth to add a value to a permission. - -Currently, the framework allows it for permissions linked to -systemd. -But this not currently used. - -Conversely, permissions linked to cynara can't carry data -except in their name. - -Thus to have a simple and cleaner model, it is better to forbid -attachment of value to permission. - -## Example of permissions - -Here is a list of some possible permissions. -These permissions are available the 21th of May 2019. - -- urn:AGL:permission::platform:no-oom - Set OOMScoreAdjust=-500 to keep the out-of-memory - killer away. -- urn:AGL:permission::partner:real-time - Set IOSchedulingClass=realtime to give to the process - realtime scheduling. - Conversely, not having this permission set RestrictRealtime=on - to forbid realtime features. -- urn:AGL:permission::public:display - Adds the group "display" to the list of supplementary groups - of the process. -- urn:AGL:permission::public:syscall:clock - Without this permission SystemCallFilter=~@clock is set to - forfid call to clock. -- urn:AGL:permission::public:no-htdocs - The http directory served is not "htdocs" but "." -- urn:AGL:permission::public:applications:read - Allows to read data of installed applications (and to - access icons). -- urn:AGL:permission::partner:service:no-ws - Forbids services to provide its API through websocket. -- urn:AGL:permission::partner:service:no-dbus - Forbids services to provide its API through D-Bus. -- urn:AGL:permission::system:run-by-default - Starts automatically the application. Example: home-screen. -- urn:AGL:permission::partner:scope-platform - Install the service at the scope of the platform. -- urn:AGL:permission::system:capability:keep-all - Keep all capabilities for the service. Note that implementing - that permission is not mandatory or can be adapted for the given - system. -- - Permission to use D-Bus. - -[URN]: https://tools.ietf.org/rfc/rfc2141.txt "RFC 2141: URN Syntax" diff --git a/docs/3_Developer_Guides/1_Application_Framework/6_Quick-Tutorial.md b/docs/3_Developer_Guides/1_Application_Framework/6_Quick-Tutorial.md deleted file mode 100644 index f031235..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/6_Quick-Tutorial.md +++ /dev/null @@ -1,267 +0,0 @@ ---- -title: Quick Tutorial ---- - -## Introduction - -This document proposes a quick tutorial to demonstrate the major -functionalities of the AGL Application Framework. -For more complete information, please refer to the inline documentation -available in the main git repository: - - - [https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-main] - - [https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-binder] - -For more information on AGL, please visit: -[https://www.automotivelinux.org/] - -## Sample applications - -4 sample applications (.wgt files) are prebuilt and available at the following address: -[https://github.com/iotbzh/afm-widget-examples] - -You can get them by cloning this git repository on your desktop (will be useful later in this tutorial): - -```bash -git clone https://github.com/iotbzh/afm-widget-examples -``` - -## Using the CLI tool - -### Setup Environment - -Connect your AGL target board to the network and copy some sample widgets on it through SSH (set BOARDIP with your board IP address) : - -```bash -cd afm-widget-examples -BOARDIP=1.2.3.4 -scp *.wgt root@$BOARDIP:~/ -``` - -Connect through SSH on the target board and check for Application Framework daemons: - -```bash -$ ssh root@$BOARDIP -root@porter:~# ps -ef|grep bin/afm -afm 409 1 0 13:00 ? 00:00:00 /usr/bin/afm-system-daemon -root 505 499 0 13:01 ? 00:00:00 /usr/bin/afm-user-daemon -root 596 550 0 13:22 pts/0 00:00:00 grep afm -``` - -We can see that there are two daemons running: - -* **afm-system-daemon** runs with a system user 'afm' and is responsible for - installing/uninstalling packages -* **afm-user-daemon** runs as a user daemon (currently as root because it's the - only real user on the target board) and is responsible for the whole life - cycle of the applications running inside the user session. - -The application framework has a tool running on the -Command Line Interface (CLI). -Using the **afm-util** command, you can install, uninstall, list, run, pause ... applications. - -To begin, run '**afm-util help**' to get a quick help on commands: - -```bash -root@porter:~# afm-util help -usage: afm-util command [arg] -``` - -The commands are: - -```bash -list -runnables list the runnable widgets installed - -add wgt -install wgt install the wgt file - -remove id -uninstall id remove the installed widget of id - -info id -detail id print detail about the installed widget of id - -ps -runners list the running instance - -run id -start id start an instance of the widget of id - -kill rid -terminate rid terminate the running instance rid - -status rid -state rid get status of the running instance rid -``` - -### Install an application - -You can then install your first application: - -```bash -root@porter:~# afm-util install /home/root/annex.wgt -{ "added": "webapps-annex@0.0" } -``` - -Let's install a second application: - -```bash -root@porter:~# afm-util install /home/root/memory-match.wgt -{ "added": "webapps-memory-match@1.1" } -``` - -Note that usually, **afm-util** will return a **JSON result**, which is the common format for messages returned by the Application Framework daemons. - -### List installed applications - -You can then list all installed applications: - -```bash -root@porter:~# afm-util list -[ { "id": "webapps-annex@0.0", "version": "0.0.10", "width": 0, "height": 0, "name": "Annex", "description": "Reversi\/Othello", "shortname": "", "author": "Todd Brandt " }, -{ "id": "webapps-memory-match@1.1", "version": "1.1.7", "width": 0, "height": 0, "name": "MemoryMatch", "description": "Memory match", "shortname": "", "author": "Todd Brandt " } ] -``` - -Here, we can see the two previously installed applications. - -### Get information about an application - -Let's get some details about the first application: - -```bash -root@porter:~# afm-util info webapps-annex@0.0 -{ "id": "webapps-annex@0.0", "version": "0.0.10", "width": 0, "height": 0, "name": "Annex", "description": "Reversi\/Othello", "shortname": "", "author": "Todd Brandt " } -``` - -Note: that AGL applications are mostly handled by afm-util through their IDs. -In our example, the application ID is 'webapps-annex@0.0'. - -### Start application - -Let's start the first application Annex: - -```bash -root@porter:~# afm-util start webapps-annex@0.0 -1 -``` - -As the application is a HTML5 game, you should then get a webview running with QML on the board display. - -### Security Context - -The application has been started in the user session, with a dedicated security context, enforced by SMACK. -To illustrate this, we can take a look at the running processes and their respective SMACK labels: - -```bash -root@porter:~# ps -efZ |grep webapps-annex | grep -v grep -User::App::webapps-annex root 716 491 0 13:19 ? 00:00:00 /usr/bin/afb-daemon --mode=local --readyfd=8 --alias=/icons /usr/share/afm/icons --port=12348 --rootdir=/usr/share/afm/applications/webapps-annex/0.0 --token=7D6D2F16 --sessiondir=/home/root/app-data/webapps-annex/.afb-daemon -User::App::webapps-annex root 717 491 0 13:19 ? 00:00:00 /usr/bin/qt5/qmlscene http://localhost:12348/index.html?token=7D6D2F16 /usr/bin/web-runtime-webkit.qml -``` - -In the previous result, we see that the application is composed of two processes: - -* the application binder (afb-daemon) -* the application UI (qmlscene ...) - -While most system processes run with the label 'System', we see that the -application runs with a specific SMACK label 'User::App::webapps-annex': this -label is used to force the application to follow -a Mandatory Access Control (MAC) scheme. -This means that those processes run in their own security context, -isolated from the rest of the system (and other applications). -Global security rules can then be applied to restrict access -to all other user or system resources. - -### Check running applications - -To check for running applications, just run: - -```bash -root@porter:~# afm-util ps -[ { "runid": 1, "state": "running", "id": "webapps-annex@0.0" } ] -``` - -The 'runid' is the application instance ID and is used as an argument for the -subcommands controlling the application runtime state (kill/pause/resume/status) - -### Uninstall application - -To uninstall an application, simply use its ID: - -```bash -root@porter:~# afm-util uninstall webapps-annex@0.0 -true -``` - -Then list the installed apps to confirm the removal: - -```bash -root@porter:~# afm-util list -[ { "id": "webapps-memory-match@1.1", "version": "1.1.7", "width": 0, "height": 0, "name": "MemoryMatch", "description": "Memory match", "shortname": "", "author": "Todd Brandt " } ] -``` - -## afm-client: a sample HTML5 'Homescreen' - -**afm-client** is a HTML5 UI that allows to install/uninstall applications as well as starting/pausing them as already demonstrated with afm-util. - -The HTML5 UI is accessible remotely through this URL: - - -### Installing an application - -By clicking on the '**Upload**' button on the right, -you can send an application package (WGT file) and install it. -Select for example the file '**rabbit.wgt**' that was cloned initially - from the git repository afm-widget-examples. - -Then a popup requester ask for a confirmation: -'Upload Application rabbit.wgt ?'. Click on the '**Install**' button. - -You should then see some changes in the toolbar: -a new icon appeared, representing the freshly installed application. - -### Running an application - -In the toolbar, click on the button representing the Rabbit application. -You'll get a popup asking to: - -* start the application -* or get some info about it -* or uninstall it - -Click on the 'start' item: the application starts and should be visible - as a webview on the target board display. -Note that at this point, we could also run the application remotely, -that is in the same browser as the Homescreen app. -By default, the application framework is configured -to run applications 'locally' on the board display. - -### Uninstalling an application - -From the same popup menu, you can select 'uninstall' -to remove the application from the system. -As a consequence, the application icon should disappear from the toolbar. - -## afb-client: a template for Angular Applications - -Another package '**afb-client**' is also available for testing. -This is a sample HTML5 application demonstrating various basic -capabilities of the Binder daemon. -It can be used by developers as a template to start writing real AGL Applications. - -This application is not available as WGT file yet and it should be started manually without any specific security context: - -```bash -root@porter:~# /usr/bin/afb-daemon --port=1235 --token='' --sessiondir=/home/root/.afm-daemon --rootdir=/usr/share/agl/afb-client --alias=/icons:/usr/share/afm/icons -``` - -Then you can access it from a browser: - - -afb-client is a simple application to demonstrate the built-in capabilities of the binder daemon (handling sessions and security tokens, testing POSTs uploads...) and was used during the application framework development to validate the proposed features. - -[https://github.com/iotbzh/afm-widget-examples]: https://github.com/iotbzh/afm-widget-examples -[https://www.automotivelinux.org/]: https://www.automotivelinux.org/ -[https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-binder]: https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-binder -[https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-main]: https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/app-framework-main diff --git a/docs/3_Developer_Guides/1_Application_Framework/images/AppFW-APP_install_sequences.svg b/docs/3_Developer_Guides/1_Application_Framework/images/AppFW-APP_install_sequences.svg deleted file mode 100644 index fab8399..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/images/AppFW-APP_install_sequences.svg +++ /dev/null @@ -1,408 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - System - - - - - - - - - - - - - - - User - - - - - - - - - - - D-Bus session - - - - - - - - - - SMACK isolatedother application - - - - - - - - - - SECURITY MANAGER - - - - - - - - - - afm-system-daemon - - - - - - - - - - CYNARA - - - - - - - - - - D-Bus system - - - - - - - - - - afm-user-daemon - - - - - - - - - - SMACK isolated Application - - - - - - - - - - - - - - - - - Application UI - - - - - - - - - - - binder afb-daemon - - - - - - - - - - afm-main-binding - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - (1), (7) - - - - - - (2) - - - - - - (3) - - - - - - (4) - - - - - - (5) - - - - - - (6) - - - - - - (9) - - - - - - (11) - - - - - - (12) - - - - - - (10) - - - - - - (13) - - - - - - (8) - - - - - - - diff --git a/docs/3_Developer_Guides/1_Application_Framework/images/Security_model_history.svg b/docs/3_Developer_Guides/1_Application_Framework/images/Security_model_history.svg deleted file mode 100644 index 7935437..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/images/Security_model_history.svg +++ /dev/null @@ -1,149 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Tizen OBS - - - - - - Tizen Yocto - - - - - - meta-intel-iot-security - - - - - - 2014 - - - - - - 2015 - - - - - - - \ No newline at end of file diff --git a/docs/3_Developer_Guides/1_Application_Framework/images/afm-daemons.svg b/docs/3_Developer_Guides/1_Application_Framework/images/afm-daemons.svg deleted file mode 100644 index 02b2c92..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/images/afm-daemons.svg +++ /dev/null @@ -1,237 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - System - - - - - - - - - - - - - - - User - - - - - - - - - - - D-Bus session - - - - - - - - - - SMACK isolatedApplication - - - - - - - - - - SECURITY MANAGER - - - - - - - - - - afm-system-daemon - - - - - - - - - - CYNARA - - - - - - - - - - D-Bus system - - - - - - - - - - afm-user-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/docs/3_Developer_Guides/1_Application_Framework/images/make-units.svg b/docs/3_Developer_Guides/1_Application_Framework/images/make-units.svg deleted file mode 100644 index d52a8c7..0000000 --- a/docs/3_Developer_Guides/1_Application_Framework/images/make-units.svg +++ /dev/null @@ -1,436 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <number> - - - - - - - - - - - - - - config.xml - - - - - - - /etc/afm/afm-unit.conf - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - json description - - - - - - - - - Mustache engine - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - units description - - - - - - - *.service - - - - - - - *.socket - - - - - - virtualdata - - - - - - - - - - - - - - - - - - - - - - - Unit installer - - - - - - - - - Config engine - - - - - - - ... - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - configurationfile - - - - - - systemdunits - - - - - - - \ No newline at end of file diff --git a/docs/3_Developer_Guides/1_Setting_Up_AGL_SDK.md b/docs/3_Developer_Guides/1_Setting_Up_AGL_SDK.md index c4ea431..8cdbe3e 100644 --- a/docs/3_Developer_Guides/1_Setting_Up_AGL_SDK.md +++ b/docs/3_Developer_Guides/1_Setting_Up_AGL_SDK.md @@ -14,7 +14,7 @@ quickstart the service and application development process. - **AARCH64 - ARM 64bit** : [qemuarm64](https://download.automotivelinux.org/AGL/snapshots/master/latest/qemuarm64/deploy/sdk/poky-agl-glibc-x86_64-agl-demo-platform-crosssdk-aarch64-qemuarm64-toolchain-10.90.0+snapshot.sh) *Henceforth,* **qemux86-64** *is used in these guides, unless specified - otherwise.* + otherwise. We also use the 'agl-demo-platform-crosssdk' as example.* 2. Create application developmment directory and copy SDK into them : diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/0_Overview.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/0_Overview.md deleted file mode 100644 index 22a88ba..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/0_Overview.md +++ /dev/null @@ -1,91 +0,0 @@ ---- -title: Overview ---- - -The ***binder*** provides the way to connect applications to -the services that it needs. - -It provides a fast way to securely offer APIs to applications -written in any language and running almost anywhere. - -- The ***binder*** is developed for AGL (Automotive Grade Linux) but it is not bound to AGL. -- The ***binder*** is the usual name. -- The binary is named **afb-daemon**. -- The name **afb-daemon** stands for ***Application Framework Binder Daemon***. - -The word *daemon*, here, denote the fact that the ***binder*** makes witchcraft to -connect applications to their expected services. (note: that usually the term of -daemon denotes background process but not here). - -Each ***binder*** **afb-daemon** is in charge to bind one instance of -an application or service to the rest of the system, applications and services. -Within AGL, the connection between services and/or applications -is tuned by the AGL framework and the AGL system. - -## The basis of the binder - -The following figure shows main concepts linked to the ***binder***. - -![Figure: binder basis](images/basis.svg) - -The shown elements are: - -- The SECURITY CONTEXT - - The primary intention of any ***binder*** is to provide - a secured environment for any application. - On AGL, the **security context** is ensured by [Smack] - , the security context of the application or service. - -- The BINDER - - This is the central element. - It makes possible to run HTML5 applications and provides - the unified access to APIs provided by the ***bindings***. - - Running a pure HTML5 application doesn't require any ***binding***. - In that case , the ***binder*** acts as a simple HTTP server for - the web runtime. - -- The BINDINGs - - A ***binding*** adds one **API** to the ***binder***. - - An **API** is a set of **verbs** that can be called - using either REST over HTTP or a kind of JSON RPC. - - ***bindings*** are either: - - - dynamically loaded libraries in the ***binder*** process - - remote service running on the same host - - remote service running on other hosts - - When acting as an HTTP server, the binder treats the language - settings of the HTTP requests to provide internationalized - content as specified by - [widget - specifications](https://www.w3.org/TR/widgets/#internationalization-and-localization). - -- The APPLICATION - - An ***application*** connects to the binder to get access to - the **API** that it provides or to get its HTTP services to access - resources. - -## Interconnection of binders - -The AGL framework interprets the **widget/application** manifests -to setup the ***bindings*** configuration of the ***binders***. - -The figure below shows that ***binders*** are interconnected. - -![Figure: binder interconnection](images/interconnection.svg) - -The figure shows 4 several **application/service**: **A**, **B**, -**C** and **D**. - -The application **A** might use an **API** that is shown as a -local ***binding*** but that in reality runs within the context -of **D**. - -The framework AGL takes care of making the plumbing working. \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/1_Binder_daemon_vocabulary.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/1_Binder_daemon_vocabulary.md deleted file mode 100644 index 9839e65..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/1_Binder_daemon_vocabulary.md +++ /dev/null @@ -1,104 +0,0 @@ ---- -title: Binder daemon vocabulary ---- - -## Binding - -A shared library object intended to add a functionality to an afb-daemon -instance. -It implements an API and may provide a service. - -Binding made for services can have specific entry points called after -initialization and before serving. - -## Event - -Messages with data propagated from the services to the client and not expecting -any reply. - -The current implementation allows to widely broadcast events to all clients. - -## Level of assurance (LOA) - -This level that can be from 0 to 3 represent the level of -assurance that the services can expect from the session. - -The exact definition of the meaning of these levels and how to use it remains to -be achieved. - -## Request - -A request is an invocation by a client to a binding method using a message -transferred through some protocol: - -- HTTP -- WebSocket -- ... - -and served by ***afb-daemon*** - -## Reply/Response - -This is a message sent to client as the result of the request. - -## Service - -Service are made of bindings running on a binder -The binder is in charge of connecting services and applications. -A service can serve many clients. - -The framework establishes connection between the services and the clients. -Using sockets currently but other protocols are considered. - -The term of service is tightly bound to the notion of API. - -## Session - -A session is meant to be the unique instance context of a client, -which identify that instance across requests. - -Each session has an identifier. -Session identifier generated by afb-daemon are UUIDs. -A client can present its own session id. - -Internally, afb-daemon offers a mechanism to attach data to sessions. -When a session is closed or disappears, data attached to that session -are freed. - -## Token - -The token is an identifier that the client must give to be authenticated. - -At start, afb-daemon get an initial token. -This initial token must be presented by incoming client to be authenticated. - -A token is valid only for a period. - -The token must be renewed periodically. -When the token is renewed, afb-daemon sends the new token to the client. - -Tokens generated by afb-daemon are UUIDs. - -## UUID - -It stand for Universal Unique IDentifier. - -It is designed to create identifier in a way that avoid has much as possible -conflicts. -It means that if two different instances create an UUID, the -probability that they create the same UUID is very low, near to zero. - -## x-afb-reqid - -Argument name that can be used with HTTP request. -When this argument is given, it is automatically added to the "request" object of the answer. - -## x-afb-token - -Argument name meant to give the token without ambiguity. -You can also use the name **token** but it may conflicts with others arguments. - -## x-afb-uuid - -Argument name for giving explicitly the session identifier without ambiguity. -You can also use the name **uuid** but it may conflicts with others arguments. diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/2_How_to_write_a_binding.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/2_How_to_write_a_binding.md deleted file mode 100644 index d739167..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/2_How_to_write_a_binding.md +++ /dev/null @@ -1,444 +0,0 @@ ---- -title: How to write a binding? ---- - -# Overview of the bindings - -The ***binder*** serves files through HTTP protocol and offers developers the capability to offer application API methods through HTTP or -WebSocket protocol. - -The ***bindings*** are used to add **API** to ***binders***. -This part describes how to write a ***binding*** for ***binder*** -or in other words how to add a new **API** to the system. - -This section target developers. - -This section shortly explain how to write a binding -using the C programming language. - -It is convenient to install the ***binder*** on the -desktop used for writing the binding. -It allows for easy debug and test. - -## Nature of a binding - -A ***binding*** is an independent piece of software compiled as a shared -library and dynamically loaded by a ***binder***. -It is intended to provide one **API** (**A**pplication **P**rogramming -**I**nterface). - -The **API** is designated and accessed through its name. -It contains several **verbs** that implement the ***binding*** -functionalities. -Each of these **verbs** is a **method** that -processes requests of applications and sends results. - -The ***binding***'s methods are invoked by HTTP or websocket -requests. - -The **methods** of the ***bindings*** are noted **api/verb** -where **api** is the **API** name of the binding and **verb** is -the **method**'s name within the **API**. -This notation comes from HTTP invocations that rely on URL path terminated -with **api/verb**. - -The name of an **API** can be made of any characters except: - -- the control characters (\u0000 .. \u001f) -- the characters of the set { ' ', '"', '#', '%', '&', - '\'', '/', '?', '`', '\x7f' } - -The names of the **verbs** can be any character. - -The binder makes no distinctions between upper case and lower case -latin letters. -So **API/VERB** matches **Api/Verb** or **api/verb**. - -## Versions of the bindings - -Since introduction of the binder, the way how bindings are written -evolved a little. While changing, attention was made to ensure binary -compatibility between the different versions. - -Actually it exists 3 ways of writing ***bindings***. -You can either write: - -- a binding version 1 (not more supported); -- a binding version 2 (not recommended); -- a binding version 3 (RECOMMENDED). - -A ***binder*** loads and runs any of these version in any combination. -This document explain how to write bindings version 3. - -## Sample binding: tuto-1 - -This is the code of the binding **tuto-1.c**: - -```C - 1 #define AFB_BINDING_VERSION 3 - 2 #include - 3 - 4 void hello(afb_req_t req) - 5 { - 6 AFB_REQ_DEBUG(req, "hello world"); - 7 afb_req_reply(req, NULL, NULL, "hello world"); - 8 } - 9 - 10 const afb_verb_t verbs[] = { - 11 { .verb="hello", .callback=hello }, - 12 { .verb=NULL } - 13 }; - 14 - 15 const afb_binding_t afbBindingExport = { - 16 .api = "tuto-1", - 17 .verbs = verbs - 18 }; -``` - -Compiling: - -```bash -gcc -fPIC -shared tuto-1.c -o tuto-1.so $(pkg-config --cflags-only-I afb-daemon) -``` - -> Note: the variable environment variable PKG_CONFIG_PATH might be necessary -> tuned to get **pkg-config** working properly - -Running: - -```bash -afb-daemon --binding ./tuto-1.so --port 3333 --token '' -``` - -At this point, afb-daemon has started, it loaded the binding tuto-1.so and now -listen at localhost on the port 3333. - -Testing using **curl**: - -```bash -$ curl http://localhost:3333/api/tuto-1/hello -{"jtype":"afb-reply","request":{"status":"success","info":"hello world","uuid":"1e587b54-900b-49ab-9940-46141bc2e1d6"}} -``` - -Testing using **afb-client-demo** (with option -H for -getting a human readable output): - -```bash -$ afb-client-demo -H ws://localhost:3333/api?token=x tuto-1 hello -ON-REPLY 1:tuto-1/hello: OK -{ - "jtype":"afb-reply", - "request":{ - "status":"success", - "info":"hello world", - "uuid":"03a84ad1-458a-4ace-af74-b1da917391b9" - } -} -``` - -This shows basic things: - -- The include to get for creating a binding -- How to declare the API offered by the binding -- How to handle requests made to the binding - -### Getting declarations for the binding - -The lines 1 and 2 show how to get the include file **afb-binding.h**. - -```C - 1 #define AFB_BINDING_VERSION 3 - 2 #include -``` - -You must define the version of ***binding*** that you are using. -This is done line 1 where we define that this is the version 3 (earlier -versions 1 and 2 are deprecated). - -If you don't define it, an error is reported and the compilation aborts. - -To include **afb-binding.h** successfully, the include search path -should be set correctly if needed (not needed only if installed in -/usr/include/afb directory that is the default). - -Setting the include path is easy using **pkg-config**: - -```bash -pkg-config --cflags-only-I afb-daemon -``` - -> Note for **C++** developers: -> -> The ***binder*** currently expose a draft version of **C++** api. -> To get it include the file <**afb/afb-binding**> (without **.h**). - - -### Declaring the API of the binding - -Lines 10 to 18 show the declaration of the ***binding***. - -The ***binder*** knows that this is a ***binding*** because -it finds the exported symbol **afbBindingExport** that is expected to be -a structure of type **afb_binding_t**. - -```C - 10 const afb_verb_t verbs[] = { - 11 { .verb="hello", .callback=hello }, - 12 { .verb=NULL } - 13 }; - 14 - 15 const afb_binding_t afbBindingExport = { - 16 .api = "tuto-1", - 17 .verbs = verbs - 18 }; -``` - -The structure **afbBindingExport** actually tells that: - -- the exported **API** name is **tuto-1** (line 16) -- the array of verbs is the above defined one - -The exported list of verb is specified by an array of structures of -type **afb_verb_t**, each describing a verb, ended with a verb NULL (line 12). - -The only defined verb here (line 11) is named **hello** (field **.verb**) -and the function that handle the related request is **hello** -(field **.callback**). - -### Handling binder's requests - -As shown above this is by default the common include directory where -the AGL stuff is installed. - -```C - 4 void hello(afb_req_t req) - 5 { - 6 AFB_REQ_DEBUG(req, "hello world"); - 7 afb_req_reply(req, NULL, NULL, "hello world"); - 8 } -``` - -When the ***binder*** receives a request for the verb **hello** of -of the api **tuto-1**, it invoke the callback **hello** of the **binding** -with the argument **req** that handles the client request. - -The callback has to treat synchronously or asynchronously the request and -should at the end emit a reply for the request. - -At the line 7, the callback for **tuto-1/hello** replies to the request **req**. -Parameters of the reply are: - - 1. The first parameter is the replied request - 2. The second parameter is a json object (here NULL) - 3. The third parameter is the error string indication (here NULL: no error) - 4. The fourth parameter is an informative string (that can be NULL) that can be used to provide meta data. - -The 3 last parameters are sent back to the client as the reply content. - - - -## Sample binding: tuto-2 - -The second tutorial shows many important feature that can -commonly be used when writing a ***binding***: - -- initialization, getting arguments, sending replies, pushing events. - -This is the code of the binding **tuto-2.c**: - -```C - 1 #include - 2 #include - 3 - 4 #define AFB_BINDING_VERSION 3 - 5 #include - 6 - 7 afb_event_t event_login, event_logout; - 8 - 9 void login(afb_req_t req) - 10 { - 11 json_object *args, *user, *passwd; - 12 char *usr; - 13 - 14 args = afb_req_json(req); - 15 if (!json_object_object_get_ex(args, "user", &user) - 16 || !json_object_object_get_ex(args, "password", &passwd)) { - 17 AFB_REQ_ERROR(req, "login, bad request: %s", json_object_get_string(args)); - 18 afb_req_reply(req, NULL, "bad-request", NULL); - 19 } else if (afb_req_context_get(req)) { - 20 AFB_REQ_ERROR(req, "login, bad state, logout first"); - 21 afb_req_reply(req, NULL, "bad-state", NULL); - 22 } else if (strcmp(json_object_get_string(passwd), "please")) { - 23 AFB_REQ_ERROR(req, "login, unauthorized: %s", json_object_get_string(args)); - 24 afb_req_reply(req, NULL, "unauthorized", NULL); - 25 } else { - 26 usr = strdup(json_object_get_string(user)); - 27 AFB_REQ_NOTICE(req, "login user: %s", usr); - 28 afb_req_session_set_LOA(req, 1); - 29 afb_req_context_set(req, usr, free); - 30 afb_req_reply(req, NULL, NULL, NULL); - 31 afb_event_push(event_login, json_object_new_string(usr)); - 32 } - 33 } - 34 - 35 void action(afb_req_t req) - 36 { - 37 json_object *args, *val; - 38 char *usr; - 39 - 40 args = afb_req_json(req); - 41 usr = afb_req_context_get(req); - 42 AFB_REQ_NOTICE(req, "action for user %s: %s", usr, json_object_get_string(args)); - 43 if (json_object_object_get_ex(args, "subscribe", &val)) { - 44 if (json_object_get_boolean(val)) { - 45 AFB_REQ_NOTICE(req, "user %s subscribes to events", usr); - 46 afb_req_subscribe(req, event_login); - 47 afb_req_subscribe(req, event_logout); - 48 } else { - 49 AFB_REQ_NOTICE(req, "user %s unsubscribes to events", usr); - 50 afb_req_unsubscribe(req, event_login); - 51 afb_req_unsubscribe(req, event_logout); - 52 } - 53 } - 54 afb_req_reply(req, json_object_get(args), NULL, NULL); - 55 } - 56 - 57 void logout(afb_req_t req) - 58 { - 59 char *usr; - 60 - 61 usr = afb_req_context_get(req); - 62 AFB_REQ_NOTICE(req, "login user %s out", usr); - 63 afb_event_push(event_logout, json_object_new_string(usr)); - 64 afb_req_session_set_LOA(req, 0); - 65 afb_req_context_clear(req); - 66 afb_req_reply(req, NULL, NULL, NULL); - 67 } - 68 - 69 int preinit(afb_api_t api) - 70 { - 71 AFB_API_NOTICE(api, "preinit"); - 72 return 0; - 73 } - 74 - 75 int init(afb_api_t api) - 76 { - 77 AFB_API_NOTICE(api, "init"); - 78 event_login = afb_api_make_event(api, "login"); - 79 event_logout = afb_api_make_event(api, "logout"); - 80 if (afb_event_is_valid(event_login) && afb_event_is_valid(event_logout)) - 81 return 0; - 82 AFB_API_ERROR(api, "Can't create events"); - 83 return -1; - 84 } - 85 - 86 const afb_verb_t verbs[] = { - 87 { .verb="login", .callback=login }, - 88 { .verb="action", .callback=action, .session=AFB_SESSION_LOA_1 }, - 89 { .verb="logout", .callback=logout, .session=AFB_SESSION_LOA_1 }, - 90 { .verb=NULL } - 91 }; - 92 - 93 const afb_binding_t afbBindingExport = { - 94 .api = "tuto-2", - 95 .specification = NULL, - 96 .verbs = verbs, - 97 .preinit = preinit, - 98 .init = init, - 99 .noconcurrency = 0 - 100 }; -``` - -Compiling: - -```bash -gcc -fPIC -shared tuto-2.c -o tuto-2.so $(pkg-config --cflags --libs afb-daemon) -``` - -Running: - -```bash -afb-daemon --binding ./tuto-2.so --port 3333 --token '' -``` - -Testing: - -```bash -$ afb-client-demo -H localhost:3333/api?token=toto -tuto-2 login {"help":true} -ON-REPLY 1:tuto-2/login: ERROR -{ - "jtype":"afb-reply", - "request":{ - "status":"bad-request", - "uuid":"e2b24a13-fc43-487e-a5f4-9266dd1e60a9" - } -} -tuto-2 login {"user":"jose","password":"please"} -ON-REPLY 2:tuto-2/login: OK -{ - "jtype":"afb-reply", - "request":{ - "status":"success" - } -} -tuto-2 login {"user":"jobol","password":"please"} -ON-REPLY 3:tuto-2/login: ERROR -{ - "jtype":"afb-reply", - "request":{ - "status":"bad-state" - } -} -tuto-2 action {"subscribe":true} -ON-REPLY 4:tuto-2/action: OK -{ - "response":{ - "subscribe":true - }, - "jtype":"afb-reply", - "request":{ - "status":"success" - } -} -``` - -In another terminal: - -```bash -$ afb-client-demo -H localhost:3333/api?token=toto -tuto-2 login {"user":"jobol","password":"please"} -ON-REPLY 1:tuto-2/login: OK -{ - "jtype":"afb-reply", - "request":{ - "status":"success", - "uuid":"a09f55ff-0e89-4f4e-8415-c6e0e7f439be" - } -} -tuto-2 logout true -ON-REPLY 2:tuto-2/logout: OK -{ - "jtype":"afb-reply", - "request":{ - "status":"success" - } -} -``` - -It produced in the first terminal: - -```bash -ON-EVENT tuto-2/login: -{ - "event":"tuto-2\/login", - "data":"jobol", - "jtype":"afb-event" -} -ON-EVENT tuto-2/logout: -{ - "event":"tuto-2\/logout", - "data":"jobol", - "jtype":"afb-event" -} -``` diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/3_Binder_References.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/3_Binder_References.md deleted file mode 100644 index fab571b..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/3_Binder_References.md +++ /dev/null @@ -1,2524 +0,0 @@ ---- -title: Binder References ---- - -i. TYPES AND GLOBALS -====================== - -## The global afbBindingRoot - -The global **afbBindingRoot** of type **afb_api_t** is always implicitly -defined for bindings of version 3 or upper. It records the root api of -the binding. - -When the binding has a defined **afbBindingExport**, the root api -**afbBindingRoot** is the **afb_pi_t** relative to the api created for -this static description. - -When the binding has no defined **afbBindingExport**, the root api is -a virtual api representing the shared object of the binding. In that case -the name of the api is the path of the shared object. Its use is restricted -but allows log messages. - -## The global afbBindingExport - -The global **afbBindingExport** is not mandatory. - -If **afbBindingExport** is defined and exported, it must be of the type -**const afb_binding_t** and must describe the *root* api of the binding. - -## The type afb_api_t - -Bindings now can declare more than one api. The counter part is that -a new handle is needed to manage apis. These handles are of the type -**afb_api_t**. - -It is defined as below. - -```C -typedef struct afb_api_x3 afb_api_t; -``` - -## The type afb_binding_t - -The main structure, of type **afb_binding_t**, for describing the binding -must be exported under the name **afbBindingExport**. - -This structure is defined as below. - -```C -typedef struct afb_binding_v3 afb_binding_t; -``` - -Where: - -```C -/** - * Description of the bindings of type version 3 - */ -struct afb_binding_v3 -{ - /** api name for the binding, can't be NULL */ - const char *api; - - /** textual specification of the binding, can be NULL */ - const char *specification; - - /** some info about the api, can be NULL */ - const char *info; - - /** array of descriptions of verbs terminated by a NULL name, can be NULL */ - const struct afb_verb_v3 *verbs; - - /** callback at load of the binding */ - int (*preinit)(struct afb_api_x3 *api); - - /** callback for starting the service */ - int (*init)(struct afb_api_x3 *api); - - /** callback for handling events */ - void (*onevent)(struct afb_api_x3 *api, const char *event, struct json_object *object); - - /** userdata for afb_api_x3 */ - void *userdata; - - /** space separated list of provided class(es) */ - const char *provide_class; - - /** space separated list of required class(es) */ - const char *require_class; - - /** space separated list of required API(es) */ - const char *require_api; - - /** avoids concurrent requests to verbs */ - unsigned noconcurrency: 1; -}; -``` - -## The type afb_verb_t - -Each verb is described with a structure of type **afb_verb_t** -defined below: - -```C -typedef struct afb_verb_v3 afb_verb_t; -``` - -```C -/** - * Description of one verb as provided for binding API version 3 - */ -struct afb_verb_v3 -{ - /** name of the verb, NULL only at end of the array */ - const char *verb; - - /** callback function implementing the verb */ - void (*callback)(afb_req_t_x2 *req); - - /** required authorization, can be NULL */ - const struct afb_auth *auth; - - /** some info about the verb, can be NULL */ - const char *info; - - /**< data for the verb callback */ - void *vcbdata; - - /** authorization and session requirements of the verb */ - uint16_t session; - - /** is the verb glob name */ - uint16_t glob: 1; -}; -``` - -The **session** flags is one of the constant defined below: - -| Name | Description -|:----------------------:|------------------------------------------------------ -| AFB_SESSION_NONE | no flag, synonym to 0 -| AFB_SESSION_LOA_0 | Requires the LOA to be 0 or more, synonym to 0 or AFB_SESSION_NONE -| AFB_SESSION_LOA_1 | Requires the LOA to be 1 or more -| AFB_SESSION_LOA_2 | Requires the LOA to be 2 or more -| AFB_SESSION_LOA_3 | Requires the LOA to be 3 or more -| AFB_SESSION_CHECK | Requires the token to be set and valid -| AFB_SESSION_REFRESH | Implies a token refresh -| AFB_SESSION_CLOSE | Implies closing the session after request processed - -The LOA (Level Of Assurance) is set, by binding api, using the function **afb_req_session_set_LOA**. - -The session can be closed, by binding api, using the function **afb_req_session_close**. - -## The types afb_auth_t and afb_auth_type_t - -The structure **afb_auth_t** is used within verb description to -set security requirements. -The interpretation of the structure depends on the value of the field **type**. - -```C -typedef struct afb_auth afb_auth_t; - -/** - * Definition of an authorization entry - */ -struct afb_auth -{ - /** type of entry @see afb_auth_type */ - enum afb_auth_type type; - - union { - /** text when @ref type == @ref afb_auth_Permission */ - const char *text; - - /** level of assurancy when @ref type == @ref afb_auth_LOA */ - unsigned loa; - - /** first child when @ref type in { @ref afb_auth_Or, @ref afb_auth_And, @ref afb_auth_Not } */ - const struct afb_auth *first; - }; - - /** second child when @ref type in { @ref afb_auth_Or, @ref afb_auth_And } */ - const struct afb_auth *next; -}; - -``` - -The possible values for **type** is defined here: - -```C -typedef enum afb_auth_type afb_auth_type_t; - -/** - * Enumeration for authority (Session/Token/Assurance) definitions. - * - * @see afb_auth - */ -enum afb_auth_type -{ - /** never authorized, no data */ - afb_auth_No = 0, - - /** authorized if token valid, no data */ - afb_auth_Token, - - /** authorized if LOA greater than or equal to data 'loa' */ - afb_auth_LOA, - - /** authorized if permission 'text' is granted */ - afb_auth_Permission, - - /** authorized if 'first' or 'next' is authorized */ - afb_auth_Or, - - /** authorized if 'first' and 'next' are authorized */ - afb_auth_And, - - /** authorized if 'first' is not authorized */ - afb_auth_Not, - - /** always authorized, no data */ - afb_auth_Yes -}; -``` - -Example: - -```C -static const afb_auth_t myauth[] = { - { .type = afb_auth_Permission, .text = "urn:AGL:permission:me:public:set" }, - { .type = afb_auth_Permission, .text = "urn:AGL:permission:me:public:get" }, - { .type = afb_auth_Or, .first = &myauth[1], .next = &myauth[0] } -}; -``` - - -## The type afb_req_subcall_flags_t - -This is an enumeration that defines bit's positions for setting behaviour -of subcalls. - -| flag | value | description -|----------------------------|-------|-------------- -| afb_req_subcall_catch_events | 1 | the calling API wants to receive the events from subscription -| afb_req_subcall_pass_events | 2 | the original request will receive the events from subscription -| afb_req_subcall_on_behalf | 4 | the calling API wants to use the credentials of the original request -| afb_req_subcall_api_session | 8 | the calling API wants to use its session instead of the one of the original request - -ii. MACROS FOR LOGGING -================= - -The final behaviour of macros can be tuned using 2 defines that must be defined -before including ****. - -| define | action -|---------------------------------------|-------------------- -| AFB_BINDING_PRAGMA_NO_VERBOSE_DATA | show file and line, remove function and text message -| AFB_BINDING_PRAGMA_NO_VERBOSE_DETAILS | show text, remove function, line and file - -## Logging for an api - -The following macros must be used for logging for an **api** of type -**afb_api_t**. - -```C -AFB_API_ERROR(api,fmt,...) -AFB_API_WARNING(api,fmt,...) -AFB_API_NOTICE(api,fmt,...) -AFB_API_INFO(api,fmt,...) -AFB_API_DEBUG(api,fmt,...) -``` - -## Logging for a request - - -The following macros can be used for logging in the context -of a request **req** of type **afb_req_t**: - -```C -AFB_REQ_ERROR(req,fmt,...) -AFB_REQ_WARNING(req,fmt,...) -AFB_REQ_NOTICE(req,fmt,...) -AFB_REQ_INFO(req,fmt,...) -AFB_REQ_DEBUG(req,fmt,...) -``` - -By default, the logging macros add file, line and function -indication. - -## Logging legacy - -The following macros are provided for legacy. - -```C -AFB_ERROR(fmt,...) -AFB_WARNING(fmt,...) -AFB_NOTICE(fmt,...) -AFB_INFO(fmt,...) -AFB_DEBUG(fmt,...) -``` - -iii. FUNCTIONS OF CLASS **afb_api** -============================ - -## General functions - -### afb_api_name - -```C -/** - * Get the name of the 'api'. - * - * @param api the api whose name is to be returned - * - * @return the name of the api. - * - * The returned value must not be changed nor freed. - */ -const char *afb_api_name( - afb_api_t api); -``` - -### afb_api_get_userdata - -```C -/** - * Get the "userdata" pointer of the 'api' - * - * @param api the api whose user's data is to be returned - * - * @return the user's data pointer of the api. - * - * @see afb_api_set_userdata - */ -void *afb_api_get_userdata( - afb_api_t api); -``` - -### afb_api_set_userdata - -```C -/** - * Set the "userdata" pointer of the 'api' to 'value' - * - * @param api the api whose user's data is to be set - * @param value the data to set - * - * @see afb_api_get_userdata - */ -void afb_api_set_userdata( - afb_api_t api, - void *value); -``` - -### afb_api_require_api - -```C -/** - * Check that it requires the API of 'name'. - * If 'initialized' is not zero it requests the API to be - * initialized, implying its initialization if needed. - * - * Calling this function is only allowed within init. - * - * A single request allows to require multiple apis. - * - * @param api the api that requires the other api by its name - * @param name a space separated list of required api names - * @param initialized if zero, the api is just required to exist. If not zero, - * the api is required to exist and to be initialized at return of the call - * (initializing it if needed and possible as a side effect of the call). - * - * @return 0 in case of success or -1 in case of error with errno set appropriately. - */ -int afb_api_require_api( - afb_api_t api, - const char *name, - int initialized); -``` - - -## Verbosity functions - -### afb_api_wants_log_level - -```C -/** - * Is the log message of 'level (as defined for syslog) required for the api? - * - * @param api the api to check - * @param level the level to check as defined for syslog: - * - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @return 0 if not required or a value not null if required - * - * @see syslog - */ -int afb_api_wants_log_level( - afb_api_t api, - int level); -``` - -### afb_api_vverbose - -```C -/** - * Send to the journal with the logging 'level' a message described - * by 'fmt' applied to the va-list 'args'. - * - * 'file', 'line' and 'func' are indicators of code position in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @param api the api that collects the logging message - * @param level the level of the message - * @param file the source file that logs the messages or NULL - * @param line the line in the source file that logs the message - * @param func the name of the function in the source file that logs - * @param fmt the format of the message as in printf - * @param args the arguments to the format string of the message as a va_list - * - * @see syslog - * @see printf - */ -void afb_api_vverbose( - afb_api_t api, - int level, - const char *file, - int line, - const char *func, - const char *fmt, - va_list args); -``` - -### afb_api_verbose - -```C -/** - * Send to the journal with the log 'level' a message described - * by 'fmt' and following parameters. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @param api the api that collects the logging message - * @param level the level of the message - * @param file the source file that logs the messages or NULL - * @param line the line in the source file that logs the message - * @param func the name of the function in the source file that logs - * @param fmt the format of the message as in printf - * @param ... the arguments to the format string of the message - * - * @see syslog - * @see printf - */ -void afb_api_verbose( - afb_api_t api, - int level, - const char *file, - int line, - const char *func, - const char *fmt, - ...); -``` - -## Data retrieval functions - -### afb_api_rootdir_get_fd - -```C -/** - * Get the root directory file descriptor. This file descriptor can - * be used with functions 'openat', 'fstatat', ... - * - * CAUTION, manipulate this descriptor with care, in particular, don't close - * it. - * - * This can be used to get the path of the root directory using: - * - * char buffer[MAX_PATH], proc[100]; - * int dirfd = afb_api_rootdir_get_fd(api); - * snprintf(proc, sizeof proc, "/proc/self/fd/%d", dirfd); - * readlink(proc, buffer, sizeof buffer); - * - * But note that within AGL this is the value given by the environment variable - * AFM_APP_INSTALL_DIR. - * - * @param api the api that uses the directory file descriptor - * - * @return the file descriptor of the root directory. - * - * @see afb_api_rootdir_open_locale - */ -int afb_api_rootdir_get_fd( - afb_api_t api); -``` - -### afb_api_rootdir_open_locale - -```C -/** - * Opens 'filename' within the root directory with 'flags' (see function openat) - * using the 'locale' definition (example: "jp,en-US") that can be NULL. - * - * The filename must be relative to the root of the bindings. - * - * The opening mode must be for read or write but not for O_CREAT. - * - * The definition of locales and of how files are searched can be checked - * here: https://www.w3.org/TR/widgets/#folder-based-localization - * and https://tools.ietf.org/html/rfc7231#section-5.3.5 - * - * @param api the api that queries the file - * @param filename the relative path to the file to open - * @param flags the flags for opening as for C function 'open' - * @param locale string indicating how to search content, can be NULL - * - * @return the file descriptor or -1 in case of error and errno is set with the - * error indication. - * - * @see open - * @see afb_api_rootdir_get_fd - */ -int afb_api_rootdir_open_locale( - afb_api_t api, - const char *filename, - int flags, - const char *locale); -``` - -### afb_api_settings - -```C -/** - * Settings of the api. - * - * Get the settings of the API. The settings are recorded - * as a JSON object. The returned object should not be modified. - * It MUST NOT be released using json_object_put. - * - * @param api the api whose settings are required - * - * @returns The setting object. - */ -struct json_object *afb_api_settings( - struct afb_api_x3 *api); -``` - -## Calls and job functions - -### afb_api_call - -```C -/** - * Calls the 'verb' of the 'apiname' with the arguments 'args' and 'verb' in the name of the binding 'api'. - * The result of the call is delivered to the 'callback' function with the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 5 arguments: - * 1. 'closure' the user defined closure pointer 'closure', - * 2. 'object' a JSON object returned (can be NULL) - * 3. 'error' a string not NULL in case of error but NULL on success - * 4. 'info' a string handling some info (can be NULL) - * 5. 'api' the api - * - * NOTE: For convenience, *json_object_put* is called on 'object' after the - * callback returns. So, it is wrong to call *json_object_put* in the callback. - * - * @param api The api that makes the call - * @param apiname The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param callback The to call on completion - * @param closure The closure to pass to the callback - * - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - * @see afb_api_call_sync - */ -void afb_api_call( - afb_api_t api, - const char *apiname, - const char *verb, - struct json_object *args, - void (*callback)( - void *closure, - struct json_object *object, - const char *error, - const char * info, - afb_api_t api), - void *closure); -``` - -### afb_api_call_sync - -```C -/** - * Calls the 'verb' of the 'apiname' with the arguments 'args' and 'verb' in the name of the binding 'api'. - * 'result' will receive the response. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param api The api that makes the call - * @param apiname The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param object Where to store the returned object - should call json_object_put on it - can be NULL - * @param error Where to store the copied returned error - should call free on it - can be NULL - * @param info Where to store the copied returned info - should call free on it - can be NULL - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - * @see afb_api_call - */ -int afb_api_call_sync( - afb_api_t api, - const char *apiname, - const char *verb, - struct json_object *args, - struct json_object **object, - char **error, - char **info); -``` - -### afb_api_queue_job - -```C -/** - * Queue the job defined by 'callback' and 'argument' for being executed asynchronously - * in this thread (later) or in an other thread. - * - * If 'group' is not NULL, the jobs queued with a same value (as the pointer value 'group') - * are executed in sequence in the order of there submission. - * - * If 'timeout' is not 0, it represent the maximum execution time for the job in seconds. - * At first, the job is called with 0 as signum and the given argument. - * - * The job is executed with the monitoring of its time and some signals like SIGSEGV and - * SIGFPE. When a such signal is catched, the job is terminated and reexecuted but with - * signum being the signal number (SIGALRM when timeout expired). - * - * When executed, the callback function receives 2 arguments: - * - * - int signum: the signal catched if any or zero at the beginning - * - void *arg: the parameter 'argument' - * - * A typical implementation of the job callback is: - * - * void my_job_cb(int signum, void *arg) - * { - * struct myarg_t *myarg = arg; - * if (signum) - * AFB_API_ERROR(myarg->api, "job interrupted with signal %s", strsignal(signum)); - * else - * really_do_my_job(myarg); - * } - * - * @param api the api that queue the job - * @param callback the job as a callback function - * @param argument the argument to pass to the queued job - * @param group the group of the job, NULL if no group - * @param timeout the timeout of execution of the job - * - * @return 0 in case of success or -1 in case of error with errno set appropriately. - */ -int afb_api_queue_job( - afb_api_t api, - void (*callback)(int signum, void *arg), - void *argument, - void *group, - int timeout); -``` - -## Event functions - -### afb_api_broadcast_event - -```C -/** - * Broadcasts widely the event of 'name' with the data 'object'. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * Calling this function is only forbidden during preinit. - * - * The event sent as the name API/name where API is the name of the - * api. - * - * @param api the api that broadcast the event - * @param name the event name suffix - * @param object the object that comes with the event - * - * @return 0 in case of success or -1 in case of error - */ -int afb_api_broadcast_event( - afb_api_t api, - const char *name, - struct json_object *object); -``` - -### afb_api_make_event - -```C -/** - * Creates an event of 'name' and returns it. - * - * Calling this function is only forbidden during preinit. - * - * See afb_event_is_valid to check if there is an error. - * - * The event created as the name API/name where API is the name of the - * api. - * - * @param api the api that creates the event - * @param name the event name suffix - * - * @return the created event. Use the function afb_event_is_valid to check - * whether the event is valid (created) or not (error as reported by errno). - * - * @see afb_event_is_valid - */ -afb_event_t afb_api_make_event( - afb_api_t api, - const char *name); -``` - -### afb_api_event_handler_add - -```C -/** - * Add a specific event handler for the api - * - * The handler callback is called when an event matching the given pattern - * is received (it is received if broadcasted or after subscription through - * a call or a subcall). - * - * The handler callback receive 4 arguments: - * - * - the closure given here - * - the event full name - * - the companion JSON object of the event - * - the api that subscribed the event - * - * @param api the api that creates the handler - * @param pattern the global pattern of the event to handle - * @param callback the handler callback function - * @param closure the closure of the handler - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_api_on_event - * @see afb_api_event_handler_del - */ -int afb_api_event_handler_add( - afb_api_t api, - const char *pattern, - void (*callback)( - void *, - const char*, - struct json_object*, - afb_api_t), - void *closure); -``` - -### afb_api_event_handler_del - -```C -/** - * Delete a specific event handler for the api - * - * @param api the api that the handler belongs to - * @param pattern the global pattern of the handler to remove - * @param closure if not NULL it will receive the closure set to the handler - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_api_on_event - * @see afb_api_event_handler_add - */ -int afb_api_event_handler_del( - afb_api_t api, - const char *pattern, - void **closure); - -``` - -## Systemd functions - -### afb_api_get_event_loop - -```C -/** - * Retrieves the common systemd's event loop of AFB - * - * @param api the api that uses the event loop - * - * @return the systemd event loop if active, NULL otherwise - * - * @see afb_api_get_user_bus - * @see afb_api_get_system_bus - */ -struct sd_event *afb_api_get_event_loop( - afb_api_t api); -``` - -### afb_api_get_user_bus - -```C -/** - * Retrieves the common systemd's user/session d-bus of AFB - * - * @param api the api that uses the user dbus - * - * @return the systemd user connection to dbus if active, NULL otherwise - * - * @see afb_api_get_event_loop - * @see afb_api_get_system_bus - */ -struct sd_bus *afb_api_get_user_bus( - afb_api_t api); -``` - -### afb_api_get_system_bus - -```C -/** - * Retrieves the common systemd's system d-bus of AFB - * - * @param api the api that uses the system dbus - * - * @return the systemd system connection to dbus if active, NULL otherwise - * - * @see afb_api_get_event_loop - * @see afb_api_get_user_bus - */ -struct sd_bus *afb_api_get_system_bus( - afb_api_t api); -``` - - -## Dynamic api functions - -### afb_api_new_api - -```C -/** - * Creates a new api of name 'apiname' briefly described by 'info' (that can - * be NULL). - * - * When the pre-initialization function is given, it is a function that - * receives 2 parameters: - * - * - the closure as given in the call - * - the created api that can be initialised - * - * This pre-initialization function must return a negative value to abort - * the creation of the api. Otherwise, it returns a non-negative value to - * continue. - * - * @param api the api that creates the other one - * @param apiname the name of the new api - * @param info the brief description of the new api (can be NULL) - * @param noconcurrency zero or not zero whether the new api is reentrant or not - * @param preinit the pre-initialization function if any (can be NULL) - * @param closure the closure for the pre-initialization preinit - * - * @return the created api in case of success or NULL on error - * - * @see afb_api_delete_api - */ -afb_api_t afb_api_new_api( - afb_api_t api, - const char *apiname, - const char *info, - int noconcurrency, - int (*preinit)(void*, afb_api_t ), - void *closure); -``` - -### afb_api_set_verbs_v2 - -```C -/** - * @deprecated use @ref afb_api_set_verbs_v3 instead - * - * Set the verbs of the 'api' using description of verbs of the api v2 - * - * @param api the api that will get the verbs - * @param verbs the array of verbs to add terminated with an item with name=NULL - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_verb_v2 - * @see afb_api_add_verb - * @see afb_api_set_verbs_v3 - */ -int afb_api_set_verbs_v2( - afb_api_t api, - const struct afb_verb_v2 *verbs); -``` - -### afb_api_set_verbs_v3 - -```C -/** - * Set the verbs of the 'api' using description of verbs of the api v2 - * - * @param api the api that will get the verbs - * @param verbs the array of verbs to add terminated with an item with name=NULL - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_verb_v3 - * @see afb_api_add_verb - * @see afb_api_del_verb - */ -int afb_api_set_verbs_v3( - afb_api_t api, - const struct afb_verb_v3 *verbs); -``` - -### afb_api_add_verb - -```C -/** - * Add one verb to the dynamic set of the api - * - * @param api the api to change - * @param verb name of the verb - * @param info brief description of the verb, can be NULL - * @param callback callback function implementing the verb - * @param vcbdata data for the verb callback, available through req - * @param auth required authorization, can be NULL - * @param session authorization and session requirements of the verb - * @param glob is the verb glob name - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_verb_v3 - * @see afb_api_del_verb - * @see afb_api_set_verbs_v3 - * @see fnmatch for matching names using glob - */ -int afb_api_add_verb( - afb_api_t api, - const char *verb, - const char *info, - void (*callback)(struct afb_req_x2 *req), - void *vcbdata, - const struct afb_auth *auth, - uint32_t session, - int glob); -``` - -### afb_api_del_verb - -```C -/** - * Delete one verb from the dynamic set of the api - * - * @param api the api to change - * @param verb name of the verb to delete - * @param vcbdata if not NULL will receive the vcbdata of the deleted verb - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afb_api_add_verb - */ -int afb_api_del_verb( - afb_api_t api, - const char *verb, - void **vcbdata); -``` - -### afb_api_on_event - -```C -/** - * Set the callback 'onevent' to process events in the name of the 'api'. - * - * This setting can be done statically using the global variable - * @ref afbBindingV3. - * - * This function replace any previously global event callback set. - * - * When an event is received, the callback 'onevent' is called with 3 parameters - * - * - the api that recorded the event handler - * - the full name of the event - * - the companion JSON object of the event - * - * @param api the api that wants to process events - * @param onevent the callback function that will process events (can be NULL - * to remove event callback) - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afbBindingV3 - * @see afb_binding_v3 - * @see afb_api_event_handler_add - * @see afb_api_event_handler_del - */ -int afb_api_on_event( - afb_api_t api, - void (*onevent)( - afb_api_t api, - const char *event, - struct json_object *object)); -``` - -### afb_api_on_init - -```C -/** - * Set the callback 'oninit' to process initialization of the 'api'. - * - * This setting can be done statically using the global variable - * @ref afbBindingV3 - * - * This function replace any previously initialization callback set. - * - * This function is only valid during the pre-initialization stage. - * - * The callback initialization function will receive one argument: the api - * to initialize. - * - * @param api the api that wants to process events - * @param oninit the callback function that initialize the api - * - * @return 0 in case of success or -1 on failure with errno set - * - * @see afbBindingV3 - * @see afb_binding_v3 - */ -int afb_api_on_init( - afb_api_t api, - int (*oninit)(afb_api_t api)); -``` - -### afb_api_provide_class - -```C -/** - * Tells that the api provides a class of features. Classes are intended to - * allow ordering of initializations: apis that provides a given class are - * initialized before apis requiring it. - * - * This function is only valid during the pre-initialization stage. - * - * @param api the api that provides the classes - * @param name a space separated list of the names of the provided classes - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see afb_api_require_class - */ -int afb_api_provide_class( - afb_api_t api, - const char *name); -``` - -### afb_api_require_class - -```C -/** - * Tells that the api requires a set of class features. Classes are intended to - * allow ordering of initializations: apis that provides a given class are - * initialized before apis requiring it. - * - * This function is only valid during the pre-initialization stage. - * - * @param api the api that requires the classes - * @param name a space separated list of the names of the required classes - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see afb_api_provide_class - */ -int afb_api_require_class( - afb_api_t api, - const char *name); -``` - -### afb_api_seal - -```C -/** - * Seal the api. After a call to this function the api can not be modified - * anymore. - * - * @param api the api to be sealed - */ -void afb_api_seal( - afb_api_t api); -``` - -### afb_api_delete_api - -```C -/** - * Delete the given api. - * - * It is of the responsibility of the caller to don't used the deleted api - * anymore after this function returned. - * - * @param api the api to delete - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see afb_api_new_api - */ -int afb_api_delete_api( - afb_api_t api); -``` - -### afb_api_add_alias - -```C -/** - * Create an aliased name 'as_name' for the api 'name'. - * Calling this function is only allowed within preinit. - * - * @param api the api that requires the aliasing - * @param name the api to alias - * @param as_name the aliased name of the aliased api - * - * @return 0 in case of success or -1 in case of error with errno set appropriately. - */ -int afb_api_add_alias( - afb_api_t api, - const char *name, - const char *as_name); -``` - - -## Legacy functions - -The function for legacy calls are still provided for some time because -adaptation of existing code to the new call functions require a small amount -of work. - -### afb_api_call_legacy - -```C -/** - * @deprecated try to use @ref afb_api_call instead - * - * Calls the 'verb' of the 'apiname' with the arguments 'args' and 'verb' - * in the name of the binding. - * The result of the call is delivered to the 'callback' function - * with the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 3 arguments: - * 1. 'closure' the user defined closure pointer 'closure', - * 2. 'status' a status being 0 on success or negative when an error occurred, - * 2. 'result' the resulting data as a JSON object. - * - * @param api The api - * @param apiname The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param callback The to call on completion - * @param closure The closure to pass to the callback - * - * @see also 'afb_api_call' - * @see also 'afb_api_call_sync' - * @see also 'afb_api_call_sync_legacy' - * @see also 'afb_req_subcall' - * @see also 'afb_req_subcall_sync' - */ -void afb_api_call_legacy( - afb_api_t api, - const char *apiname, - const char *verb, - struct json_object *args, - void (*callback)( - void *closure, - int status, - struct json_object *result, - afb_api_t api), - void *closure); -``` - -### afb_api_call_sync_legacy - -```C -/** - * @deprecated try to use @ref afb_api_call_sync instead - * - * Calls the 'verb' of the 'apiname' with the arguments 'args' and 'verb' - * in the name of the binding. - * 'result' will receive the response. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param api The api - * @param apiname The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param result Where to store the result - should call json_object_put on it - - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see also 'afb_api_call' - * @see also 'afb_api_call_sync' - * @see also 'afb_api_call_legacy' - * @see also 'afb_req_subcall' - * @see also 'afb_req_subcall_sync' - */ -int afb_api_call_sync_legacy( - afb_api_t api, - const char *apiname, - const char *verb, - struct json_object *args, - struct json_object **result); -``` - -iv. FUNCTIONS OF CLASS **afb_req** -============================ - -## General function - -### afb_req_is_valid - -```C -/** - * Checks whether the request 'req' is valid or not. - * - * @param req the request to check - * - * @return 0 if not valid or 1 if valid. - */ -int afb_req_is_valid( - afb_req_t req); -``` - -### afb_req_get_api - -```C -/** - * Retrieves the api that serves the request - * - * @param req the request whose serving api is queried - * - * @return the api serving the request - */ -afb_api_t afb_req_get_api( - afb_req_t req); -``` - -### afb_req_get_vcbdata - -```C -/** - * Retrieves the callback data of the verb. This callback data is set - * when the verb is created. - * - * @param req whose verb vcbdata is queried - * - * @return the callback data attached to the verb description - */ -void *afb_req_get_vcbdata( - afb_req_t req); -``` - -### afb_req_get_called_api - -```C -/** - * Retrieve the name of the called api. - * - * @param req the request - * - * @return the name of the called api - * - * @see afb_api_new_api - * @see afb_api_add_alias - */ -const char *afb_req_get_called_api( - afb_req_t req); -``` - -### afb_req_get_called_verb - -```C -/** - * Retrieve the name of the called verb - * - * @param req the request - * - * @return the name of the called verb - */ -const char *afb_req_get_called_verb( - afb_req_t req); -``` - -### afb_req_addref - -```C -/** - * Increments the count of references of 'req'. - * - * @param req the request - * - * @return returns the request req - */ -afb_req_t *afb_req_addref( - afb_req_t req); -``` - -### afb_req_unref - -```C -/** - * Decrement the count of references of 'req'. - * - * @param req the request - */ -void afb_req_unref( - afb_req_t req); -``` - - -## Logging functions - -### afb_req_wants_log_level - -```C -/** - * Is the log message of 'level (as defined for syslog) required for the - * request 'req'? - * - * @param req the request - * @param level the level to check as defined for syslog: - * - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @return 0 if not required or a value not null if required - * - * @see syslog - */ -int afb_req_wants_log_level( - afb_req_t req, - int level); -``` - -### afb_req_vverbose - -```C -/** - * Send associated to 'req' a message described by 'fmt' and its 'args' - * to the journal for the verbosity 'level'. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @param req the request - * @param level the level of the message - * @param file the source filename that emits the message or NULL - * @param line the line number in the source filename that emits the message - * @param func the name of the function that emits the message or NULL - * @param fmt the message format as for printf - * @param args the arguments to the format - * - * @see printf - * @see afb_req_verbose - */ -void afb_req_vverbose( - afb_req_t req, - int level, const char *file, - int line, - const char * func, - const char *fmt, - va_list args); -``` - -### afb_req_verbose - -```C -/** - * Send associated to 'req' a message described by 'fmt' and following parameters - * to the journal for the verbosity 'level'. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - * - * @param req the request - * @param level the level of the message - * @param file the source filename that emits the message or NULL - * @param line the line number in the source filename that emits the message - * @param func the name of the function that emits the message or NULL - * @param fmt the message format as for printf - * @param ... the arguments of the format 'fmt' - * - * @see printf - */ -void afb_req_verbose( - afb_req_t req, - int level, const char *file, - int line, - const char * func, - const char *fmt, - ...); -``` - -## Arguments/parameters function - -### afb_req_get - -```C -/** - * Gets from the request 'req' the argument of 'name'. - * - * Returns a PLAIN structure of type 'struct afb_arg'. - * - * When the argument of 'name' is not found, all fields of result are set to NULL. - * - * When the argument of 'name' is found, the fields are filled, - * in particular, the field 'result.name' is set to 'name'. - * - * There is a special name value: the empty string. - * The argument of name "" is defined only if the request was made using - * an HTTP POST of Content-Type "application/json". In that case, the - * argument of name "" receives the value of the body of the HTTP request. - * - * @param req the request - * @param name the name of the argument to get - * - * @return a structure describing the retrieved argument for the request - * - * @see afb_req_value - * @see afb_req_path - */ -struct afb_arg afb_req_get( - afb_req_t req, - const char *name); -``` - -### afb_req_value - -```C -/** - * Gets from the request 'req' the string value of the argument of 'name'. - * Returns NULL if when there is no argument of 'name'. - * Returns the value of the argument of 'name' otherwise. - * - * Shortcut for: afb_req_get(req, name).value - * - * @param req the request - * @param name the name of the argument's value to get - * - * @return the value as a string or NULL - * - * @see afb_req_get - * @see afb_req_path - */ -const char *afb_req_value( - afb_req_t req, - const char *name); -``` - -### afb_req_path - -```C -/** - * Gets from the request 'req' the path for file attached to the argument of 'name'. - * Returns NULL if when there is no argument of 'name' or when there is no file. - * Returns the path of the argument of 'name' otherwise. - * - * Shortcut for: afb_req_get(req, name).path - * - * @param req the request - * @param name the name of the argument's path to get - * - * @return the path if any or NULL - * - * @see afb_req_get - * @see afb_req_value - */ -const char *afb_req_path( - afb_req_t req, - const char *name); -``` - -### afb_req_json - -```C -/** - * Gets from the request 'req' the json object hashing the arguments. - * - * The returned object must not be released using 'json_object_put'. - * - * @param req the request - * - * @return the JSON object of the query - * - * @see afb_req_get - * @see afb_req_value - * @see afb_req_path - */ -struct json_object *afb_req_json( - afb_req_t req); -``` - -## Reply functions - -The functions **success** and **fail** are still supported. -These functions are now implemented as the following macros: - -```C -#define afb_req_success(r,o,i) afb_req_reply(r,o,NULL,i) -#define afb_req_success_f(r,o,...) afb_req_reply_f(r,o,NULL,__VA_ARGS__) -#define afb_req_success_v(r,o,f,v) afb_req_reply_v(r,o,NULL,f,v) -#define afb_req_fail(r,e,i) afb_req_reply(r,NULL,e,i) -#define afb_req_fail_f(r,e,...) afb_req_reply_f(r,NULL,e,__VA_ARGS__) -#define afb_req_fail_v(r,e,f,v) afb_req_reply_v(r,NULL,e,f,v) -``` - - -### afb_req_reply - -```C -/** - * Sends a reply to the request 'req'. - * - * The status of the reply is set to 'error' (that must be NULL on success). - * Its send the object 'obj' (can be NULL) with an - * informational comment 'info (can also be NULL). - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param req the request - * @param obj the replied object or NULL - * @param error the error message if it is a reply error or NULL - * @param info an informative text or NULL - * - * @see afb_req_reply_v - * @see afb_req_reply_f - */ -void afb_req_reply( - afb_req_t req, - struct json_object *obj, - const char *error, - const char *info); -``` - -### afb_req_reply_v - -```C -/** - * Same as 'afb_req_reply_f' but the arguments to the format 'info' - * are given as a variable argument list instance. - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param req the request - * @param obj the replied object or NULL - * @param error the error message if it is a reply error or NULL - * @param info an informative text containing a format as for vprintf - * @param args the va_list of arguments to the format as for vprintf - * - * @see afb_req_reply - * @see afb_req_reply_f - * @see vprintf - */ -void afb_req_reply_v( - afb_req_t req, - struct json_object *obj, - const char *error, - const char *info, - va_list args); -``` - -### afb_req_reply_f - -```C -/** - * Same as 'afb_req_reply' but the 'info' is a formatting - * string followed by arguments. - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param req the request - * @param obj the replied object or NULL - * @param error the error message if it is a reply error or NULL - * @param info an informative text containing a format as for printf - * @param ... the arguments to the format as for printf - * - * @see afb_req_reply - * @see afb_req_reply_v - * @see printf - */ -void afb_req_reply_f( - afb_req_t req, - struct json_object *obj, - const char *error, - const char *info, - ...); -``` - -## Subcall functions - - - -### afb_req_subcall - -```C -/** - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the name of the binding. - * The result of the call is delivered to the 'callback' function with the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 5 arguments: - * 1. 'closure' the user defined closure pointer 'closure', - * 2. 'object' a JSON object returned (can be NULL) - * 3. 'error' a string not NULL in case of error - * 4. 'info' a string handling some info (can be NULL) - * 5. 'req' the req - * - * NOTE: For convenience, *json_object_put* is called on 'object' after the - * callback returns. So, it is wrong to call *json_object_put* in the callback. - * - * @param req The request - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param flags The bit field of flags for the subcall as defined by @ref afb_req_subcall_flags_t - * @param callback The to call on completion - * @param closure The closure to pass to the callback - * - * The flags are any combination of the following values: - * - * - afb_req_x2_subcall_catch_events = 1 - * - * the calling API wants to receive the events from subscription - * - * - afb_req_x2_subcall_pass_events = 2 - * - * the original request will receive the events from subscription - * - * - afb_req_x2_subcall_on_behalf = 4 - * - * the calling API wants to use the credentials of the original request - * - * - afb_req_x2_subcall_api_session = 8 - * - * the calling API wants to use its session instead of the one of the - * original request - * - * @see also 'afb_req_subcall_sync' - */ -void afb_req_subcall( - afb_req_t req, - const char *api, - const char *verb, - struct json_object *args, - int flags, - void (*callback)( - void *closure, - struct json_object *object, - const char *error, - const char * info, - afb_req_t req), - void *closure); -``` - -### afb_req_subcall_sync - -```C -/** - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * This call is synchronous, it waits untill completion of the request. - * It returns 0 on success or a negative value on error answer. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * See also: - * - 'afb_req_subcall_req' that is convenient to keep request alive automatically. - * - 'afb_req_subcall' that doesn't keep request alive automatically. - * - * @param req The request - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param flags The bit field of flags for the subcall as defined by @ref afb_req_subcall_flags - * @param object a pointer where the replied JSON object is stored must be freed using @ref json_object_put (can be NULL) - * @param error a pointer where a copy of the replied error is stored must be freed using @ref free (can be NULL) - * @param info a pointer where a copy of the replied info is stored must be freed using @ref free (can be NULL) - * - * @return 0 in case of success or -1 in case of error - */ -int afb_req_subcall_sync( - afb_req_t req, - const char *api, - const char *verb, - struct json_object *args, - int flags, - struct json_object **object, - char **error, - char **info); -``` - -## Event functions - -### afb_req_subscribe - -```C -/** - * Establishes for the client link identified by 'req' a subscription - * to the 'event'. - * - * Establishing subscription MUST be called BEFORE replying to the request. - * - * @param req the request - * @param event the event to subscribe - * - * @return 0 in case of successful subscription or -1 in case of error. - */ -int afb_req_subscribe( - afb_req_t req, - afb_event_t event); -``` - -### afb_req_unsubscribe - -```C -/** - * Revokes the subscription established to the 'event' for the client - * link identified by 'req'. - * Returns 0 in case of successful subscription or -1 in case of error. - * - * Revoking subscription MUST be called BEFORE replying to the request. - * - * @param req the request - * @param event the event to revoke - * - * @return 0 in case of successful subscription or -1 in case of error. - */ -int afb_req_unsubscribe( - afb_req_t req, - afb_event_t event); -``` - -## Session functions - -### afb_req_context - -```C -/** - * Manage the pointer stored by the binding for the client session of 'req'. - * - * If no previous pointer is stored or if 'replace' is not zero, a new value - * is generated using the function 'create_context' called with the 'closure'. - * If 'create_context' is NULL the generated value is 'closure'. - * - * When a value is created, the function 'free_context' is recorded and will - * be called (with the created value as argument) to free the created value when - * it is not more used. - * - * This function is atomic: it ensures that 2 threads will not race together. - * - * @param req the request - * @param replace if not zero an existing value is replaced - * @param create_context the creation function or NULL - * @param free_context the destroying function or NULL - * @param closure the closure to the creation function - * - * @return the stored value - */ -void *afb_req_context( - afb_req_t req, - int replace, - void *(*create_context)(void *closure), - void (*free_context)(void*), - void *closure); -``` - -### afb_req_context_get - -```C -/** - * Gets the pointer stored by the binding for the session of 'req'. - * When the binding has not yet recorded a pointer, NULL is returned. - * - * Shortcut for: afb_req_context(req, 0, NULL, NULL, NULL) - * - * @param req the request - * - * @return the previously stored value - */ -void *afb_req_context_get( - afb_req_t req); -``` - -### afb_req_context_set - -```C -/** - * Stores for the binding the pointer 'context' to the session of 'req'. - * The function 'free_context' will be called when the session is closed - * or if binding stores an other pointer. - * - * Shortcut for: afb_req_context(req, 1, NULL, free_context, context) - * - * - * @param req the request - * @param context the context value to store - * @param free_context the cleaning function for the stored context (can be NULL) - */ -void afb_req_context_set( - afb_req_t req, - void *context, - void (*free_context)(void*)); -``` - -### afb_req_context_clear - -```C -/** - * Frees the pointer stored by the binding for the session of 'req' - * and sets it to NULL. - * - * Shortcut for: afb_req_context_set(req, NULL, NULL) - * - * @param req the request - */ -void afb_req_context_clear( - afb_req_t req); -``` - -### afb_req_session_close - -```C -/** - * Closes the session associated with 'req' - * and delete all associated contexts. - * - * @param req the request - */ -void afb_req_session_close( - afb_req_t req); -``` - -### afb_req_session_set_LOA - -```C -/** - * Sets the level of assurance of the session of 'req' - * to 'level'. The effect of this function is subject of - * security policies. - * - * @param req the request - * @param level of assurance from 0 to 7 - * - * @return 0 on success or -1 if failed. - */ -int afb_req_session_set_LOA( - afb_req_t req, - unsigned level); -``` - -## Credential/client functions - -### afb_req_has_permission - -```C -/** - * Check whether the 'permission' is granted or not to the client - * identified by 'req'. - * - * @param req the request - * @param permission string to check - * - * @return 1 if the permission is granted or 0 otherwise. - */ -int afb_req_has_permission( - afb_req_t req, - const char *permission); -``` - -### afb_req_get_application_id - -```C -/** - * Get the application identifier of the client application for the - * request 'req'. - * - * Returns the application identifier or NULL when the application - * can not be identified. - * - * The returned value if not NULL must be freed by the caller - * - * @param req the request - * - * @return the string for the application id of the client MUST BE FREED - */ -char *afb_req_get_application_id( - afb_req_t req); -``` - -### afb_req_get_uid - -```C -/** - * Get the user identifier (UID) of the client for the - * request 'req'. - * - * @param req the request - * - * @return -1 when the application can not be identified or the unix uid. - * - */ -int afb_req_get_uid( - afb_req_t req); -``` - -### afb_req_get_client_info - -```C -/** - * Get informations about the client of the - * request 'req'. - * - * Returns an object with client informations: - * { - * "pid": int, "uid": int, "gid": int, - * "label": string, "id": string, "user": string, - * "uuid": string, "LOA": int - * } - * - * If some of this information can't be computed, the field of the return - * object will not be set at all. - * - * @param req the request - * - * @return a JSON object that must be freed using @ref json_object_put - */ -struct json_object *afb_req_get_client_info( - afb_req_t req); -``` - -## Legacy functions - -### afb_req_subcall_legacy - -```C -/** - * @deprecated use @ref afb_req_subcall - * - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * On completion, the function 'callback' is invoked with the - * 'closure' given at call and two other parameters: 'iserror' and 'result'. - * 'status' is 0 on success or negative when on an error reply. - * 'result' is the json object of the reply, you must not call json_object_put - * on the result. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param req the request - * @param api the name of the api to call - * @param verb the name of the verb to call - * @param args the arguments of the call as a JSON object - * @param callback the call back that will receive the reply - * @param closure the closure passed back to the callback - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - */ -void afb_req_subcall_legacy( - afb_req_t req, - const char *api, - const char *verb, - struct json_object *args, - void (*callback)( - void *closure, - int iserror, - struct json_object *result, - afb_req_t req), - void *closure); -``` - -### afb_req_subcall_sync_legacy - -```C -/** - * @deprecated use @ref afb_req_subcall_sync - * - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * This call is synchronous, it waits until completion of the request. - * It returns 0 on success or a negative value on error answer. - * The object pointed by 'result' is filled and must be released by the caller - * after its use by calling 'json_object_put'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param req the request - * @param api the name of the api to call - * @param verb the name of the verb to call - * @param args the arguments of the call as a JSON object - * @param result the pointer to the JSON object pointer that will receive the result - * - * @return 0 on success or a negative value on error answer. - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - */ -int afb_req_subcall_sync_legacy( - afb_req_t req, - const char *api, - const char *verb, - struct json_object *args, - struct json_object **result); -``` - -v. FUNCTIONS OF CLASS **afb_event** -============================== - -## General functions - -### afb_event_is_valid - -```C -/** - * Checks whether the 'event' is valid or not. - * - * @param event the event to check - * - * @return 0 if not valid or 1 if valid. - */ -int afb_event_is_valid( - afb_event_t event); -``` - -### afb_event_name - -```C -/** - * Gets the name associated to 'event'. - * - * @param event the event whose name is requested - * - * @return the name of the event - * - * The returned name can be used until call to 'afb_event_unref'. - * It shouldn't be freed. - */ -const char *afb_event_name( - afb_event_t event); -``` - -### afb_event_unref - -```C -/** - * Decrease the count of references to 'event'. - * Call this function when the evenid is no more used. - * It destroys the event_x2 when the reference count falls to zero. - * - * @param event the event - */ -void afb_event_unref( - afb_event_t event); -``` - -### afb_event_addref - -```C -/** - * Increases the count of references to 'event' - * - * @param event the event - * - * @return the event - */ -afb_event_t *afb_event_addref( - afb_event_t event); -``` - -## Pushing functions - -### afb_event_broadcast - -```C -/** - * Broadcasts widely an event of 'event' with the data 'object'. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param event the event to broadcast - * @param object the companion object to associate to the broadcasted event (can be NULL) - * - * @return 0 in case of success or -1 in case of error - */ -int afb_event_broadcast( - afb_event_t event, - struct json_object *object); -``` - -### afb_event_push - -```C -/** - * Pushes an event of 'event' with the data 'object' to its observers. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param event the event to push - * @param object the companion object to associate to the pushed event (can be NULL) - * - * @Return - * * 1 if at least one client listen for the event - * * 0 if no more client listen for the event - * * -1 in case of error (the event can't be delivered) - */ -int afb_event_push( - afb_event_t event, - struct json_object *object); -``` - -vi. FUNCTIONS OF CLASS **afb_daemon** -============================ - -All the functions of the class **afb_daemon** use the default api. -This are internally aliased to the corresponding function of class afb_api_t. - -```C -/** - * Retrieves the common systemd's event loop of AFB - */ -struct sd_event *afb_daemon_get_event_loop(); - -/** - * Retrieves the common systemd's user/session d-bus of AFB - */ -struct sd_bus *afb_daemon_get_user_bus(); - -/** - * Retrieves the common systemd's system d-bus of AFB - */ -struct sd_bus *afb_daemon_get_system_bus(); - -/** - * Broadcasts widely the event of 'name' with the data 'object'. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * Calling this function is only forbidden during preinit. - * - * Returns the count of clients that received the event. - */ -int afb_daemon_broadcast_event( - const char *name, - struct json_object *object); - -/** - * Creates an event of 'name' and returns it. - * - * Calling this function is only forbidden during preinit. - * - * See afb_event_is_valid to check if there is an error. - */ -afb_event_t afb_daemon_make_event( - const char *name); - -/** - * @deprecated use bindings version 3 - * - * Send a message described by 'fmt' and following parameters - * to the journal for the verbosity 'level'. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - */ -void afb_daemon_verbose( - int level, - const char *file, - int line, - const char * func, - const char *fmt, - ...); - -/** - * @deprecated use bindings version 3 - * - * Get the root directory file descriptor. This file descriptor can - * be used with functions 'openat', 'fstatat', ... - * - * Returns the file descriptor or -1 in case of error. - */ -int afb_daemon_rootdir_get_fd(); - -/** - * Opens 'filename' within the root directory with 'flags' (see function openat) - * using the 'locale' definition (example: "jp,en-US") that can be NULL. - * - * Returns the file descriptor or -1 in case of error. - */ -int afb_daemon_rootdir_open_locale( - const char *filename, - int flags, - const char *locale); - -/** - * Queue the job defined by 'callback' and 'argument' for being executed asynchronously - * in this thread (later) or in an other thread. - * If 'group' is not NUL, the jobs queued with a same value (as the pointer value 'group') - * are executed in sequence in the order of there submission. - * If 'timeout' is not 0, it represent the maximum execution time for the job in seconds. - * At first, the job is called with 0 as signum and the given argument. - * The job is executed with the monitoring of its time and some signals like SIGSEGV and - * SIGFPE. When a such signal is catched, the job is terminated and reexecuted but with - * signum being the signal number (SIGALRM when timeout expired). - * - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_queue_job( - void (*callback)(int signum, void *arg), - void *argument, - void *group, - int timeout); - -/** - * Tells that it requires the API of "name" to exist - * and if 'initialized' is not null to be initialized. - * Calling this function is only allowed within init. - * - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_require_api( - const char *name, - int initialized); - -/** - * Create an aliased name 'as_name' for the api 'name'. - * Calling this function is only allowed within preinit. - * - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_add_alias(const char *name, const char *as_name); - -/** - * Creates a new api of name 'api' with brief 'info'. - * - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_new_api( - const char *api, - const char *info, - int noconcurrency, - int (*preinit)(void*, struct afb_api_x3 *), - void *closure); -``` - -vii. FUNCTIONS OF CLASS **afb_service** -============================== - -All the functions of the class **afb_service** use the default api. - -All these function are deprecated, try to use functions of class **afb_api** instead. - -## afb_service_call - -```C -/** - * @deprecated try to use @ref afb_api_call instead - * - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the name of the binding. - * The result of the call is delivered to the 'callback' function with the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 5 arguments: - * 1. 'closure' the user defined closure pointer 'closure', - * 2. 'object' a JSON object returned (can be NULL) - * 3. 'error' a string not NULL in case of error but NULL on success - * 4. 'info' a string handling some info (can be NULL) - * 5. 'api' the api - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param callback The to call on completion - * @param closure The closure to pass to the callback - * - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - * @see afb_api_call_sync - */ -void afb_service_call( - const char *api, - const char *verb, - struct json_object *args, - void (*callback)( - void *closure, - struct json_object *object, - const char *error, - const char * info, - afb_api_t api), - void *closure); -``` - -## afb_service_call_sync - -```C -/** - * @deprecated try to use @ref afb_api_call_sync instead - * - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the name of the binding. - * 'result' will receive the response. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param object Where to store the returned object - should call json_object_put on it - can be NULL - * @param error Where to store the copied returned error - should call free on it - can be NULL - * @param info Where to store the copied returned info - should call free on it - can be NULL - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see afb_req_subcall - * @see afb_req_subcall_sync - * @see afb_api_call - */ -int afb_service_call_sync( - const char *api, - const char *verb, - struct json_object *args, - struct json_object **object, - char **error, - char **info); -``` - -## afb_service_call_legacy - -```C -/** - * @deprecated try to use @ref afb_api_call instead - * - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' - * in the name of the binding. - * The result of the call is delivered to the 'callback' function with - * the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 3 arguments: - * 1. 'closure' the user defined closure pointer 'closure', - * 2. 'status' a status being 0 on success or negative when an error occurred, - * 2. 'result' the resulting data as a JSON object. - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param callback The to call on completion - * @param closure The closure to pass to the callback - * - * @see also 'afb_api_call' - * @see also 'afb_api_call_sync' - * @see also 'afb_api_call_sync_legacy' - * @see also 'afb_req_subcall' - * @see also 'afb_req_subcall_sync' - */ -void afb_service_call_legacy( - const char *api, - const char *verb, - struct json_object *args, - void (*callback)( - void *closure, - int status, - struct json_object *result, - afb_api_t api), - void *closure); -``` - -## afb_service_call_sync_legacy - -```C -/** - * @deprecated try to use @ref afb_api_call_sync instead - * - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the - * name of the binding. 'result' will receive the response. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param result Where to store the result - should call json_object_put on it - - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see also 'afb_api_call' - * @see also 'afb_api_call_sync' - * @see also 'afb_api_call_legacy' - * @see also 'afb_req_subcall' - * @see also 'afb_req_subcall_sync' - */ -int afb_service_call_sync_legacy( - const char *api, - const char *verb, - struct json_object *args, - struct json_object **result); -``` \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/4_Binder_events_guide.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/4_Binder_events_guide.md deleted file mode 100644 index 57175a6..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/4_Binder_events_guide.md +++ /dev/null @@ -1,291 +0,0 @@ ---- -title: Binder events guide ---- - -Signaling agents are services that send events to any clients that -are subscribed to receive it. -The sent events carry any data. - -To have a good understanding of how to: - -- write a signaling agent. -- actions of subscribing. -- actions of unsubscribing. -- actions of producing. -- actions of sending and receiving. - -Events must be described and explained. - -## Overview of events - -The basis of a signaling agent is shown in the following figure: - -![scenario of using events](images/signaling-basis.svg) - -This figure shows the main role of the signaling framework for the events -propagation. - -For people not familiar with the framework, a signaling agent and -a “binding” are similar. - -### Subscribing and unsubscribing - -- Subscribing is the action that makes a client able to receive - data from a signaling agent. - -Subscription must : - -1. Create resources for generating the data. -2. Deliver the data to the client. - -These two aspects are not handled by the same piece of software. - -1. Generating the data is the responsibility of the developer of the signaling agent -2. Delivering the data is handled by the framework. - -When a client subscribes for data, the agent must: - -1. Check that the subscription request is correct. -2. Establish the computation chain of the required data (if not already done). -3. Create a named event for the computed data (if not already done). -4. Ask the framework to establish the subscription to the event for the request. -5. Optionally give indications about the event in the reply to the client. - -The first two steps do not involve the framework. -They are linked to the business logic of the binding. -The request can be any description of the requested data -and the computing stream can be of any nature, -this is specific to the binding. - -As said before, the framework uses and integrates **libsystemd** and its event -loop. -Within the framework, **libsystemd** is the standard API/library for -bindings expecting to setup and handle I/O, timer or signal events. - -Steps 3 and 4 are bound to the framework. - -The agent must create an object for handling the propagation of produced -data to its clients. -That object is called “event” in the framework. -An event has a name that allows clients to distinguish it from other -events. - -Events are created using the ***afb\_api\_make\_event*** function -that takes the api that creates the event and the name of the event. -Example: - -```C - event = afb_api_make_event(api, name); -``` - -Once created, the event can be used either to push data to its -subscribers or to broadcast data to any listener. - -The event must be used to establish the subscription for the requesting -client. -This is done using the ***afb\_req\_subscribe*** function -that takes the current request object and event and associates them -together. -Example: - -```C - rc = afb_req_subscribe(req, event); -``` - -When successful, this function make the connection between the event and -the client that emitted the request. -The client becomes a subscriber of the event until it unsubscribes or disconnects. -The ***afb\_req\_subscribe*** function will fail: - -- if the client connection is weak. -- if the request comes from a HTTP link. - -To receive signals, the client must be connected. - -The AGL framework allows connections using WebSocket. - -The name of the event is either a well known name or an ad hoc name -forged for the use case. - -Let's see a basic example: - -- client A expects to receive the speed in km/h every second. -- client B expects the speed in mph twice a second. - -In that case, there are two different events because it is not the same -unit and it is not the same frequency. -Having two different events allows to associate clients to the correct event. -But this doesn't tell any word about the name of these events. -The designer of the signaling agent has two options for naming: - -1. names can be the same (“speed” for example) with sent data - self describing itself or having a specific tag (requiring from - clients awareness about requesting both kinds of speed isn't safe). -2. names of the event include the variations (by example: - “speed-km/h-1Hz” and “speed-mph-2Hz”) and, in that case, sent data - can self describe itself or not. - -In both cases, the signaling agent might have to send the name of the -event and/or an associated tag to its client in the reply of the -subscription. -This is part of the step 5 above. - -The framework only uses the event (not its name) for: - -- subscription -- un-subscription -- pushing - -When the requested data is already generated and the event used for -pushing it already exists, the signaling agent must not instantiate a -new processing chain and must not create a new event object for pushing -data. -The signaling agent must reuse the existing chain and event. - -Unsubscribing is made by the signaling agent on a request of its client. -The ***afb\_req\_unsubscribe*** function tells the framework to -remove the requesting client from the event's list of subscribers. -Example: - -```C - afb_req_unsubscribe(req, event); -``` - -Subscription count does not matter to the framework: - -- Subscribing the same client several times has the same effect that subscribing only one time. - -Thus, when unsubscribing is invoked, it becomes immediately effective. - -#### More on naming events - -- Within the AGL framework, a signaling agent is a binding that has an API prefix. - -This prefix is meant to be unique and to identify the binding API. -The names of the events that this signaling agent creates are -automatically prefixed by the framework, using the API prefix of the -binding. - -Thus, if a signaling agent of API prefix ***api*** creates an event -of name ***event*** and pushes data to that event, the subscribers -will receive an event of name ***api/event***. - -### Generating and pushing signals and data - -- This of the responsibility of the designer of the signaling agent to establish the processing chain for generating events. - -In many cases, this can be achieved using I/O or timer or signal events inserted in the main loop. -For this case, the AGL framework uses **libsystemd** and -provide a way to integrates to the main loop of this library using -afb\_api\_get\_event\_loop. -Example: - -```C - sdev = afb_api_get_event_loop(api); - rc = sd_event_add_io(sdev, &source, fd, EPOLLIN, myfunction, NULL); -``` - -In some other cases, the events are coming from D-Bus. -In that case, the framework also uses **libsystemd** internally to access D-Bus. -It provides two methods to get the available D-Bus objects, already existing and -bound to the main **libsystemd** event loop. -Use either ***afb\_api\_get\_system\_bus*** or -***afb\_api\_get\_user\_bus*** to get the required instance. -Then use functions of **libsystemd** to handle D-Bus. - -In some rare cases, the generation of the data requires to start a new -thread. - -When a data is generated and ready to be pushed, the signaling agent -should call the function ***afb\_event\_push***. -Example: - -```C - rc = afb_event_push(event, JSON); - if (rc == 0) { - stop_generating(event); - afb_event_unref(event); - } -``` - -The function ***afb\_event\_push*** pushes json data to all the subscribers. -It then returns the count of subscribers. -When the count is zero, there is no subscriber listening for the event. -The example above shows that in that case, the signaling agent stops to -generate data for the event and tells that it doesn't use it anymore by calling -**afb\_event\_unref**. - -This is one possible option. -Other valuable options are: - -- do nothing and continue to generate and push the event. -- just stop to generate and push the data but keep the event existing. - -### Receiving the signals - -Understanding what a client expects when it receives signals, events or -data shall be the most important topic of the designer of a signaling -agent. -The good point here is that because JSON[^1] is the exchange -format, structured data can be sent in a flexible way. - -The good design is to allow as much as possible the client to describe -what is needed with the goal to optimize the processing to the -requirements only. - -### The exceptional case of wide broadcast - -Some data or events have so much importance that they can be widely -broadcasted to alert any listening client. -Examples of such an alert are: - -- system is entering/leaving “power safe” mode -- system is shutting down -- the car starts/stops moving -- ... - -An event can be broadcasted using one of the two following methods: - -- ***afb\_api\_broadcast\_event*** -- ***afb\_event\_broadcast*** - -Example 1: - -```C -afb_api_broadcast_event(api, name, json); -``` - -Example 2: - -```C -event = afb_api_make_event(api, name); -. . . . -afb_event_broadcast(event, json); -``` - -As for other events, the name of events broadcasted using -***afb\_api\_broadcast\_event*** are automatically prefixed by -the framework with API prefix. - -## Reference of functions - -See the [references for functions of class afb_event](3_Binder_References.md#v-FUNCTIONS-OF-CLASS-afb_event) - -### Function onevent (field of afbBindingExport) - -Binding can designate an event handling function using the field **onevent** -of the structure **afb_binding_t**. - -This function is called when an event is broadcasted or when an event that the -api subscribed to (through call or subcall mechanism) is pushed. -That behavior allows a service to react to an event and do what it is to do if -this is relevant for it. -(ie: car back camera detects imminent collision and broadcast it, then -appropriate service enable parking brake.). - -### Event handlers - -The apis functions allow to declare event handling callbacks. These callbacks are -called on reception of an event matching a pattern and a receive in more that -the event name and its companion JSON data, a user defiend closure and the api -that is used to create it. \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/5_Binder_Application_writing_guide.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/5_Binder_Application_writing_guide.md deleted file mode 100644 index 4886e5d..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/5_Binder_Application_writing_guide.md +++ /dev/null @@ -1,319 +0,0 @@ ---- -title: Binder Application writing guide ---- - -### Writing an HTML5 application - -Developers of HTML5 applications (client side) can easily create -applications for AGL framework using their preferred -HTML5 framework. - -Developers may also take advantage of powerful server side bindings to improve -application behavior. -Server side bindings return an application/json mine-type -and can be accessed though either HTTP or Websockets. - -In a near future, JSON-RPC protocol should be added to complete the current -x-afb-json1 protocol. - -Two examples of HTML5 applications are given: - -- [afb-client](https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-demo.git;a=tree;f=afb-client) a simple "hello world" application template - -- [afm-client](https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-demo.git;a=tree;f=afm-client) a simple "Home screen" application template - -### Writing a Qt application - -Writing Qt applications is also supported. -Qt offers standard API to send request through HTTP or WebSockets. - -It is also possible to write QML applications. -A sample QML application token-websock is available: - -- [token-websock](https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-binder.git;a=blob;f=test/token-websock.qml) - -A simple "hello world" application in QML - -### Writing a "C" application - -C applications can use afb-daemon binder through a websocket connection. - -The library **libafbwsc** is provided for C clients that need -to connect with an afb-daemon binder. - -The program **afb-client-demo** is the C example that uses the -**libafbwsc** library. -Source code is available here -[src/afb-client-demo.c](https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-binder.git;a=blob;f=src/afb-client-demo.c). - -Current implementation relies on libsystemd and file descriptors. -This model may be reviewed in the future to support secure sockets -and get rid of libsystemd dependency. - -### Handling sessions within applications - -Applications should understand sessions and token management when interacting -with afb-daemon binder. - -Applications communicate with their private binder (afb-daemon) using -a network connection or any other potential connection channel. -While the current version does not yet implement Unix socket, -this feature might be added in the near future. -Developers need to be warn that HTTP protocol is a none -connected protocol and that using HTTP socket connection to authenticate -clients is not supported. - -For this reason, the binder should authenticate the application -by using a shared secret. -The secret is named "token" and the identification of client is named "session.” - -The examples **token-websock.qml** and **afb-client** are demonstrating -how authentication and sessions are managed. - -### Handling sessions - -Bindings and other binder features need to keep track of client -instances. -This is especially important for bindings running as services -as they may typically have to keep each client's data separated. - -For HTML5 applications, the web runtime handles the cookie of the session -that the binder afb-daemon automatically sets. - -Session identifier can be set using the parameter **uuid** or **x-afb-uuid** in -URI requests. -Within current version of the framework session UUID is supported -by both HTTP requests and websocket negotiation. - -### Exchanging tokens - -At application start, AGL framework communicates a shared secret to both binder -and client application. -This initial secret is called the "**initial token**". - -For each of its client application, the binder manages a current active -token for session management. -This authentication token can be use to restrict the access to some binding's methods. - -The token must be included in URI request on HTTP or during websockets -connection using parameter **token** or **x-afb-token**. - -To ensure security, tokens must be refreshed periodically. - -### Example of session management - -In following examples, we suppose that **afb-daemon** is launched with something -equivalent to: - -```bash -afb-daemon --port=1234 --token=123456 [...] -``` - -making the expectation that **AuthLogin** binding is requested as default. - -#### Using curl - -First, connects with the initial token, 123456: - -```bash -$ curl http://localhost:1234/api/auth/connect?token=123456 -{ - "jtype": "afb-reply", - "request": { - "status": "success", - "token": "0aef6841-2ddd-436d-b961-ae78da3b5c5f", - "uuid": "850c4594-1be1-4e9b-9fcc-38cc3e6ff015" - }, - "response": {"token": "A New Token and Session Context Was Created"} -} -``` - -It returns an answer containing session UUID, 850c4594-1be1-4e9b-9fcc-38cc3e6ff015, -and a refreshed token, 850c4594-1be1-4e9b-9fcc-38cc3e6ff015. - -Check if session and token is valid: - -```bash -$ curl http://localhost:1234/api/auth/check?token=0aef6841-2ddd-436d-b961-ae78da3b5c5f\&uuid=850c4594-1be1-4e9b-9fcc-38cc3e6ff015 -{ - "jtype": "afb-reply", - "request": {"status":"success"}, - "response": {"isvalid":true} -} -``` - -Refresh the token: - -```bash -$ curl http://localhost:1234/api/auth/refresh?token=0aef6841-2ddd-436d-b961-ae78da3b5c5f\&uuid=850c4594-1be1-4e9b-9fcc-38cc3e6ff015 -{ - "jtype": "afb-reply", - "request": { - "status":"success", - "token":"b8ec3ec3-6ffe-448c-9a6c-efda69ad7bd9" - }, - "response": {"token":"Token was refreshed"} -} -``` - -Close the session: - -```bash -$ curl http://localhost:1234/api/auth/logout?token=b8ec3ec3-6ffe-448c-9a6c-efda69ad7bd9\&uuid=850c4594-1be1-4e9b-9fcc-38cc3e6ff015 -{ - "jtype": "afb-reply", - "request": {"status": "success"}, - "response": {"info":"Token and all resources are released"} -} -``` - -Checking on closed session for uuid should be refused: - -```bash -$ curl http://localhost:1234/api/auth/check?token=b8ec3ec3-6ffe-448c-9a6c-efda69ad7bd9\&uuid=850c4594-1be1-4e9b-9fcc-38cc3e6ff015 -{ - "jtype": "afb-reply", - "request": { - "status": "failed", - "info": "invalid token's identity" - } -} -``` - -#### Using afb-client-demo - -- The program is packaged within AGL in the rpm **libafbwsc-dev** - -Here is an example of exchange using **afb-client-demo**: - -```bash -$ afb-client-demo ws://localhost:1234/api?token=123456 -auth connect -ON-REPLY 1:auth/connect: {"jtype":"afb-reply","request":{"status":"success", - "token":"63f71a29-8b52-4f9b-829f-b3028ba46b68","uuid":"5fcc3f3d-4b84-4fc7-ba66-2d8bd34ae7d1"}, - "response":{"token":"A New Token and Session Context Was Created"}} -auth check -ON-REPLY 2:auth/check: {"jtype":"afb-reply","request":{"status":"success"},"response":{"isvalid":true}} -auth refresh -ON-REPLY 4:auth/refresh: {"jtype":"afb-reply","request":{"status":"success", - "token":"8b8ba8f4-1b0c-48fa-962d-4a00a8c9157e"},"response":{"token":"Token was refreshed"}} -auth check -ON-REPLY 5:auth/check: {"jtype":"afb-reply","request":{"status":"success"},"response":{"isvalid":true}} -auth refresh -ON-REPLY 6:auth/refresh: {"jtype":"afb-reply","request":{"status":"success", - "token":"e83b36f8-d945-463d-b983-5d8ed73ba529"},"response":{"token":"Token was refreshed"}} -``` - -After closing connection, reconnect as here after: - -```bash -$ afb-client-demo ws://localhost:1234/api?token=e83b36f8-d945-463d-b983-5d8ed73ba529\&uuid=5fcc3f3d-4b84-4fc7-ba66-2d8bd34ae7d1 auth check -ON-REPLY 1:auth/check: {"jtype":"afb-reply","request":{"status":"success"},"response":{"isvalid":true}} -``` - -Same connection check using **curl**: - -```bash -$ curl http://localhost:1234/api/auth/check?token=e83b36f8-d945-463d-b983-5d8ed73ba529\&uuid=5fcc3f3d-4b84-4fc7-ba66-2d8bd34ae7d1 -{"jtype":"afb-reply","request":{"status":"success"},"response":{"isvalid":true}} -``` - -### Format of replies - -Replies use javascript object returned as serialized JSON. - -This object contains at least 2 mandatory fields of name **jtype** and -**request** and one optional field of name **response**. - -#### Template of replies - -This is a template of replies: - -```json -{ - "jtype": "afb-reply", - "request": { - "status": "success", - "info": "informationnal text", - "token": "e83b36f8-d945-463d-b983-5d8ed73ba52", - "uuid": "5fcc3f3d-4b84-4fc7-ba66-2d8bd34ae7d1", - "reqid": "application-generated-id-23456" - }, - "response": ....any response object.... -} -``` - -#### Field jtype of replies - -The field **jtype** must have a value of type string equal to **"afb-reply"**. - -#### Field request of replies - -The field **request** must have a value of type object. -This request object has at least one field named **status** -and four optional fields named **info**, **token**, **uuid**, **reqid**. - -##### Subfield request.status - -**status** must have a value of type string. This string is equal to **"success"** -only in case of success. - -##### Subfield request.info - -**info** is of type string and represent optional information added to the reply. - -##### Subfield request.token - -**token** is of type string. It is sent either at session creation -or when the token is refreshed. - -##### Subfield request.uuid - -**uuid** is of type string. It is sent at session creation. - -##### Subfield request.reqid - -**reqid** is of type string. It is sent in response to HTTP requests -that added a parameter of name **reqid** or **x-afb-reqid** at request time. -Value returns in the reply has the exact same value as the one received in the -request. - -#### Field response of replies - -This field response optionally contains an object returned when request -succeeded. - -### Format of events - -Events are javascript object serialized as JSON. - -This object contains at least 2 mandatory fields of name **jtype** and **event** -and one optional field of name **data**. - -#### Template of event - -Here is a template of event: - -```json -{ - "jtype": "afb-event", - "event": "sample_api_name/sample_event_name", - "data": ...any event data... -} -``` - -#### Field jtype of event - -The field **jtype** must have a value of type string equal to **"afb-event"**. - -#### Field event of event - -The field **event** carries the event's name. - -The name of the event is made of two parts separated by a slash: -the name of the name of the API that generated the event -and the name of event within the API. - -#### Field data of event - -This field data if present holds the data carried by the event. \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/7_Document_revisions.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/7_Document_revisions.md deleted file mode 100644 index 06242ce..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/7_Document_revisions.md +++ /dev/null @@ -1,17 +0,0 @@ ---- -title: Document revisions ---- - -Document revisions - -| Date | Version | Designation  | Author | -|--------------|:----------:|----------------------------------------------|-------------------------------------------------------| -| 23 May 2016 | 0.9 | Initial release | J. Bollo [ IoT.bzh ]
M. Bachmann [ IoT.bzh ] | -| 30 May 2016 | 1.0 | Master document edition, final review | S. Desneux [ IoT.bzh ]
F. Ar Foll [ IoT.bzh ] | -| 21 Sept 2016 | 2.0 | Updated with new sections (events,widgets) | J. Bollo [ IoT.bzh ]
S. Desneux [ IoT.bzh ] | -| 12 Dec 2016 | 2.1 | Updated for CC Release | S. Desneux [ IoT.bzh ] | -| 14 Dec 2016 | 3.0 | Minor fixes, alignment with CC version | S. Desneux [ IoT.bzh ] | -| 20 Mar 2017 | 3.1 | Systemd integration | J. Bollo [ IoT.bzh ]
S. Desneux [ IoT.bzh ] | -| 21 Jun 2017 | 4.0 | Update for AGL DD | J. Bollo [ IoT.bzh ]
S. Desneux [ IoT.bzh ] | -| 21 Sep 2017 | 4.99-EERC1 | Update for AGL EE-RC1 | J. Bollo [ IoT.bzh ]
S. Desneux [ IoT.bzh ] | -| 14 Jun 2018 | 5.99-FFRC1 | Update for AGL FF-RC1 | J. Bollo [ IoT.bzh ] | diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/1_Migration_to_bindings_v3.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/1_Migration_to_bindings_v3.md deleted file mode 100644 index bba5354..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/1_Migration_to_bindings_v3.md +++ /dev/null @@ -1,199 +0,0 @@ ---- -title: Migration to bindings v3 ---- - -The ***binding*** interface evolved from version 1 to version 2 -for the following reasons: - -- integration of the security requirements within the bindings -- simplification of the API (after developer feedbacks) -- removal of obscure features and cleanup - -The ***binder*** can run ***bindings*** v1, v2 and/or v3 in any combination. -Thus moving from v1 or v2 to v3 is not enforced at this time. But ... - -In the face to face meeting in Karlsruhe it was decided to remove support -of bindings v1 and to deprecate the use of bindings v2. - -So at the end, **IT IS HIGHLY NEEDED TO SWITCH TO VERSION 3** - -This guide covers the migration of bindings from version 2 to version 3. - -The migration from version 1 is not treated here because bindings version 1 -are very old and probably do not exist anymore. If needed you can refer -to the old [guide to migrate bindings from v1 to v2](./6_LEGACY_Migration_from_v1_to_v2.md). - - -Differences between version 2 and version 3 -------------------------------------------- - -** *In v3 all is api.* ** - -The version 3 introduces the concept of "API" that gather what was called before -the daemon and the service. This is the new concept that predates the 2 others. - -The concept of API is intended to allow the definition of multiple APIs -by a same "binding" (a dynamically loaded library). - -Because there is potentially several "API", the functions that were without -context in bindings version 2 need now to tell what API is consumer. - -To be compatible with version 2, bindings v3 still have a default hidden -context: the default API named **afbBindingV3root**. - -To summarize, the functions of class **daemon** and **service** use the default -hidden API. - -It is encouraged to avoid use of functions of class **daemon** and **service**. -You should replace these implicit calls to explicit **api** calls that -reference **afbBindingV3root**. - -Same thing for the logging macros: **AFB_ERROR**, **AFB_WARNING**, -**AFB_NOTICE**, **AFB_INFO**, **AFB_DEBUG** that becomes respectively -**AFB_API_ERROR**, **AFB_API_WARNING**, **AFB_API_NOTICE**, **AFB_API_INFO**, -**AFB_API_DEBUG**. - -Example of 2 equivalent writes: - -```C - AFB_NOTICE("send stress event"); - afb_daemon_broadcast_event(stressed_event, NULL); -``` - -or - -```C - AFB_API_NOTICE(afbBindingV3root, "send stress event"); - afb_api_broadcast_event(afbBindingV3root, stressed_event, NULL); -``` - -**The reply mechanism predates success and fail. Subcall has more power.** - -Task list for the migration ---------------------------- - -This task list is: - -1. Use the automatic migration procedure described below -2. Adapt the functions **preinit**, **init** and **onevent** -3. Consider use of the new reply -4. Consider use of the new (sub)call -5. Consider use of event handlers - -The remaining chapters explain these task with more details. - -Automatic migration! --------------------- - -A tiny **sed** script is intended to perform a first pass on the code that -you want to upgrade. It can be done using **curl** and applied using **sed** -as below. - -```bash -BASE=https://git.automotivelinux.org/src/app-framework-binder/plain -SED=migration-to-binding-v3.sed -curl -o $SED $BASE/docs/$SED -sed -i -f $SED file1 file2 file3... -``` - -You can also follow -[this link](https://git.automotivelinux.org/src/app-framework-binder/plain/docs/migration-to-binding-v3.sed) -and save the file. - -This automatic action does most of the boring job but not all the job. -The remaining of this guide explains the missing part. - -Adapt the functions preinit, init and onevent ----------------------------------------------- - -The signature of the functions **preinit**, **init** and **onevent** changed -to include the target api. - -The functions of the v2: - -```C -int (*preinit)(); -int (*init)(); -void (*onevent)(const char *event, struct json_object *object); -``` - -Gain a new first argument of type **afb_api_t** as below: - -```C -int (*preinit)(afb_api_t api); -int (*init)(afb_api_t api); -void (*onevent)(afb_api_t api, const char *event, struct json_object *object); -``` - -For the migration, it is enough to just add the new argument without -using it. - -Consider use of the new reply ------------------------------ - -The v3 allows error reply with JSON object. To achieve it, an unified -reply function's family is introduced: - -```C -void afb_req_reply(afb_req_t req, json_object *obj, const char *error, const char *info); -void afb_req_reply_v(afb_req_t req, json_object *obj, const char *error, const char *info, va_list args); -void afb_req_reply_f(afb_req_t req, json_object *obj, const char *error, const char *info, ...); -``` - -The functions **success** and **fail** are still supported. -These functions are now implemented as the following macros: - - -```C -#define afb_req_success(r,o,i) afb_req_reply(r,o,NULL,i) -#define afb_req_success_f(r,o,...) afb_req_reply_f(r,o,NULL,__VA_ARGS__) -#define afb_req_success_v(r,o,f,v) afb_req_reply_v(r,o,NULL,f,v) -#define afb_req_fail(r,e,i) afb_req_reply(r,NULL,e,i) -#define afb_req_fail_f(r,e,...) afb_req_reply_f(r,NULL,e,__VA_ARGS__) -#define afb_req_fail_v(r,e,f,v) afb_req_reply_v(r,NULL,e,f,v) -``` - -This is a decision of the developer to switch to the new family -**afb_req_reply** or to keep the good old functions **afb_req_fail** -adn **afb_req_success**. - -Consider use of the new (sub)call ---------------------------------- - -The new call and subcall (the functions **afb_api_call**, **afb_api_call_sync**, -**afb_req_subcall** and **afb_req_subcall_sync**) functions are redesigned -to better fit the new reply behaviour. In most case the developer will benefit -of the new behavior that directly gives result and error without enforcing -to parse the JSON object result. - -The subcall functions are also fully redesigned to allow precise handling -of the context and event subscriptions. The new design allows you to specify: - - - whether the subcall is made in the session of the caller or in the session - of the service - - whether the credentials to use are those of the caller or those of the - service - - whether the caller or the service or both or none will receive the - eventually events during the subcall. - -See [calls](../3_Binder_References.md#afb_api_call) and -[subcalls](../3_Binder_References.md#subcall-functions). - -The table below list the changes to apply: - -| Name in Version 2 | New name of Version 3 -|:----------------------:|:----------------------------------------------------: -| afb_req_subcall | afb_req_subcall_legacy -| afb_req_subcall_sync | afb_req_subcall_sync_legacy -| afb_service_call | afb_service_call_legacy -| afb_service_call_sync | afb_service_call_sync_legacy -| afb_req_subcall_req | afb_req_subcall_req (same but obsolete) - - -Consider use of event handlers ------------------------------- - -Binding V3 brings new ways of handling event in services. You can register -functions that will handle specific events and that accept closure arguments. - -See [**afb_api_event_handler_add** and **afb_api_event_handler_del**](../3_Binder_References.md#event-functions) \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/2_WebSocket_protocol_x-afb-ws-json1.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/2_WebSocket_protocol_x-afb-ws-json1.md deleted file mode 100644 index 7ebf22a..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/2_WebSocket_protocol_x-afb-ws-json1.md +++ /dev/null @@ -1,308 +0,0 @@ ---- -title: WebSocket protocol x-afb-ws-json1 ---- - -The WebSocket protocol *x-afb-ws-json1* is used to communicate between -an application and a binder. It allows access to all registered apis -of the binder. - -This protocol is inspired from the protocol **OCPP - SRPC** as described for -example here: -[OCPP transport specification - SRPC over WebSocket](http://www.gir.fr/ocppjs/ocpp_srpc_spec.shtml). - -The registration to the IANA is still to be done, see: -[WebSocket Protocol Registries](https://www.iana.org/assignments/websocket/websocket.xml) - -This document gives a short description of the protocol *x-afb-ws-json1*. -A more formal description has to be done. - -## Architecture - -The protocol is intended to be symmetric. It allows: - -- to CALL a remote procedure that returns a result -- to push and receive EVENT - -## Messages - -Valid messages are made of *text* frames that are all valid JSON. - -Valid messages are: - -Calls: - -```txt -[ 2, ID, PROCN, ARGS ] -[ 2, ID, PROCN, ARGS, TOKEN ] -``` - -Replies (3: OK, 4: ERROR): - -```txt -[ 3, ID, RESP ] -[ 4, ID, RESP ] -``` - -Events: - -```txt -[ 5, EVTN, OBJ ] -``` - -Where: - -| Field | Type | Description -|-------|--------|------------------ -| ID | string | A string that identifies the call. A reply to that call use the ID of the CALL. -| PROCN | string | The procedure name to call of the form "api/verb" -| ARGS | any | Any argument to pass to the call (see afb_req_json that returns it) -| RESP | any | The response to the call -| TOKEN | string | The authorisation token -| EVTN | string | Name of the event in the form "api/event" -| OBJ | any | The companion object of the event - -Below, an example of exchange: - -```txt -C->S: [2,"156","hello/ping",null] -S->C: [3,"156",{"response":"Some String","jtype":"afb-reply","request":{"status":"success","info":"Ping Binder Daemon tag=pingSample count=1 query=\"null\"","uuid":"ec30120c-6997-4529-9d63-c0de0cce56c0"}}] -``` - -## History - -### 14 November 2019 - -Removal of token returning. The replies - -```txt -[ 3, ID, RESP, TOKEN ] -[ 4, ID, RESP, TOKEN ] -``` - -are removed from the specification. - -## Future - -Here are the planned extensions: - -- add binary messages with cbor data -- add calls with unstructured replies - -This could be implemented by extending the current protocol or by -allowing the binder to accept either protocol including the new ones. - -## Javascript implementation - -The file **AFB.js** is a javascript implementation of the protocol. - -Here is that code: - -```javascript -/* - * Copyright (C) 2017-2019 "IoT.bzh" - * Author: José Bollo - * - * 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. - */ -AFB = function(base, initialtoken){ - -if (typeof base != "object") - base = { base: base, token: initialtoken }; - -var initial = { - base: base.base || "api", - token: base.token || initialtoken || "HELLO", - host: base.host || window.location.host, - url: base.url || undefined -}; - -var urlws = initial.url || "ws://"+initial.host+"/"+initial.base; - -/*********************************************/ -/**** ****/ -/**** AFB_context ****/ -/**** ****/ -/*********************************************/ -var AFB_context; -{ - var UUID = undefined; - var TOKEN = initial.token; - - var context = function(token, uuid) { - this.token = token; - this.uuid = uuid; - } - - context.prototype = { - get token() {return TOKEN;}, - set token(tok) {if(tok) TOKEN=tok;}, - get uuid() {return UUID;}, - set uuid(id) {if(id) UUID=id;} - }; - - AFB_context = new context(); -} -/*********************************************/ -/**** ****/ -/**** AFB_websocket ****/ -/**** ****/ -/*********************************************/ -var AFB_websocket; -{ - var CALL = 2; - var RETOK = 3; - var RETERR = 4; - var EVENT = 5; - - var PROTO1 = "x-afb-ws-json1"; - - AFB_websocket = function(on_open, on_abort) { - var u = urlws; - if (AFB_context.token) { - u = u + '?x-afb-token=' + AFB_context.token; - if (AFB_context.uuid) - u = u + '&x-afb-uuid=' + AFB_context.uuid; - } - this.ws = new WebSocket(u, [ PROTO1 ]); - this.url = u; - this.pendings = {}; - this.awaitens = {}; - this.counter = 0; - this.ws.onopen = onopen.bind(this); - this.ws.onerror = onerror.bind(this); - this.ws.onclose = onclose.bind(this); - this.ws.onmessage = onmessage.bind(this); - this.onopen = on_open; - this.onabort = on_abort; - } - - function onerror(event) { - var f = this.onabort; - if (f) { - delete this.onopen; - delete this.onabort; - f && f(this); - } - this.onerror && this.onerror(this); - } - - function onopen(event) { - var f = this.onopen; - delete this.onopen; - delete this.onabort; - f && f(this); - } - - function onclose(event) { - for (var id in this.pendings) { - try { this.pendings[id][1](); } catch (x) {/*TODO?*/} - } - this.pendings = {}; - this.onclose && this.onclose(); - } - - function fire(awaitens, name, data) { - var a = awaitens[name]; - if (a) - a.forEach(function(handler){handler(data);}); - var i = name.indexOf("/"); - if (i >= 0) { - a = awaitens[name.substring(0,i)]; - if (a) - a.forEach(function(handler){handler(data);}); - } - a = awaitens["*"]; - if (a) - a.forEach(function(handler){handler(data);}); - } - - function reply(pendings, id, ans, offset) { - if (id in pendings) { - var p = pendings[id]; - delete pendings[id]; - try { p[offset](ans); } catch (x) {/*TODO?*/} - } - } - - function onmessage(event) { - var obj = JSON.parse(event.data); - var code = obj[0]; - var id = obj[1]; - var ans = obj[2]; - AFB_context.token = obj[3]; - switch (code) { - case RETOK: - reply(this.pendings, id, ans, 0); - break; - case RETERR: - reply(this.pendings, id, ans, 1); - break; - case EVENT: - default: - fire(this.awaitens, id, ans); - break; - } - } - - function close() { - this.ws.close(); - this.ws.onopen = - this.ws.onerror = - this.ws.onclose = - this.ws.onmessage = - this.onopen = - this.onabort = function(){}; - } - - function call(method, request, callid) { - return new Promise((function(resolve, reject){ - var id, arr; - if (callid) { - id = String(callid); - if (id in this.pendings) - throw new Error("pending callid("+id+") exists"); - } else { - do { - id = String(this.counter = 4095 & (this.counter + 1)); - } while (id in this.pendings); - } - this.pendings[id] = [ resolve, reject ]; - arr = [CALL, id, method, request ]; - if (AFB_context.token) arr.push(AFB_context.token); - this.ws.send(JSON.stringify(arr)); - }).bind(this)); - } - - function onevent(name, handler) { - var id = name; - var list = this.awaitens[id] || (this.awaitens[id] = []); - list.push(handler); - } - - AFB_websocket.prototype = { - close: close, - call: call, - onevent: onevent - }; -} -/*********************************************/ -/**** ****/ -/**** ****/ -/**** ****/ -/*********************************************/ -return { - context: AFB_context, - ws: AFB_websocket -}; -}; -``` diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/3_Installing_the_binder_on_a_desktop.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/3_Installing_the_binder_on_a_desktop.md deleted file mode 100644 index 8874bde..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/3_Installing_the_binder_on_a_desktop.md +++ /dev/null @@ -1,44 +0,0 @@ ---- -title: Installing the binder on a desktop ---- - -Packages of the ***binder*** (afb-daemon)exist -for common desktop linux distributions. - -- Fedora -- Ubuntu -- Debian -- Suse - -Installing the development package of the ***binder*** -allows to write ***bindings*** that runs on the desktop -computer of the developer. - -It is very convenient to quickly write and debug a binding. - -## Retrieving compiling option with pkg-config - -The ***binder*** afb-daemon provides a configuration -file for **pkg-config**. -Typing the command - -```bash -pkg-config --cflags afb-daemon -``` - -Print flags use for compilation: - -```bash -$ pkg-config --cflags afb-daemon --I/opt/local/include -I/usr/include/json-c -``` - -For linking, you should use - -```bash -$ pkg-config --libs afb-daemon --ljson-c -``` - -It automatically includes the dependency to json-c. -This is activated through **Requires** keyword in pkg-config. diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/4_Options_of_afb-daemon.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/4_Options_of_afb-daemon.md deleted file mode 100644 index 0b58eec..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/4_Options_of_afb-daemon.md +++ /dev/null @@ -1,355 +0,0 @@ ---- -title: Options of afb-daemon ---- - -The launch options for binder **afb-daemon** are: - -``` - -v, --verbose Verbose Mode, repeat to increase verbosity - -c, --color Colorize the ouput - -q, --quiet Quiet Mode, repeat to decrease verbosity - -l, --log=xxxx Tune log level - --foreground Get all in foreground mode - --background Get all in background mode - -D, --daemon Get all in background mode - -n, --name=xxxx Set the visible name - -p, --port=xxxx HTTP listening TCP port [default 1234] - --roothttp=xxxx HTTP Root Directory [default no root http (files not served but apis still available)] - --rootbase=xxxx Angular Base Root URL [default /opa] - --rootapi=xxxx HTML Root API URL [default /api] - --alias=xxxx Multiple url map outside of rootdir [eg: --alias=/icons:/usr/share/icons] - --apitimeout=xxxx Binding API timeout in seconds [default 20] - --cntxtimeout=xxxx Client Session Context Timeout [default 32000000] - --cache-eol=xxxx Client cache end of live [default 100000] - -w, --workdir=xxxx Set the working directory [default: $PWD or current working directory] - -u, --uploaddir=xxxx Directory for uploading files [default: workdir] relative to workdir - --rootdir=xxxx Root Directory of the application [default: workdir] relative to workdir - --ldpaths=xxxx Load bindings from dir1:dir2:... [default: path of afb-dbus-binding.so] - -b, --binding=xxxx Load the binding of path - --weak-ldpaths=xxxx Same as --ldpaths but ignore errors - --no-ldpaths Discard default ldpaths loading - -t, --token=xxxx Initial Secret [default=random, use --token= to allow any token] - -r, --random-token Enforce a random token - -V, --version Display version and copyright - -h, --help Display this help - --ws-client=xxxx Bind to an afb service through websocket - --ws-server=xxxx Provide an afb service through websockets - -A, --auto-api=xxxx Automatic load of api of the given directory - --session-max=xxxx Max count of session simultaneously [default 200] - --tracereq=xxxx Log the requests: no, common, extra, all - --traceevt=xxxx Log the events: no, common, extra, all - --traceses=xxxx Log the sessions: no, all - --traceapi=xxxx Log the apis: no, common, api, event, all - --traceglob=xxxx Log the globals: none, all - --traceditf=xxxx Log the daemons: no, common, all - --tracesvc=xxxx Log the services: no, all - --call=xxxx call at start, format of val: API/VERB:json-args - --no-httpd Forbid HTTP service - -e, --exec Execute the remaining arguments - -M, --monitoring Enable HTTP monitoring at /monitoring/ - -C, --config=xxxx Load options from the given config file - -Z, --dump-config Dump the config to stdout and exit - -s, --set=xxxx Set parameters ([API]/[KEY]:JSON or {"API":{"KEY":JSON}} - -o, --output=xxxx Redirect stdout and stderr to output file (when --daemon) - --trap-faults=xxxx Trap faults: on, off, yes, no, true, false, 1, 0 (default: true) -``` - -## help - -Prints help with available options - -## version - -Display version and copyright - -## verbose - -Increases the verbosity, can be repeated - -## color - -Add basic colorization to the ouput. - -## quiet - -Decreases the verbosity, can be repeated - -## log=xxxx - -Tune the log level mask. The levels are: - - - error - - warning - - notice - - info - - debug - -The level can be set using + or -. - -| Examples | descritpion -|-----------------|------------------- -| error,warning | selects only the levels error and warning -| +debug | adds level debug to the current verbosity -| -warning | remove the level warning from the current verbosity -| +warning-debug,info | Adds error and remove errors and warnings - -## port=xxxx - -HTTP listening TCP port [default 1234] - -## workdir=xxxx - -Directory where the daemon must run [default: $PWD if defined -or the current working directory] - -## uploaddir=xxxx - -Directory where uploaded files are temporarily stored [default: workdir] - -## rootdir=xxxx - -Root directory of the application to serve [default: workdir] - -## roothttp=xxxx - -Directory of HTTP served files. If not set, files are not served -but apis are still accessible. - -## rootbase=xxxx - -Angular Base Root URL [default /opa] - -This is used for any application of kind OPA (one page application). -When set, any missing document whose url has the form /opa/zzz -is translated to /opa/#!zzz - -## rootapi=xxxx - -HTML Root API URL [default /api] - -The bindings are available within that url. - -## alias=xxxx - -Maps a path located anywhere in the file system to the -a subdirectory. The syntax for mapping a PATH to the -subdirectory NAME is: --alias=/NAME:PATH. - -Example: --alias=/icons:/usr/share/icons maps the -content of /usr/share/icons within the subpath /icons. - -This option can be repeated. - -## apitimeout=xxxx - -binding API timeout in seconds [default 20] - -Defines how many seconds maximum a method is allowed to run. -0 means no limit. - -## cntxtimeout=xxxx - -Client Session Timeout in seconds [default 32000000 that is 1 year] - -## cache-eol=xxxx - -Client cache end of live [default 100000 that is 27,7 hours] - -## session-max=xxxx - -Maximum count of simultaneous sessions [default 200] - -## ldpaths=xxxx - -Load bindings from given paths separated by colons -as for dir1:dir2:binding1.so:... [default = $libdir/afb] - -You can mix path to directories and to bindings. -The sub-directories of the given directories are searched -recursively. - -The bindings are the files terminated by '.so' (the extension -so denotes shared object) that contain the public entry symbol. - -## weak-ldpaths=xxxx - -Same as --ldpaths but instead of stopping on error, ignore errors and continue. - -## binding=xxxx - -Load the binding of given path. - -## token=xxxx - -Initial Secret token to authenticate. - -If not set, no client can authenticate. - -If set to the empty string, then any initial token is accepted. - -## random-token - -Generate a random starting token. See option --exec. - -## ws-client=xxxx - -Transparent binding to a binder afb-daemon service through a WebSocket. - -The value of xxxx is either a unix naming socket, of the form "unix:path/api", -or an internet socket, of the form "host:port/api". - -## ws-server=xxxx - -Provides a binder afb-daemon service through WebSocket. - -The value of xxxx is either a unix naming socket, of the form "unix:path/api", -or an internet socket, of the form "host:port/api". - -## foreground - -Get all in foreground mode (default) - -## daemon - -Get all in background mode - -## no-httpd - -Forbids HTTP serve - -## exec - -Must be the last option for afb-daemon. The remaining -arguments define a command that afb-daemon will launch. -The sequences @p, @t and @@ of the arguments are replaced -with the port, the token and @. - -## tracereq=xxxx - -Trace the processing of requests in the log file. - -Valid values are 'no' (default), 'common', 'extra' or 'all'. - -## traceapi=xxxx - -Trace the accesses to functions of class api. - -Valid values are 'no' (default), 'common', 'api', 'event' or 'all'. - -## traceevt=xxxx - -Trace the accesses to functions of class event. - -Valid values are 'no' (default), 'common', 'extra' or 'all'. - -## call=xxx - -Call a binding at start (can be be repeated). -The values are given in the form API/VERB:json-args. - -Example: --call 'monitor/set:{"verbosity":{"api":"debug"}}' - -## monitoring - -Enable HTTP monitoring at /monitoring/ - -## name=xxxx - -Set the visible name - -## auto-api=xxxx - -Automatic activation of api of the given directory when the api is missing. - -## config=xxxx - -Load options from the given config file - -This can be used instead of arguments on the command line. - -Example: - - afb-daemon \ - --no-ldpaths \ - --binding /home/15646/bindings/binding45.so \ - --binding /home/15646/bindings/binding3.so \ - --tracereq common \ - --port 5555 \ - --token SPYER \ - --set api45/key:54027a5e3c6cb2ca5ddb97679ce32f185b067b0a557d16a8333758910bc25a72 \ - --exec /home/15646/bin/test654 @p @t - -is equivalent to: - - afb-daemon --config /home/15646/config1 - -when the file **/home/15646/config1** is: - - { - "no-ldpaths": true, - "binding": [ - "\/home\/15646\/bindings\/binding45.so", - "\/home\/15646\/bindings\/binding3.so" - ], - "tracereq": "common", - "port": 5555, - "token": "SPYER", - "set" : { - "api45": { - "key": "54027a5e3c6cb2ca5ddb97679ce32f185b067b0a557d16a8333758910bc25a72" - } - }, - "exec": [ - "\/home\/15646\/bin\/test654", - "@p", - "@t" - ] - } - -The options are the keys of the config object. - -See option --dump-config - -## dump-config - -Output a JSON representation of the configuration resulting from -environment and options. - -## output=xxxx - -Redirect stdout and stderr to output file - -## set=xxxx - -Set values that can be retrieved by bindings. - -The set value can have different formats. - -The most generic format is **{"API1":{"KEY1":VALUE,"KEY2":VALUE2,...},"API2":...}** - -This example set 2 keys for the api *chook*: - - afb-daemon -Z --set '{"chook":{"account":"urn:chook:b2ca5ddb97679","delay":500}}' - { - "set": { - "chook": { - "account": "urn:chook:b2ca5ddb97679", - "delay": 500 - } - } - } - -An other format is: **[API]/[KEY]:VALUE**. -When API is omitted, it take the value " * ". -When KEY is ommitted, it take the value of " * ". - -The settings for the API \* are globals and apply to all bindings. - -The settings for the KEY \* are mixing the value for the API. - -The following examples are all setting the same values: - - afb-daemon --set '{"chook":{"account":"urn:chook:b2ca5ddb97679","delay":500}}' - afb-daemon --set 'chook/*:{"account":"urn:chook:b2ca5ddb97679","delay":500}' - afb-daemon --set 'chook/:{"account":"urn:chook:b2ca5ddb97679","delay":500}' - afb-daemon --set 'chook/account:"urn:chook:b2ca5ddb97679"' --set chook/delay:500 \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/5_Debugging_binder_and_bindings.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/5_Debugging_binder_and_bindings.md deleted file mode 100644 index dbb9bdd..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/5_Debugging_binder_and_bindings.md +++ /dev/null @@ -1,38 +0,0 @@ ---- -title: Debugging binder and bindings ---- - -When compiled with the symbol AGL_DEVEL defined, the ***binder*** -understands the 2 configuration variables: - - - AFB_DEBUG_BREAK: to emit interrupts - - AFB_DEBUG_WAIT: to wait interrupts - -To use these variables, assign it the list of break or wait points -to reach. - -Example: - -```bash -$ AFB_DEBUG_BREAK=main-entry AFB_DEBUG_WAIT=start-load,start-exec afb-daemon .... -``` - -This tells to ***afb-daemon*** to break at the point **main-entry** and to -wait at the points **start-load** and **start-exec**. - -The items of the list can be separated using comma, space, tab or new-line. - -The break/wait points are, in the order of their occurrence: - -- main-entry: before decode arguments -- main-args: before daemon setup -- main-start: before starting jobs -- start-entry: before initialisation of sessions and hooks -- start-load: before load and pre-init of bindings -- start-start: before init of bindings -- start-http: before start of http server -- start-call: before execution of requests of the command line (option --call) -- start-exec: before execution of child preocees - -Note also that a call to 'personality' is inserted just after -the point start-start. \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/6_LEGACY_Migration_from_v1_to_v2.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/6_LEGACY_Migration_from_v1_to_v2.md deleted file mode 100644 index 6004aec..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/6_LEGACY_Migration_from_v1_to_v2.md +++ /dev/null @@ -1,656 +0,0 @@ ---- -title: LEGACY Migration from v1 to v2 ---- - -> LEGACY!!! IT IS NOT EXPECTED THAT YOU STILL NEED THIS GUIDE. -> -> THIS GUIDE WILL BE REMOVED IN A NEAR FUTURE - - -The ***binding*** interface evolved from version 1 to version 2 -for the following reasons: - -- integration of the security requirements within the bindings -- simplification of the API (after developer feedbacks) -- removal of obscure features, cleanup - -The ***binder*** can run ***bindings*** v1 and/or v2 in any combination. -Thus moving from v1 to v2 is not enforced, there is no real need. - -More, it is possible to write a dual ***binding***: - -- a ***binding*** that implements the version 1 and the version 2. - -However, IT IS HIGHLY RECOMMENDED TO SWITCH TO ONLY VERSION 2: - -- any new development SHOULD start using ***binding*** V2 -- existing ***bindings*** SHOULD migrate to the version 2 - -This guide covers the migration of bindings from version 1 to version 2. - -It also explains some of the rationale taken when migrating from version 1 to version 2. - -In the future, if ***binding*** api evolves to fresh versions (3, 4, ...) -it might be necessarily to write bindings implementing more than -just one version. -For example: - -- a ***binding*** being v2 AND v3 will resolve the issue of running on older and newer version of AGL. - -This should always be possible even if more complicated. - -Important things to known when migrating ----------------------------------------- - -One of the most important change when migrating from v1 to v2 is -that many functions use an hidden *common* variable. -This affects the functions of the following classes: - -- functions of class **daemon**: - - functions starting with **afb_daemon_...** - - functions for logging: **ERROR**, **WARNING**, **NOTICE**, **INFO**, **DEBUG** -- functions of class **service**: - - functions starting with **afb_service_...** -- callback functions: - - the register function (that is removed) - - the service init function - - the onevent function - -For these functions, the first parameter is now implicit. - -Let takes an example. -For ***binding*** v1 you had to write: - -```C - afb_daemon_broadcast_event(afbitf->daemon, reason, description); -``` - -For ***binding*** v2, you simply write: - -```C - afb_daemon_broadcast_event(reason, description); -``` - -This simplification is possible because the header files included for the bindings -now provide a common variable for storing the **daemon** and **service** data. - -As a programmer, you shouldn't care much about that hidden variable. -It simplifies the job, that's all and that is the reason of the change. - -An other important difference is between the version 1 and the version 2 is -on how the ***binding***'s **API** is documented. -The version 2 emphasis the **OpenAPI v3** description of the **API**. -For this reason, to avoid duplication of descriptions, only one description is expected: - -- The **OpenAPI** one. - -Task list for the migration ---------------------------- - -This task list is: - -1. Enforce use of binding v2 by setting **AFB_BINDING_VERSION** -2. Rewrite the main structure and the list of exported verbs -3. Adapt the init and callback functions -4. Removes the first parameter of functions of classes **daemon** and **service** -5. Consider where to emit logs for requests -6. Take care of store/unstore changes -7. Consider use of synchronous (sub)call requests -8. Optionally, removes explicit struct - -The remaining chapters explain these task with more details. - -Enforce use of binding v2 by setting AFB_BINDING_VERSION --------------------------------------------------------- - -By defining **AFB_BINDING_VERSION** to **2** you switch to version 2. -This is done as below. - -```C -#define AFB_BINDING_VERSION 2 -#include -``` - -After that you will get many errors when compiling. - -Rewrite the main structures and the list of exported verbs ---------------------------------------------------------- - -The structures describing the ***binding** changed from version 1 to version 2. - -The structure for describing verbs changed to include security -requirements. - -In version 1 it was: - -```C -struct afb_verb_desc_v1 -{ - const char *name; /* name of the verb */ - enum afb_session_flags_v1 session; /* authorization and session requirements of the verb */ - void (*callback)(struct afb_req req); /* callback function implementing the verb */ - const char *info; /* textual description of the verb */ -}; -``` - -In version 2 it becomes: - -```C -struct afb_verb_v2 -{ - const char *verb; /* name of the verb */ - void (*callback)(struct afb_req req); /* callback function implementing the verb */ - const struct afb_auth *auth; /* required authorization */ - uint32_t session; /* authorization and session requirements of the verb */ -}; - -``` - -The migration of instances of that structure requires the following actions: - -- rename field **name** to **verb** -- remove field **info** -- adapt field **session** if needed -- set field **auth** to NULL - -Example: - -```C - { .name= "new", .session= AFB_SESSION_NONE, .callback= new, .info= "Starts a new game" } -``` - -Becomes - -```C - { .verb = "new", .session = AFB_SESSION_NONE, .callback = new, .auth = NULL } -``` - -The field **auth** can be set to a value describing the requested -authorization. - -The main describing structure also changed. - -In version 1 it was: - -```C -struct afb_binding_desc_v1 -{ - const char *info; /* textual information about the binding */ - const char *prefix; /* required prefix name for the binding */ - const struct afb_verb_desc_v1 *verbs; /* array of descriptions of verbs terminated by a NULL name */ -}; -``` - -In version 2 it becomes: - -```C -struct afb_binding_v2 -{ - const char *api; /* api name for the binding */ - const char *specification; /* textual specification of the binding */ - const struct afb_verb_v2 *verbs; /* array of descriptions of verbs terminated by a NULL name */ - int (*preinit)(); /* callback at load of the binding */ - int (*init)(); /* callback for starting the service */ - void (*onevent)(const char *event, struct json_object *object); /* callback for handling events */ - unsigned noconcurrency: 1; /* avoids concurrent requests to verbs */ -}; -``` - -The migration of instances of that structure requires the following actions: - -- declare, explore, name the structure as ```const struct afb_binding_v2 afbBindingV2``` -- rename the field **prefix** to **api** -- remove the field **info** -- setup the fields **preinit**, **init**, **onevent** according to the next section -- set the field **noconcurrency** to the right value: - - to 1 if you want to avoid concurrent calls to verbs. - - to 0 if you allow concurrent calls to verbs. - -Example: - -```C -static const struct afb_binding plugin_desc = { - .type = AFB_BINDING_VERSION_1, - .v1 = { - .info = "Minimal Hello World Sample", - .prefix = "hello", - .verbs = verbs - } -``` - -Becomes: - -```C -const struct afb_binding_v2 afbBindingV2 = { - .api = "hello", - .specification = NULL, - .verbs = verbs, - .preinit = preinit, - .init = init -}; -``` - -The **binder** now relies only on the exported names -to deduce the type of the binding. -This make the main structure more simple. - -Adapt the init and callback functions -------------------------------------- - -The ***bindings*** version 1 defined 3 exported functions: - -- **afbBindingV1Register** -- **afbBindingV1ServiceInit** -- **afbBindingV1ServiceEvent** - -These function should not be exported any more and there definition changed. - -The function **afbBindingV1Register** is no more used to describe the binding. -When a binding has to take actions when it is loaded, it must set the field -**preinit** of the structure **afbBindingV2**. -This field, this preinit, might be used to check features at load. -When it returns a negative number, the ***binder*** stops before initializing any ***binding***. - -The function **afbBindingV1ServiceInit** is replaced by the field **init** -of the structure **afbBindingV2**. -The init function should return 0 in case of success or a negative error code -in case of problem. -It is called during initialization of services. - -The function **afbBindingV1ServiceEvent**is replaced by the field **onevent** -of the structure **afbBindingV2**. - -The two functions **afbBindingV1Register** and **afbBindingV1ServiceInit**, -were taking as parameter the ***binder*** interface and the service interface respectively. -These interfaces are now managed hiddenly for the **binding** by the **binder**. -So the variable that ***bindings*** version used to store the ***binder*** interface -and the service interface are no more needed and can be removed. - -Example: - -```C -const struct afb_binding_interface *interface; -struct afb_service service; - -static const struct afb_binding plugin_desc = { - .type = AFB_BINDING_VERSION_1, - .v1 = { - .info = "Minimal Hello World Sample", - .prefix = "hello", - .verbs = verbs - } -} - -const struct afb_binding *afbBindingV1Register (const struct afb_binding_interface *itf) -{ - interface = itf; - NOTICE(interface, "binding register"); - return &plugin_desc; -} - -int afbBindingV1ServiceInit(struct afb_service svc) -{ - service = svc; - NOTICE(interface, "binding init"); - return 0; -} - -void afbBindingV1ServiceEvent(const char *event, struct json_object *object) -{ - NOTICE(interface, "onevent %s", event); -} -``` - -Becomes: - -```C -static int preinit() -{ - AFB_NOTICE("binding preinit (was register)"); - return 0; -} - -static int init() -{ - AFB_NOTICE("binding init"); - return 0; -} - -static void onevent(const char *event, struct json_object *object) -{ - AFB_NOTICE("onevent %s", event); -} - -const struct afb_binding_v2 afbBindingV2 = { - .api = "hello", - .specification = NULL, - .verbs = verbs, - .preinit = preinit, - .init = init, - .onevent = onevent -}; -``` - -The two functions **afbBindingV1Register** and **afbBindingV1ServiceInit**, -were taking as parameter the ***binder*** interface and the service interface respectively. -These interfaces are now managed hiddenly for the **binding** by the **binder**. -So the variable that ***bindings*** version used to store the ***binder*** interface -and the service interface are no more needed and can be removed. - -On the above example the following lines were removed: - -```C -const struct afb_binding_interface *interface; -struct afb_service service; - - interface = itf; - - service = svc; -``` - -Removes the first parameter of functions of classes **daemon** and **service** ------------------------------------------------------------------------------- - -As explained before, many functions loose there first -arguments, this are the functions of the following classes: - -- functions of class **daemon**: - - functions starting with **afb_daemon_...** - - functions for logging: **ERROR**, **WARNING**, **NOTICE**, **INFO**, **DEBUG** -- functions of class **service**: - - functions starting with **afb_service_...** -- callback functions: - - the register function (that is removed) - - the service init function - - the onevent function - -For these functions, the first parameter is now implicit. - -Example: - -```C - afb_daemon_broadcast_event(afbitf->daemon, reason, description); -``` - -Becomes: - -```C - afb_daemon_broadcast_event(reason, description); -``` - -Also, to avoid possible conflicts, we introduced prefixed logging functions: -the macros - -- **ERROR** -- **WARNING** -- **NOTICE** -- **INFO** -- **DEBUG** - -have now a prefixed version: - -- **AFB\_ERROR** -- **AFB\_WARNING** -- **AFB\_NOTICE** -- **AFB\_INFO** -- **AFB\_DEBUG** - -It is now recommended to use the prefixed version. - -Example: - -```C - NOTICE(interface, "hello plugin comes to live"); -``` - -Become: - -```C - NOTICE("hello plugin comes to live"); -``` - -or, better: - -```C - AFB_NOTICE("hello plugin comes to live"); -``` - -To remove definition of the un-prefixed versions of logging macros: - -- **ERROR** -- **WARNING** -- **NOTICE** -- **INFO** -- **DEBUG** - -and just define - -- **AFB_BINDING_PRAGMA_NO_VERBOSE_UNPREFIX** - -before to include **afb/afb-binding.h**. - -```C -#define AFB_BINDING_PRAGMA_NO_VERBOSE_UNPREFIX -#define AFB_BINDING_VERSION 2 -#include -``` - -Consider where to emit logs for requests ----------------------------------------- - -The ***bindings*** v2 now allows to emit log messages associated to ***requests***. -This feature is valuable when debugging because it allows to return -side information associated to a ***request***. - -The defined macros for logging to requests are: - -- **AFB_REQ_ERROR** -- **AFB_REQ_WARNING** -- **AFB_REQ_NOTICE** -- **AFB_REQ_INFO** -- **AFB_REQ_DEBUG** - -We encourage the use of these new logging facilities everywhere it makes sense. - -Example: - -```C - INFO(afbitf, "method 'new' called for boardid %d", board->id); -``` - -Might become: - -```C - AFB_REQ_INFO(req, "method 'new' called for boardid %d", board->id); -``` - -Take care of store/unstore change ---------------------------------- - -For efficiency, the version 2 redefined how storing/un-storing of -requests works. -Storing request is needed for asynchronous handling of requests. - -For ***bindings*** version, the signature of the functions were: - -```C -struct afb_req *afb_req_store(struct afb_req req); -struct afb_req afb_req_unstore(struct afb_req *req); -``` - -For version 2 it becomes - -```C -struct afb_stored_req *afb_req_store(struct afb_req req); -struct afb_req afb_req_unstore(struct afb_stored_req *sreq); -``` - -Where the structure ```struct afb_stored_req``` is opaque. - -It should require few code change. - -Also check the following chapter that explain that asynchronous (sub)calls -can be replaced by synchronous one, avoiding the need to store/unstore -requests. - -Consider use of synchronous (sub)call requests ----------------------------------------------- - -***Bindings*** can emit requests for themselves (calls) or for -their clients (subcalls). -With ***bindings*** version 2 comes also synchronous requests for both cases. - -So when migrating to bindings version 2, a developer can consider -to replace the asynchronous requests (with asynchronous call back) -by synchronous ones. - -See functions ***afb_service_call_sync*** and ***afb_req_subcall_sync***. - -Optionally, removes explicit struct ------------------------------------ - -The new definitions now includes **typedefs** for common -structures, as shown on below sample: - -```C -typedef struct afb_daemon afb_daemon; -typedef struct afb_event afb_event; -typedef struct afb_arg afb_arg; -typedef struct afb_req afb_req; -typedef struct afb_service afb_service; -``` - -So you can remove the keyword **struct** if it bores you. - -Example: - -```C -static void verb(struct afb_req req) -{ - ... -} -``` - -Might become: - -```C -static void verb(afb_req req) -{ - ... -} -``` - -Example of migration --------------------- - -The first ***binding*** that migrated from v1 to v2 was the sample **HelloWorld**. -Here is shown the differences between the version 1 and the version 2. - -```diff -diff --git a/bindings/samples/HelloWorld.c b/bindings/samples/HelloWorld.c -index c6fa779..505aee3 100644 ---- a/bindings/samples/HelloWorld.c -+++ b/bindings/samples/HelloWorld.c -@@ -21,9 +21,9 @@ - - #include - -+#define AFB_BINDING_VERSION 2 - #include - --const struct afb_binding_interface *interface; - static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; - - struct event -@@ -79,7 +80,7 @@ static int event_add(const char *tag, const char *name) - strcpy(e->tag, tag); - - /* make the event */ -- e->event = afb_daemon_make_event(interface->daemon, name); -+ e->event = afb_daemon_make_event(name); - if (!e->event.closure) { free(e); return -1; } - - /* link */ -@@ -140,7 +141,7 @@ static void pingBug (struct afb_req request) - static void pingEvent(struct afb_req request) - { - json_object *query = afb_req_json(request); -- afb_daemon_broadcast_event(interface->daemon, "event", json_object_get(query)); -+ afb_daemon_broadcast_event("event", json_object_get(query)); - ping(request, json_object_get(query), "event"); - } - -@@ -288,38 +289,43 @@ static void exitnow (struct afb_req request) - exit(0); - } - -+static int preinit() -+{ -+ AFB_NOTICE("hello binding comes to live"); -+ return 0; -+} -+ -+static int init() -+{ -+ AFB_NOTICE("hello binding starting"); -+ return 0; -+} -+ - // NOTE: this sample does not use session to keep test a basic as possible - // in real application most APIs should be protected with AFB_SESSION_CHECK --static const struct afb_verb_desc_v1 verbs[]= { -- {"ping" , AFB_SESSION_NONE, pingSample , "Ping Application Framework"}, -- {"pingfail" , AFB_SESSION_NONE, pingFail , "Fails"}, -- {"pingnull" , AFB_SESSION_NONE, pingNull , "Return NULL"}, -- {"pingbug" , AFB_SESSION_NONE, pingBug , "Do a Memory Violation"}, -- {"pingJson" , AFB_SESSION_NONE, pingJson , "Return a JSON object"}, -- {"pingevent", AFB_SESSION_NONE, pingEvent , "Send an event"}, -- {"subcall", AFB_SESSION_NONE, subcall , "Call api/verb(args)"}, -- {"subcallsync", AFB_SESSION_NONE, subcallsync , "Call api/verb(args)"}, -- {"eventadd", AFB_SESSION_NONE, eventadd , "adds the event of 'name' for the 'tag'"}, -- {"eventdel", AFB_SESSION_NONE, eventdel , "deletes the event of 'tag'"}, -- {"eventsub", AFB_SESSION_NONE, eventsub , "subscribes to the event of 'tag'"}, -- {"eventunsub",AFB_SESSION_NONE, eventunsub , "unsubscribes to the event of 'tag'"}, -- {"eventpush", AFB_SESSION_NONE, eventpush , "pushs the event of 'tag' with the 'data'"}, -- {"exit", AFB_SESSION_NONE, exitnow , "exits from afb-daemon"}, -- {NULL} -+static const struct afb_verb_v2 verbs[]= { -+ { "ping" , pingSample , NULL, AFB_SESSION_NONE }, -+ { "pingfail" , pingFail , NULL, AFB_SESSION_NONE }, -+ { "pingnull" , pingNull , NULL, AFB_SESSION_NONE }, -+ { "pingbug" , pingBug , NULL, AFB_SESSION_NONE }, -+ { "pingJson" , pingJson , NULL, AFB_SESSION_NONE }, -+ { "pingevent", pingEvent , NULL, AFB_SESSION_NONE }, -+ { "subcall", subcall , NULL, AFB_SESSION_NONE }, -+ { "subcallsync", subcallsync, NULL, AFB_SESSION_NONE }, -+ { "eventadd", eventadd , NULL, AFB_SESSION_NONE }, -+ { "eventdel", eventdel , NULL, AFB_SESSION_NONE }, -+ { "eventsub", eventsub , NULL, AFB_SESSION_NONE }, -+ { "eventunsub", eventunsub , NULL, AFB_SESSION_NONE }, -+ { "eventpush", eventpush , NULL, AFB_SESSION_NONE }, -+ { "exit", exitnow , NULL, AFB_SESSION_NONE }, -+ { NULL} - }; - --static const struct afb_binding plugin_desc = { -- .type = AFB_BINDING_VERSION_1, -- .v1 = { -- .info = "Minimal Hello World Sample", -- .prefix = "hello", -- .verbs = verbs -- } -+const struct afb_binding_v2 afbBindingV2 = { -+ .api = "hello", -+ .specification = NULL, -+ .verbs = verbs, -+ .preinit = preinit, -+ .init = init - }; - --const struct afb_binding *afbBindingV1Register (const struct afb_binding_interface *itf) --{ -- interface = itf; -- NOTICE(interface, "hello plugin comes to live"); -- return &plugin_desc; --} -``` \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/7_LEGACY_Binding_v2_references.md b/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/7_LEGACY_Binding_v2_references.md deleted file mode 100644 index c790db8..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/Annexes/7_LEGACY_Binding_v2_references.md +++ /dev/null @@ -1,757 +0,0 @@ ---- -title: LEGACY Binding V2 references ---- - -# Structure for declaring binding ---------------------------------- - -### struct afb_binding_v2 - -The main structure, of type **afb_binding_v2**, for describing the binding -must be exported under the name **afbBindingV2**. - -This structure is defined as below. - -```C -/* - * Description of the bindings of type version 2 - */ -struct afb_binding_v2 -{ - const char *api; /* api name for the binding */ - const char *specification; /* textual openAPIv3 specification of the binding */ - const char *info; /* some info about the api, can be NULL */ - const struct afb_verb_v2 *verbs; /* array of descriptions of verbs terminated by a NULL name */ - int (*preinit)(); /* callback at load of the binding */ - int (*init)(); /* callback for starting the service */ - void (*onevent)(const char *event, struct json_object *object); /* callback for handling events */ - unsigned noconcurrency: 1; /* avoids concurrent requests to verbs */ -}; -``` - -### struct afb_verb_v2 - -Each verb is described with a structure of type **afb_verb_v2** -defined below: - -```C -/* - * Description of one verb of the API provided by the binding - * This enumeration is valid for bindings of type version 2 - */ -struct afb_verb_v2 -{ - const char *verb; /* name of the verb */ - void (*callback)(struct afb_req req); /* callback function implementing the verb */ - const struct afb_auth *auth; /* required authorization */ - const char *info; /* some info about the verb, can be NULL */ - uint32_t session; /* authorization and session requirements of the verb */ -}; -``` - -The **session** flags is one of the constant defined below: - -- AFB_SESSION_NONE : no flag, synonym to 0 -- AFB_SESSION_LOA_0 : Requires the LOA to be 0 or more, synonym to 0 or AFB_SESSION_NONE -- AFB_SESSION_LOA_1 : Requires the LOA to be 1 or more -- AFB_SESSION_LOA_2 : Requires the LOA to be 2 or more -- AFB_SESSION_LOA_3 : Requires the LOA to be 3 or more -- AFB_SESSION_CHECK : Requires the token to be set and valid -- AFB_SESSION_REFRESH : Implies a token refresh -- AFB_SESSION_CLOSE : Implies cloing the session - -The LOA (Level Of Assurance) is set, by binding, using the function **afb_req_session_set_LOA**. - -### struct afb_auth and enum afb_auth_type - -The structure **afb_auth** is used within verb description to -set security requirements. -The interpretation of the structure depends on the value of the field **type**. - -```C -struct afb_auth -{ - const enum afb_auth_type type; - union { - const char *text; - const unsigned loa; - const struct afb_auth *first; - }; - const struct afb_auth *next; -}; -``` - -The possible values for **type** is defined here: - -```C -/* - * Enum for Session/Token/Assurance middleware. - */ -enum afb_auth_type -{ - afb_auth_No = 0, /** never authorized, no data */ - afb_auth_Token, /** authorized if token valid, no data */ - afb_auth_LOA, /** authorized if LOA greater than data 'loa' */ - afb_auth_Permission, /** authorized if permission 'text' is granted */ - afb_auth_Or, /** authorized if 'first' or 'next' is authorized */ - afb_auth_And, /** authorized if 'first' and 'next' are authorized */ - afb_auth_Not, /** authorized if 'first' is not authorized */ - afb_auth_Yes /** always authorized, no data */ -}; -``` - -Example: - -```C -static const struct afb_auth _afb_auths_v2_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_v2_monitor[1], .next = &_afb_auths_v2_monitor[0] } -}; -``` - -## Functions of class afb_daemon - -The 3 following functions are linked to libsystemd. -They allow use of **sd_event** features and access -to **sd_bus** features. - -```C -/* - * Retrieves the common systemd's event loop of AFB - */ -struct sd_event *afb_daemon_get_event_loop(); - -/* - * Retrieves the common systemd's user/session d-bus of AFB - */ -struct sd_bus *afb_daemon_get_user_bus(); - -/* - * Retrieves the common systemd's system d-bus of AFB - */ -struct sd_bus *afb_daemon_get_system_bus(); -``` - -The 2 following functions are linked to event management. -Broadcasting an event send it to any possible listener. - -```C -/* - * Broadcasts widely the event of 'name' with the data 'object'. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * Calling this function is only forbidden during preinit. - * - * Returns the count of clients that received the event. - */ -int afb_daemon_broadcast_event(const char *name, struct json_object *object); - -/* - * Creates an event of 'name' and returns it. - * - * Calling this function is only forbidden during preinit. - * - * See afb_event_is_valid to check if there is an error. - */ -struct afb_event afb_daemon_make_event(const char *name); -``` - -The following function is used by logging macros and should normally -not be used. -Instead, you should use the macros: - -- **AFB\_ERROR** -- **AFB\_WARNING** -- **AFB\_NOTICE** -- **AFB\_INFO** -- **AFB\_DEBUG** - -```C -/* - * Send a message described by 'fmt' and following parameters - * to the journal for the verbosity 'level'. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - */ -void afb_daemon_verbose(int level, const char *file, int line, const char * func, const char *fmt, ...); -``` - -The 2 following functions MUST be used to access data of the bindings. - -```C -/* - * Get the root directory file descriptor. This file descriptor can - * be used with functions 'openat', 'fstatat', ... - */ -int afb_daemon_rootdir_get_fd(); - -/* - * Opens 'filename' within the root directory with 'flags' (see function openat) - * using the 'locale' definition (example: "jp,en-US") that can be NULL. - * Returns the file descriptor or -1 in case of error. - */ -int afb_daemon_rootdir_open_locale(const char *filename, int flags, const char *locale); -``` - -The following function is used to queue jobs. - -```C -/* - * Queue the job defined by 'callback' and 'argument' for being executed asynchronously - * in this thread (later) or in an other thread. - * If 'group' is not NUL, the jobs queued with a same value (as the pointer value 'group') - * are executed in sequence in the order of there submission. - * If 'timeout' is not 0, it represent the maximum execution time for the job in seconds. - * At first, the job is called with 0 as signum and the given argument. - * The job is executed with the monitoring of its time and some signals like SIGSEGV and - * SIGFPE. When a such signal is catched, the job is terminated and re-executed but with - * signum being the signal number (SIGALRM when timeout expired). - * - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_queue_job(void (*callback)(int signum, void *arg), void *argument, void *group, int timeout) -``` - -The following function must be used when a binding depends on other -bindings at its initialization. - -```C -/* - * Tells that it requires the API of "name" to exist - * and if 'initialized' is not null to be initialized. - * Calling this function is only allowed within init. - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_require_api(const char *name, int initialized) -``` - -This function allows to give a different name to the binding. -It can be called during pre-init. - -```C -/* - * Set the name of the API to 'name'. - * Calling this function is only allowed within preinit. - * Returns 0 in case of success or -1 in case of error. - */ -int afb_daemon_rename_api(const char *name); -``` - -## Functions of class afb_service - -The following functions allow services to call verbs of other -bindings for themselves. - -```C -/** - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the name of the binding. - * The result of the call is delivered to the 'callback' function with the 'callback_closure'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * The 'callback' receives 3 arguments: - * 1. 'closure' the user defined closure pointer 'callback_closure', - * 2. 'status' a status being 0 on success or negative when an error occurred, - * 2. 'result' the resulting data as a JSON object. - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param callback The to call on completion - * @param callback_closure The closure to pass to the callback - * - * @see also 'afb_req_subcall' - */ -void afb_service_call( - const char *api, - const char *verb, - struct json_object *args, - void (*callback)(void*closure, int status, struct json_object *result), - void *callback_closure); - -/** - * Calls the 'verb' of the 'api' with the arguments 'args' and 'verb' in the name of the binding. - * 'result' will receive the response. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * @param api The api name of the method to call - * @param verb The verb name of the method to call - * @param args The arguments to pass to the method - * @param result Where to store the result - should call json_object_put on it - - * - * @returns 0 in case of success or a negative value in case of error. - * - * @see also 'afb_req_subcall' - */ -int afb_service_call_sync( - const char *api, - const char *verb, - struct json_object *args, - struct json_object **result); -``` - -## Functions of class afb_event - -This function checks whether the event is valid. -It must be used when creating events. - -```C -/* - * Checks wether the 'event' is valid or not. - * - * Returns 0 if not valid or 1 if valid. - */ -int afb_event_is_valid(struct afb_event event); -``` - -The two following functions are used to broadcast or push -event with its data. - -```C -/* - * Broadcasts widely the 'event' with the data 'object'. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * Returns the count of clients that received the event. - */ -int afb_event_broadcast(struct afb_event event, struct json_object *object); - -/* - * Pushes the 'event' with the data 'object' to its observers. - * 'object' can be NULL. - * - * For convenience, the function calls 'json_object_put' for 'object'. - * Thus, in the case where 'object' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * Returns the count of clients that received the event. - */ -int afb_event_push(struct afb_event event, struct json_object *object); -``` - -The following function destroys the event. - -```C -/* - * Drops the data associated to the 'event' - * After calling this function, the event - * MUST NOT BE USED ANYMORE. - */ -void afb_event_drop(struct afb_event event); -``` - -This function allows to retrieve the exact name of the event. - -```C -/* - * Gets the name associated to the 'event'. - */ -const char *afb_event_name(struct afb_event event); -``` - -## Functions of class afb_req - -This function checks the validity of the **req**. - -```C -/* - * Checks wether the request 'req' is valid or not. - * - * Returns 0 if not valid or 1 if valid. - */ -int afb_req_is_valid(struct afb_req req); -``` - -The following functions retrieves parameters of the request. - -```C -/* - * Gets from the request 'req' the argument of 'name'. - * Returns a PLAIN structure of type 'struct afb_arg'. - * When the argument of 'name' is not found, all fields of result are set to NULL. - * When the argument of 'name' is found, the fields are filled, - * in particular, the field 'result.name' is set to 'name'. - * - * There is a special name value: the empty string. - * The argument of name "" is defined only if the request was made using - * an HTTP POST of Content-Type "application/json". In that case, the - * argument of name "" receives the value of the body of the HTTP request. - */ -struct afb_arg afb_req_get(struct afb_req req, const char *name); - -/* - * Gets from the request 'req' the string value of the argument of 'name'. - * Returns NULL if when there is no argument of 'name'. - * Returns the value of the argument of 'name' otherwise. - * - * Shortcut for: afb_req_get(req, name).value - */ -const char *afb_req_value(struct afb_req req, const char *name); - -/* - * Gets from the request 'req' the path for file attached to the argument of 'name'. - * Returns NULL if when there is no argument of 'name' or when there is no file. - * Returns the path of the argument of 'name' otherwise. - * - * Shortcut for: afb_req_get(req, name).path - */ -const char *afb_req_path(struct afb_req req, const char *name); - -/* - * Gets from the request 'req' the json object hashing the arguments. - * The returned object must not be released using 'json_object_put'. - */ -struct json_object *afb_req_json(struct afb_req req); -``` - -The following functions emit the reply to the request. - -```C -/* - * Sends a reply of kind success to the request 'req'. - * The status of the reply is automatically set to "success". - * Its send the object 'obj' (can be NULL) with an - * informational comment 'info (can also be NULL). - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - */ -void afb_req_success(struct afb_req req, struct json_object *obj, const char *info); - -/* - * Same as 'afb_req_success' but the 'info' is a formatting - * string followed by arguments. - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - */ -void afb_req_success_f(struct afb_req req, struct json_object *obj, const char *info, ...); - -/* - * Same as 'afb_req_success_f' but the arguments to the format 'info' - * are given as a variable argument list instance. - * - * For convenience, the function calls 'json_object_put' for 'obj'. - * Thus, in the case where 'obj' should remain available after - * the function returns, the function 'json_object_get' shall be used. - */ -void afb_req_success_v(struct afb_req req, struct json_object *obj, const char *info, va_list args); - -/* - * Sends a reply of kind failure to the request 'req'. - * The status of the reply is set to 'status' and an - * informational comment 'info' (can also be NULL) can be added. - * - * Note that calling afb_req_fail("success", info) is equivalent - * to call afb_req_success(NULL, info). Thus even if possible it - * is strongly recommended to NEVER use "success" for status. - */ -void afb_req_fail(struct afb_req req, const char *status, const char *info); - -/* - * Same as 'afb_req_fail' but the 'info' is a formatting - * string followed by arguments. - */ -void afb_req_fail_f(struct afb_req req, const char *status, const char *info, ...); - -/* - * Same as 'afb_req_fail_f' but the arguments to the format 'info' - * are given as a variable argument list instance. - */ -void afb_req_fail_v(struct afb_req req, const char *status, const char *info, va_list args); -``` - -The following functions handle the session data. - -```C -/* - * Gets the pointer stored by the binding for the session of 'req'. - * When the binding has not yet recorded a pointer, NULL is returned. - */ -void *afb_req_context_get(struct afb_req req); - -/* - * Stores for the binding the pointer 'context' to the session of 'req'. - * The function 'free_context' will be called when the session is closed - * or if binding stores an other pointer. - */ -void afb_req_context_set(struct afb_req req, void *context, void (*free_context)(void*)); - -/* - * Gets the pointer stored by the binding for the session of 'req'. - * If the stored pointer is NULL, indicating that no pointer was - * already stored, afb_req_context creates a new context by calling - * the function 'create_context' and stores it with the freeing function - * 'free_context'. - */ -void *afb_req_context(struct afb_req req, void *(*create_context)(), void (*free_context)(void*)); - -/* - * Frees the pointer stored by the binding for the session of 'req' - * and sets it to NULL. - * - * Shortcut for: afb_req_context_set(req, NULL, NULL) - */ -void afb_req_context_clear(struct afb_req req); - -/* - * Closes the session associated with 'req' - * and delete all associated contexts. - */ -void afb_req_session_close(struct afb_req req); - -/* - * Sets the level of assurance of the session of 'req' - * to 'level'. The effect of this function is subject of - * security policies. - * Returns 1 on success or 0 if failed. - */ -int afb_req_session_set_LOA(struct afb_req req, unsigned level); -``` - -The 4 following functions must be used for asynchronous handling requests. - -```C -/* - * Adds one to the count of references of 'req'. - * This function MUST be called by asynchronous implementations - * of verbs if no reply was sent before returning. - */ -void afb_req_addref(struct afb_req req); - -/* - * Substracts one to the count of references of 'req'. - * This function MUST be called by asynchronous implementations - * of verbs after sending the asynchronous reply. - */ -void afb_req_unref(struct afb_req req); - -/* - * Stores 'req' on heap for asynchronous use. - * Returns a handler to the stored 'req' or NULL on memory depletion. - * The count of reference to 'req' is incremented on success - * (see afb_req_addref). - */ -struct afb_stored_req *afb_req_store(struct afb_req req); - -/* - * Retrieves the afb_req stored at 'sreq'. - * Returns the stored request. - * The count of reference is UNCHANGED, thus, the - * function 'afb_req_unref' should be called on the result - * after that the asynchronous reply if sent. - */ -struct afb_req afb_req_unstore(struct afb_stored_req *sreq); -``` - -The two following functions are used to associate client with events -(subscription). - -```C -/* - * Establishes for the client link identified by 'req' a subscription - * to the 'event'. - * Returns 0 in case of successful subscription or -1 in case of error. - */ -int afb_req_subscribe(struct afb_req req, struct afb_event event); - -/* - * Revokes the subscription established to the 'event' for the client - * link identified by 'req'. - * Returns 0 in case of successful subscription or -1 in case of error. - */ -int afb_req_unsubscribe(struct afb_req req, struct afb_event event); -``` - -The following functions must be used to make request in the name of the -client (with its permissions). - -```C -/* - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * On completion, the function 'callback' is invoked with the - * 'closure' given at call and two other parameters: 'iserror' and 'result'. - * 'status' is 0 on success or negative when on an error reply. - * 'result' is the json object of the reply, you must not call json_object_put - * on the result. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * See also: - * - 'afb_req_subcall_req' that is convenient to keep request alive automatically. - * - 'afb_req_subcall_sync' the synchronous version - */ -void afb_req_subcall( - struct afb_req req, - const char *api, - const char *verb, - struct json_object *args, - void (*callback)(void *closure, int status, struct json_object *result), - void *closure); - -/* - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * On completion, the function 'callback' is invoked with the - * original request 'req', the 'closure' given at call and two - * other parameters: 'iserror' and 'result'. - * 'status' is 0 on success or negative when on an error reply. - * 'result' is the json object of the reply, you must not call json_object_put - * on the result. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * See also: - * - 'afb_req_subcall' that doesn't keep request alive automatically. - * - 'afb_req_subcall_sync' the synchronous version - */ -static inline void afb_req_subcall_req(struct afb_req req, const char *api, const char *verb, struct json_object *args, void (*callback)(void *closure, int iserror, struct json_object *result, struct afb_req req), void *closure) -{ - req.itf->subcall_req(req.closure, api, verb, args, callback, closure); -} - -/* - * Makes a call to the method of name 'api' / 'verb' with the object 'args'. - * This call is made in the context of the request 'req'. - * This call is synchronous, it waits until completion of the request. - * It returns 0 on success or a negative value on error answer. - * The object pointed by 'result' is filled and must be released by the caller - * after its use by calling 'json_object_put'. - * - * For convenience, the function calls 'json_object_put' for 'args'. - * Thus, in the case where 'args' should remain available after - * the function returns, the function 'json_object_get' shall be used. - * - * See also: - * - 'afb_req_subcall_req' that is convenient to keep request alive automatically. - * - 'afb_req_subcall' that doesn't keep request alive automatically. - */ -int afb_req_subcall_sync( - struct afb_req req, - const char *api, - const char *verb, - struct json_object *args, - struct json_object **result); -``` - -The following function is used by logging macros and should normally -not be used. -Instead, you should use the macros: - -- **AFB_REQ_ERROR** -- **AFB_REQ_WARNING** -- **AFB_REQ_NOTICE** -- **AFB_REQ_INFO** -- **AFB_REQ_DEBUG** - -```C -/* - * Send associated to 'req' a message described by 'fmt' and following parameters - * to the journal for the verbosity 'level'. - * - * 'file', 'line' and 'func' are indicators of position of the code in source files - * (see macros __FILE__, __LINE__ and __func__). - * - * 'level' is defined by syslog standard: - * EMERGENCY 0 System is unusable - * ALERT 1 Action must be taken immediately - * CRITICAL 2 Critical conditions - * ERROR 3 Error conditions - * WARNING 4 Warning conditions - * NOTICE 5 Normal but significant condition - * INFO 6 Informational - * DEBUG 7 Debug-level messages - */ -void afb_req_verbose(struct afb_req req, int level, const char *file, int line, const char * func, const char *fmt, ...); -``` - -The functions below allow a binding involved in the platform security -to explicitly check a permission of a client or to get the calling -application identity. - -```C -/* - * Check whether the 'permission' is granted or not to the client - * identified by 'req'. - * - * Returns 1 if the permission is granted or 0 otherwise. - */ -int afb_req_has_permission(struct afb_req req, const char *permission); - -/* - * Get the application identifier of the client application for the - * request 'req'. - * - * Returns the application identifier or NULL when the application - * can not be identified. - * - * The returned value if not NULL must be freed by the caller - */ -char *afb_req_get_application_id(struct afb_req req); - -/* - * Get the user identifier (UID) of the client application for the - * request 'req'. - * - * Returns -1 when the application can not be identified. - */ -int afb_req_get_uid(struct afb_req req); -``` - -## Logging macros - -The following macros must be used for logging: - -```C -AFB_ERROR(fmt,...) -AFB_WARNING(fmt,...) -AFB_NOTICE(fmt,...) -AFB_INFO(fmt,...) -AFB_DEBUG(fmt,...) -``` - -The following macros can be used for logging in the context -of a request **req** of type **afb_req**: - -```C -AFB_REQ_ERROR(req,fmt,...) -AFB_REQ_WARNING(req,fmt,...) -AFB_REQ_NOTICE(req,fmt,...) -AFB_REQ_INFO(req,fmt,...) -AFB_REQ_DEBUG(req,fmt,...) -``` - -By default, the logging macros add file, line and function -indication. \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/basis.svg b/docs/3_Developer_Guides/2_Application_Framework_Binder/images/basis.svg deleted file mode 100644 index 0d42d76..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/basis.svg +++ /dev/null @@ -1,356 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - APPLICATION - - - - - - - - BINDERafb-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - SECURITYCONTEXT - - - - - - http - - - - - - ws - - - - - - - - \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/interconnection.svg b/docs/3_Developer_Guides/2_Application_Framework_Binder/images/interconnection.svg deleted file mode 100644 index 4a10217..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/interconnection.svg +++ /dev/null @@ -1,854 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - APPLICATION - - - - - - - - BINDERafb-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - SECURITYCONTEXT - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - APPLICATION - - - - - - - - BINDERafb-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - SECURITYCONTEXT - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - APPLICATION - - - - - - - - BINDERafb-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - SECURITYCONTEXT - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - APPLICATION - - - - - - - - BINDERafb-daemon - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - BINDING - - - - - - - - - - - - SECURITYCONTEXT - - - - - - - - - interconnectiondbus, ws,bus1, tls,... - - - - - - - - A - - - - - - - - C - - - - - - - - B - - - - - - - - D - - - - - - - - \ No newline at end of file diff --git a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/signaling-basis.svg b/docs/3_Developer_Guides/2_Application_Framework_Binder/images/signaling-basis.svg deleted file mode 100644 index b13fcf1..0000000 --- a/docs/3_Developer_Guides/2_Application_Framework_Binder/images/signaling-basis.svg +++ /dev/null @@ -1,145 +0,0 @@ - - - - - - - request-data - - - - - - client 1 - - - - - - - - client 2 - - - - - - - - : framework - - - - - - - - signaling agent - - - - - - - - - - - request-data - - - - - - afb_daemon_make_event - - - - - - - - - afb_req_subscribe - - - - - reply of request-data - - - - - - afb_req_subscribe - - - - - reply of request-data - - - - - - device - - - - - - - - - setup - - - - - << wake up >> - - - - - afb_event_push - - - - - << event >> - - - - - << event >> - - - - - reply of afb_event_push - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/docs/3_Developer_Guides/2_Creating_a_New_Service.md b/docs/3_Developer_Guides/2_Creating_a_New_Service.md index ce9a745..33a3fb5 100644 --- a/docs/3_Developer_Guides/2_Creating_a_New_Service.md +++ b/docs/3_Developer_Guides/2_Creating_a_New_Service.md @@ -2,509 +2,4 @@ title: Creating a New Service --- -This tutorial provides instructions on **Creating a New Service** from scratch. - -### 1. Create new project development directory - - ```sh - $ cd ~/agl-app - $ mkdir newservice/ - $ cd newservice/ - ``` - -### 2. Source the SDK environment setup - - ```sh - $ source ~/agl-app/agl-sdk/environment-setup-corei7-64-agl-linux - ``` - -### 3. Copy initial CMAKE configuration templates - - ```sh - $ mkdir -p conf.d/cmake - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/config.cmake.sample conf.d/cmake/config.cmake - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/CMakeLists.txt.sample CMakeLists.txt - ``` - -### 4. Edit CMAKE configuration template - - ```sh - $ vim ~/agl-app/newservice/conf.d/cmake/config.cmake - - ########################################################################### - # Copyright 2020 # INSERT YEAR - # - # author: John Doe # INSERT AUTHOR DETAILS - # - # 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. - ########################################################################### - - # Project Info - # ------------------ - set(PROJECT_NAME hellocount) # INSERT NEW PROJECT NAME - set(API_NAME "hellocount") #INSERT NEW API NAME - set(PROJECT_PRETTY_NAME "Example") - set(PROJECT_DESCRIPTION "AGL hellocount application example") # INSERT CONCISE PROJECT DESCRIPTION - set(PROJECT_URL "https://gerrit.automotivelinux.org/gerrit/apps/cmake-apps-module") - set(PROJECT_ICON "icon.png") - set(PROJECT_AUTHOR "John Doe") # INSERT AUTHOR NAME - set(PROJECT_AUTHOR_MAIL "john.doe@example.com") # INSERT AUTHOR EMAIL - set(PROJECT_LICENSE "APL2.0") - set(PROJECT_LANGUAGES "C") - set(PROJECT_VERSION "1.0.0") # INSERT PROJECT VERSION - - # Which directories inspect to find CMakeLists.txt target files - # set(PROJECT_SRC_DIR_PATTERN "*") - - # Where are stored the project configuration files - # relative to the root project directory - set(PROJECT_CMAKE_CONF_DIR "conf.d/cmake") - - # Compilation Mode (DEBUG, RELEASE, COVERAGE or PROFILING) - # ---------------------------------- - set(BUILD_TYPE "RELEASE") # SELECT BUILD TYPE - #set(USE_EFENCE 1) - - # Kernel selection if needed. You can choose between a - # mandatory version to impose a minimal version. - # Or check Kernel minimal version and just print a Warning - # about missing features and define a preprocessor variable - # to be used as preprocessor condition in code to disable - # incompatibles features. Preprocessor define is named - # KERNEL_MINIMAL_VERSION_OK. - # - # NOTE*** FOR NOW IT CHECKS KERNEL Yocto environment and - # Yocto SDK Kernel version. - # ----------------------------------------------- - #set (kernel_mandatory_version 4.8) - #set (kernel_minimal_version 4.8) - - # Compiler selection if needed. Impose a minimal version. - # ----------------------------------------------- - set (gcc_minimal_version 4.9) - - # PKG_CONFIG required packages - # ----------------------------- - set (PKG_REQUIRED_LIST - json-c - afb-daemon - afb-helpers - ) - - # You can also consider to include libsystemd - # ----------------------------------- - #list (APPEND PKG_REQUIRED_LIST libsystemd>=222) - - if(IS_DIRECTORY $ENV{HOME}/opt/afb-monitoring) - set(MONITORING_ALIAS "--alias=/monitoring:$ENV{HOME}/opt/afb-monitoring") - endif() - - # Print a helper message when every thing is finished - # ---------------------------------------------------- - set(CLOSING_MESSAGE "Debug from afb-daemon --port=1234 ${MONITORING_ALIAS} --ldpaths=package --workdir=. --roothttp=../htdocs --token= --verbose ") - set(PACKAGE_MESSAGE "Install widget file using in the target : afm-util install ${PROJECT_NAME}.wgt") - - - - # Prefix path where will be installed the files - # Default: /usr/local (need root permission to write in) - # ------------------------------------------------------ - #set(INSTALL_PREFIX /opt/AGL CACHE PATH "INSTALL PREFIX PATH") - - # Customize link option - # ----------------------------- - #list(APPEND link_libraries -an-option) - - # Compilation options definition - # Use CMake generator expressions to specify only for a specific language - # Values are prefilled with default options that is currently used. - # Either separate options with ";", or each options must be quoted separately - # DO NOT PUT ALL OPTION QUOTED AT ONCE , COMPILATION COULD FAILED ! - # ---------------------------------------------------------------------------- - #set(COMPILE_OPTIONS - # -Wall - # -Wextra - # -Wconversion - # -Wno-unused-parameter - # -Wno-sign-compare - # -Wno-sign-conversion - # -Werror=maybe-uninitialized - # -Werror=implicit-function-declaration - # -ffunction-sections - # -fdata-sections - # -fPIC - # CACHE STRING "Compilation flags") - #set(C_COMPILE_OPTIONS "" CACHE STRING "Compilation flags for C language.") - #set(CXX_COMPILE_OPTIONS "" CACHE STRING "Compilation flags for C++ language.") - #set(PROFILING_COMPILE_OPTIONS - # -g - # -O0 - # -pg - # -Wp,-U_FORTIFY_SOURCE - # CACHE STRING "Compilation flags for PROFILING build type.") - #set(DEBUG_COMPILE_OPTIONS - # -g - # -ggdb - # CACHE STRING "Compilation flags for DEBUG build type.") - #set(COVERAGE_COMPILE_OPTIONS - # -g - # -O0 - # --coverage - # CACHE STRING "Compilation flags for COVERAGE build type.") - #set(RELEASE_COMPILE_OPTIONS - # -O2 - # -pipe - # -D_FORTIFY_SOURCE=2 - # -fstack-protector-strong - # -Wformat -Wformat-security - # -Werror=format-security - # -feliminate-unused-debug-types - # -Wl,-O1 - # -Wl,--hash-style=gnu - # -Wl,--as-needed - # -fstack-protector-strong - # -Wl,-z,relro,-z,now - # CACHE STRING "Compilation flags for RELEASE build type.") - - # (BUG!!!) as PKG_CONFIG_PATH does not work [should be an env variable] - # --------------------------------------------------------------------- - set(INSTALL_PREFIX $ENV{HOME}/opt) - set(CMAKE_PREFIX_PATH ${CMAKE_INSTALL_PREFIX}/lib64/pkgconfig ${CMAKE_INSTALL_PREFIX}/lib/pkgconfig) - set(LD_LIBRARY_PATH ${CMAKE_INSTALL_PREFIX}/lib64 ${CMAKE_INSTALL_PREFIX}/lib) - - # Location for config.xml.in template file. - # - # If you keep them commented then it will build with a default minimal widget - # template which is very simple and it is highly probable that it will not suit - # to your app. - # ----------------------------------------- - #set(WIDGET_ICON "conf.d/wgt/${PROJECT_ICON}" CACHE PATH "Path to the widget icon") - set(WIDGET_ICON ${PROJECT_APP_TEMPLATES_DIR}/wgt/${PROJECT_ICON}) - set(WIDGET_CONFIG_TEMPLATE ${CMAKE_SOURCE_DIR}/conf.d/wgt/config.xml.in CACHE PATH "Path to widget config file template (config.xml.in)") # UNCOMMENT WIDGET_CONFIG_TEMPLATE - #set(TEST_WIDGET_CONFIG_TEMPLATE "${CMAKE_CURRENT_SOURCE_DIR}/conf.d/wgt/test-config.xml.in" CACHE PATH "Path to the test widget config file template (test-config.xml.in)") - - # Mandatory widget Mimetype specification of the main unit - # -------------------------------------------------------------------------- - # Choose between : - #- text/html : HTML application, - # content.src designates the home page of the application - # - #- application/vnd.agl.native : AGL compatible native, - # content.src designates the relative path of the binary. - # - # - application/vnd.agl.service: AGL service, content.src is not used. - # - #- ***application/x-executable***: Native application, - # content.src designates the relative path of the binary. - # For such application, only security setup is made. - # - set(WIDGET_TYPE application/vnd.agl.service) # UNCOMMENT WIDGET_TYPE - - # Mandatory Widget entry point file of the main unit - # -------------------------------------------------------------- - # This is the file that will be executed, loaded, - # at launch time by the application framework. - # - set(WIDGET_ENTRY_POINT config.xml) # UNCOMMENT WIDGET_ENTRY_POINT - - # Optional dependencies order - # --------------------------- - #set(EXTRA_DEPENDENCIES_ORDER) - - # Optional Extra global include path - # ----------------------------------- - #set(EXTRA_INCLUDE_DIRS) - - # Optional extra libraries - # ------------------------- - #set(EXTRA_LINK_LIBRARIES) - - # Optional force binding Linking flag - # ------------------------------------ - # set(BINDINGS_LINK_FLAG LinkOptions ) - - # Optional force package prefix generation, like widget - # ----------------------------------------------------- - # set(PKG_PREFIX DestinationPath) - - # Optional Application Framework security token - # and port use for remote debugging. - #------------------------------------------------------------ - #set(AFB_TOKEN "" CACHE PATH "Default binder security token") # COMMENT AFB_TOKEN - #set(AFB_REMPORT "1234" CACHE PATH "Default binder listening port") # COMMENT AFB_REMPORT - - # Optional schema validator about now only XML, LUA and JSON - # are supported - #------------------------------------------------------------ - #set(LUA_CHECKER "luac" "-p" CACHE STRING "LUA compiler") - #set(XML_CHECKER "xmllint" CACHE STRING "XML linter") - #set(JSON_CHECKER "json_verify" CACHE STRING "JSON linter") - - include(CMakeAfbTemplates) - ``` - -### 5. Copy WGT configuration template - - ```sh - $ mkdir -p conf.d/wgt - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/config.xml.in.sample conf.d/wgt/config.xml.in - ``` - - Edit `config.xml` file - ```sh - $ vim conf.d/wgt/config.xml.in - - - - @PROJECT_NAME@ - - - @PROJECT_DESCRIPTION@ - @PROJECT_AUTHOR@ <@PROJECT_AUTHOR_MAIL@> - @PROJECT_LICENSE@ - - - - - - - - - - - - ``` - - -### 6. Run CMAKE and Generate autobuild - - ```sh - $ mkdir build/ - $ cd build/ - $ cmake .. - $ make autobuild - ``` - -### 7. Create service directory - - ```sh - $ cd .. - $ mkdir service/ - $ cd service/ - ``` - This `service` directory holds the C code & CMakeLists.txt ; - - - Add `hellocount-service.c` file which contains the functional C code : - - ```sh - $ vim hellocount-service.c - - /* - * Copyright 2020 The Linux Foundation # INSERT YEAR & ORG - * - * 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 - #include - #include - - #define AFB_BINDING_VERSION 3 - #include - - static void pingSample(afb_req_t request) - { - static int pingcount = 0; - - afb_req_success_f(request, json_object_new_int(pingcount), "Ping count = %d", pingcount); - - AFB_API_NOTICE(afbBindingV3root, "Verbosity macro at level notice invoked at ping invocation count = %d", pingcount); - - pingcount++; - } - - static void count(afb_req_t request) - { - static int counter = 0; - - afb_req_success_f(request, json_object_new_int(counter), "Counter = %d", counter); - - AFB_API_NOTICE(afbBindingV3root, "Verbosity macro at level notice invoked at count invocation count = %d", counter); - - counter++; - } - - - - static const afb_verb_t verbs[] = - { - /*Without security*/ - {.verb = "ping", .session = AFB_SESSION_NONE, .callback = pingSample, .auth = NULL}, - {.verb = "count", .session = AFB_SESSION_NONE, .callback = count, .auth = NULL}, - {NULL} - }; - - const afb_binding_t afbBindingExport = - { - .api = "hellocount", - .specification = "HelloCount API", - .verbs = verbs, - .preinit = NULL, - .init = NULL, - .onevent = NULL, - .userdata = NULL, - .provide_class = NULL, - .require_class = NULL, - .require_api = NULL, - .noconcurrency = 0 - }; - ``` - -- Add `CMakeLists.txt` file : - - ```sh - $ vim CMakeLists.txt - - ########################################################################### - # Copyright 2020 The Linux Foundation # INSERT YEAR & ORG - # - # 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(hellocount) - # Define project Targets - ADD_LIBRARY(${TARGET_NAME} MODULE hellocount-service.c) - - # Binder exposes a unique public entry point - SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES - PREFIX "afb-" - LABELS "BINDING" - OUTPUT_NAME ${TARGET_NAME} - ) - ``` - -### 8. Build and Package `wgt` using autobuild - - ```sh - $ cd .. - - $ ./autobuild/agl/autobuild build - - make[1]: Entering directory '/home/boron/agl-app/newservice/build' - make[2]: Entering directory '/home/boron/agl-app/newservice/build' - make[3]: Entering directory '/home/boron/agl-app/newservice/build' - make[3]: Leaving directory '/home/boron/agl-app/newservice/build' - [100%] Built target autobuild - make[2]: Leaving directory '/home/boron/agl-app/newservice/build' - make[1]: Leaving directory '/home/boron/agl-app/newservice/build' - - $ ./autobuild/agl/autobuild package - - make[1]: Entering directory '/home/boron/agl-app/newservice/build' - make[2]: Entering directory '/home/boron/agl-app/newservice/build' - make[3]: Entering directory '/home/boron/agl-app/newservice/build' - make[3]: Leaving directory '/home/boron/agl-app/newservice/build' - [100%] Built target autobuild - make[2]: Leaving directory '/home/boron/agl-app/newservice/build' - make[1]: Leaving directory '/home/boron/agl-app/newservice/build' - make[1]: Entering directory '/home/boron/agl-app/newservice/build' - make[2]: Entering directory '/home/boron/agl-app/newservice/build' - make[3]: Entering directory '/home/boron/agl-app/newservice/build' - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - Scanning dependencies of target prepare_package - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - [ 6%] Generating package - [ 12%] Generating package/bin - [ 18%] Generating package/etc - [ 25%] Generating package/lib - [ 31%] Generating package/htdocs - [ 37%] Generating package/var - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - [ 37%] Built target prepare_package - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - Scanning dependencies of target prepare_package_test - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - [ 43%] Generating package-test - [ 50%] Generating package-test/bin - [ 56%] Generating package-test/etc - [ 62%] Generating package-test/lib - [ 68%] Generating package-test/htdocs - [ 75%] Generating package-test/var - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - [ 75%] Built target prepare_package_test - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - Scanning dependencies of target populate - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - [ 75%] Built target populate - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - Scanning dependencies of target widget_files - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - [ 81%] Generating package/icon.png - [ 87%] Generating package/config.xml - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - [ 93%] Built target widget_files - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - Scanning dependencies of target widget - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - make[4]: Entering directory '/home/boron/agl-app/newservice/build' - [100%] Generating hellocount.wgt - NOTICE: -- PACKING widget hellocount.wgt from directory /home/boron/agl-app/newservice/build/package - ++ Install widget file using in the target : afm-util install hellocount.wgt - make[4]: Leaving directory '/home/boron/agl-app/newservice/build' - [100%] Built target widget - make[3]: Leaving directory '/home/boron/agl-app/newservice/build' - make[2]: Leaving directory '/home/boron/agl-app/newservice/build' - make[1]: Leaving directory '/home/boron/agl-app/newservice/build' - ``` - - - The `hellocount.wgt` file is packaged and available at `~/agl-app/newservice/build`. - -### 9. Install the service - - - Local System : - ```sh - # Copy hellocount.wgt to remote AGL system - $ scp ~/agl-app/newservice/build/hellocount.wgt root@:/home/0/ - ``` - - - Remote AGL System : - ```sh - # Install using the service using afm-util - $ afm-util install ./hellocount.wgt - # Reboot the system - $ reboot -f - ``` +TBD \ No newline at end of file diff --git a/docs/3_Developer_Guides/3_AppFW_Privileges_Management/03-AGL-AppFW-Privileges-Management.pdf b/docs/3_Developer_Guides/3_AppFW_Privileges_Management/03-AGL-AppFW-Privileges-Management.pdf deleted file mode 100644 index d468610a554419e344bd045eeff890774dd896ef..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1143778 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 g^id^q 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

P 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

InaJmRI(dXVVVE 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:!hTAR_2s@*D7 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

$a#5&9Yh?A|InJA&jxoEaQR_8)^t~ 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%0D!bNH$)o*oQOusvR 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

4-leDF3Ip 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

pJ$6itZcd$O27M9`KvUCJhWyM|&bfJVC+wu}b-! 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

qq{m3XRIgBw9<%IZYZ^Q$AK3R_VF~~7v+In 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⁣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 BEdBrh diff --git a/docs/3_Developer_Guides/3_AppFW_Privileges_Management/AppFW-Privileges_Management.md b/docs/3_Developer_Guides/3_AppFW_Privileges_Management/AppFW-Privileges_Management.md deleted file mode 100644 index 646732e..0000000 --- a/docs/3_Developer_Guides/3_AppFW_Privileges_Management/AppFW-Privileges_Management.md +++ /dev/null @@ -1,8 +0,0 @@ ---- -title: AGL Application Framework - Privileges Management ---- - - - - -[**AppFW - Privileges Management PDF**](03-AGL-AppFW-Privileges-Management.pdf) \ No newline at end of file diff --git a/docs/3_Developer_Guides/3_Creating_a_New_Application.md b/docs/3_Developer_Guides/3_Creating_a_New_Application.md index 757c151..6c382fd 100644 --- a/docs/3_Developer_Guides/3_Creating_a_New_Application.md +++ b/docs/3_Developer_Guides/3_Creating_a_New_Application.md @@ -2,543 +2,4 @@ title: Creating a New Application --- -This tutorial provides instructions on **Creating a New Application** from scratch. - -### 1. Create new project development directory - - ```sh - $ cd ~/agl-app - $ mkdir newapp/ - $ cd newapp/ - ``` - -### 2. Source the SDK environment setup - - ```sh - $ source ~/agl-app/agl-sdk/environment-setup-corei7-64-agl-linux - ``` - -### 3. Copy initial CMAKE configuration templates - - ```sh - $ mkdir -p conf.d/cmake - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/config.cmake.sample conf.d/cmake/config.cmake - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/CMakeLists.txt.sample CMakeLists.txt - ``` - -### 4. Edit CMAKE configuration template - - ```sh - $ vim ~/agl-app/newapp/conf.d/cmake/config.cmake - - ########################################################################### - # Copyright 2020 # INSERT YEAR - # - # author: John Doe # INSERT AUTHOR DETAILS - # - # 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. - ########################################################################### - - # Project Info - # ------------------ - set(PROJECT_NAME hellocount) # INSERT NEW PROJECT NAME - set(API_NAME hellocount) #INSERT NEW API NAME - set(PROJECT_PRETTY_NAME "Example helloworld count app") #INSERT PRETTY NAME - set(PROJECT_DESCRIPTION "AGL hellocount application example") # INSERT CONCISE PROJECT DESCRIPTION - set(PROJECT_URL "https://git.somewhere.org/foo") - set(PROJECT_ICON "icon.png") - set(PROJECT_AUTHOR "John Doe") # INSERT AUTHOR NAME - set(PROJECT_AUTHOR_MAIL "john.doe@example.com") # INSERT AUTHOR EMAIL - set(PROJECT_LICENSE "APL2.0") - set(PROJECT_LANGUAGES "C") - set(PROJECT_VERSION "1.0.0") # INSERT PROJECT VERSION - - # Which directories inspect to find CMakeLists.txt target files - # set(PROJECT_SRC_DIR_PATTERN "*") - - # Where are stored the project configuration files - # relative to the root project directory - set(PROJECT_CMAKE_CONF_DIR "conf.d") - - # Compilation Mode (DEBUG, RELEASE, COVERAGE or PROFILING) - # ---------------------------------- - set(BUILD_TYPE "RELEASE") # SELECT BUILD TYPE - #set(USE_EFENCE 1) - - # Kernel selection if needed. You can choose between a - # mandatory version to impose a minimal version. - # Or check Kernel minimal version and just print a Warning - # about missing features and define a preprocessor variable - # to be used as preprocessor condition in code to disable - # incompatibles features. Preprocessor define is named - # KERNEL_MINIMAL_VERSION_OK. - # - # NOTE*** FOR NOW IT CHECKS KERNEL Yocto environment and - # Yocto SDK Kernel version. - # ----------------------------------------------- - #set (kernel_mandatory_version 4.8) - #set (kernel_minimal_version 4.8) - - # Compiler selection if needed. Impose a minimal version. - # ----------------------------------------------- - set (gcc_minimal_version 4.9) - - # PKG_CONFIG required packages - # ----------------------------- - set (PKG_REQUIRED_LIST - json-c - afb-daemon - ) - - # You can also consider to include libsystemd - # ----------------------------------- - #list (APPEND PKG_REQUIRED_LIST libsystemd>=222) - - # Prefix path where will be installed the files - # Default: /usr/local (need root permission to write in) - # ------------------------------------------------------ - #set(INSTALL_PREFIX /opt/AGL CACHE PATH "INSTALL PREFIX PATH") - - # Customize link option - # ----------------------------- - #list(APPEND link_libraries -an-option) - - # Compilation options definition - # Use CMake generator expressions to specify only for a specific language - # Values are prefilled with default options that is currently used. - # Either separate options with ";", or each options must be quoted separately - # DO NOT PUT ALL OPTION QUOTED AT ONCE , COMPILATION COULD FAILED ! - # ---------------------------------------------------------------------------- - #set(COMPILE_OPTIONS - # -Wall - # -Wextra - # -Wconversion - # -Wno-unused-parameter - # -Wno-sign-compare - # -Wno-sign-conversion - # -Werror=maybe-uninitialized - # -Werror=implicit-function-declaration - # -ffunction-sections - # -fdata-sections - # -fPIC - # CACHE STRING "Compilation flags") - #set(C_COMPILE_OPTIONS "" CACHE STRING "Compilation flags for C language.") - #set(CXX_COMPILE_OPTIONS "" CACHE STRING "Compilation flags for C++ language.") - #set(PROFILING_COMPILE_OPTIONS - # -g - # -O0 - # -pg - # -Wp,-U_FORTIFY_SOURCE - # CACHE STRING "Compilation flags for PROFILING build type.") - #set(DEBUG_COMPILE_OPTIONS - # -g - # -ggdb - # CACHE STRING "Compilation flags for DEBUG build type.") - #set(COVERAGE_COMPILE_OPTIONS - # -g - # -O0 - # --coverage - # CACHE STRING "Compilation flags for COVERAGE build type.") - #set(RELEASE_COMPILE_OPTIONS - # -O2 - # -pipe - # -D_FORTIFY_SOURCE=2 - # -fstack-protector-strong - # -Wformat -Wformat-security - # -Werror=format-security - # -feliminate-unused-debug-types - # -Wl,-O1 - # -Wl,--hash-style=gnu - # -Wl,--as-needed - # -fstack-protector-strong - # -Wl,-z,relro,-z,now - # CACHE STRING "Compilation flags for RELEASE build type.") - - # Location for config.xml.in template file. - # - # If you keep them commented then it will build with a default minimal widget - # template which is very simple and it is highly probable that it will not suit - # to your app. - # ----------------------------------------- - #set(WIDGET_ICON "conf.d/wgt/${PROJECT_ICON}" CACHE PATH "Path to the widget icon") - set(WIDGET_CONFIG_TEMPLATE "${CMAKE_CURRENT_SOURCE_DIR}/conf.d/wgt/config.xml.in" CACHE PATH "Path to widget config file template (config.xml.in)") # UNCOMMENT WIDGET_CONFIG_TEMPLATE - #set(TEST_WIDGET_CONFIG_TEMPLATE "${CMAKE_CURRENT_SOURCE_DIR}/conf.d/wgt/test-config.xml.in" CACHE PATH "Path to the test widget config file template (test-config.xml.in)") - - # Mandatory widget Mimetype specification of the main unit - # -------------------------------------------------------------------------- - # Choose between : - #- text/html : HTML application, - # content.src designates the home page of the application - # - #- application/vnd.agl.native : AGL compatible native, - # content.src designates the relative path of the binary. - # - # - application/vnd.agl.service: AGL service, content.src is not used. - # - #- ***application/x-executable***: Native application, - # content.src designates the relative path of the binary. - # For such application, only security setup is made. - # - set(WIDGET_TYPE application/vnd.agl.service) # UNCOMMENT WIDGET_TYPE - - # Mandatory Widget entry point file of the main unit - # -------------------------------------------------------------- - # This is the file that will be executed, loaded, - # at launch time by the application framework. - # - set(WIDGET_ENTRY_POINT hellocount) # UNCOMMENT WIDGET_ENTRY_POINT - - # Optional dependencies order - # --------------------------- - #set(EXTRA_DEPENDENCIES_ORDER) - - # Optional Extra global include path - # ----------------------------------- - #set(EXTRA_INCLUDE_DIRS) - - # Optional extra libraries - # ------------------------- - #set(EXTRA_LINK_LIBRARIES) - - # Optional force binding Linking flag - # ------------------------------------ - # set(BINDINGS_LINK_FLAG LinkOptions ) - - # Optional force package prefix generation, like widget - # ----------------------------------------------------- - # set(PKG_PREFIX DestinationPath) - - # Optional Application Framework security token - # and port use for remote debugging. - #------------------------------------------------------------ - #set(AFB_TOKEN "" CACHE PATH "Default binder security token") # COMMENT AFB_TOKEN - #set(AFB_REMPORT "1234" CACHE PATH "Default binder listening port") # COMMENT AFB_REMPORT - - # Print a helper message when every thing is finished - # ---------------------------------------------------- - set(CLOSING_MESSAGE "Typical binding launch: cd ${CMAKE_BINARY_DIR}/package \\&\\& afb-daemon --port=${AFB_REMPORT} --workdir=. --ldpaths=lib --roothttp=htdocs --token=\"${AFB_TOKEN}\" --tracereq=common --verbose") - set(PACKAGE_MESSAGE "Install widget file using in the target : afm-util install ${PROJECT_NAME}.wgt") - - # Optional schema validator about now only XML, LUA and JSON - # are supported - #------------------------------------------------------------ - #set(LUA_CHECKER "luac" "-p" CACHE STRING "LUA compiler") - #set(XML_CHECKER "xmllint" CACHE STRING "XML linter") - #set(JSON_CHECKER "json_verify" CACHE STRING "JSON linter") - - include(CMakeAfbTemplates) - ``` - -### 5. Copy WGT configuration template - - ```sh - $ mkdir -p conf.d/wgt - $ cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/config.xml.in.sample conf.d/wgt/config.xml.in - ``` - -### 6. Run CMAKE and Generate autobuild - - ```sh - $ mkdir build/ - $ cd build/ - $ cmake .. - $ make autobuild - ``` - -### 7. Create app directory - - ```sh - $ cd .. - $ mkdir app/ - $ cd app/ - ``` - This `app` directory holds the C++, qrc, qml code & CMakeLists.txt ; - - - Add `main.cpp` file which contains the functional C code : - - ```sh - $ vim main.cpp - - /* - * Copyright (C) 2016 The Qt Company Ltd. # INSERT YEAR & ORG - * 2020 The Linux Foundation - * - * 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. - */ - - #include - #include - #include - #include - #include - #include - #include - #include - - int main(int argc, char *argv[]) - { - QGuiApplication app(argc, argv); - app.setDesktopFileName("Hellocount"); - - QQmlApplicationEngine engine; - QQmlContext *context = engine.rootContext(); - - QCommandLineParser parser; - parser.addPositionalArgument("port", app.translate("main", "port for binding")); - parser.addPositionalArgument("secret", app.translate("main", "secret for binding")); - parser.addHelpOption(); - parser.addVersionOption(); - parser.process(app); - QStringList positionalArguments = parser.positionalArguments(); - - if (positionalArguments.length() == 2) { - int port = positionalArguments.takeFirst().toInt(); - QString secret = positionalArguments.takeFirst(); - - QUrl bindingAddress; - QUrlQuery query; - - bindingAddress.setScheme(QStringLiteral("ws")); - bindingAddress.setHost(QStringLiteral("localhost")); - bindingAddress.setPort(port); - bindingAddress.setPath(QStringLiteral("/api")); - - - query.addQueryItem(QStringLiteral("token"), secret); - bindingAddress.setQuery(query); - context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress); - } - - engine.load(QUrl(QStringLiteral("qrc:/Hellocount.qml"))); - return app.exec(); - - } - ``` - - - Add `Hellocount.qml` file which contains the functional qml code : - - ```sh - $ vim Hellocount.qml - - /* - * Copyright 2020 The Linux Foundation # INSERT YEAR & ORG - * - * 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. - */ - - import QtQuick 2.6 - import QtQuick.Layouts 1.1 - import QtQuick.Controls 2.0 - import AGL.Demo.Controls 1.0 - - import QtQuick.Window 2.13 - - ApplicationWindow { - - // ----- Setup - id: root - width: Window.width * roles.scale - height: Window.height * roles.scale - - // ----- Childs - Label { - id: title - font.pixelSize: 48 - text: "Hello World Counter" - anchors.horizontalCenter: parent.horizontalCenter - } - - } - ``` - -- Add `Hellocount.qrc` file : - - ```sh - $ vim Hellocount.qrc - - - - Hellocount.qml - - - ``` - -- Add `CMakeLists.txt` file : - - ```sh - $ vim CMakeLists.txt - - ########################################################################### - # Copyright 2020 The Linux Foundation # INSERT YEAR & ORG - # - # 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. - ########################################################################### - - set(CMAKE_INCLUDE_CURRENT_DIR ON) - set(CMAKE_AUTOMOC ON) - set(CMAKE_AUTORCC ON) - set(CMAKE_CXX_STANDARD 14) - set(CMAKE_CXX_STANDARD_REQUIRED ON) - set(OE_QMAKE_PATH_EXTERNAL_HOST_BINS $ENV{OE_QMAKE_PATH_HOST_BINS}) - - find_package(Qt5 COMPONENTS Core Gui QuickControls2 QuickWidgets WebSockets REQUIRED) - - PROJECT_TARGET_ADD(hellocount) - - add_executable(hellocount - "main.cpp" - "Hellocount.qrc" - ) - - set_target_properties(hellocount PROPERTIES - LABELS "EXECUTABLE" - PREFIX "" - COMPILE_FLAGS " -DFOR_AFB_BINDING" - LINK_FLAGS "${BINDINGS_LINK_FLAG}" - OUTPUT_NAME "${TARGET_NAME}" - ) - - target_link_libraries(hellocount - Qt5::WebSockets - Qt5::QuickWidgets - Qt5::QuickControls2 - json-c - libafb-helpers-qt.a - ) - ``` - -### 8. Build and Package `wgt` using autobuild - - ```sh - $ cd .. - - $ ./autobuild/agl/autobuild build - - make[1]: Entering directory '/home/boron/agl-app/newapp/build' - make[2]: Entering directory '/home/boron/agl-app/newapp/build' - make[3]: Entering directory '/home/boron/agl-app/newapp/build' - make[3]: Leaving directory '/home/boron/agl-app/newapp/build' - [100%] Built target autobuild - make[2]: Leaving directory '/home/boron/agl-app/newapp/build' - make[1]: Leaving directory '/home/boron/agl-app/newapp/build' - - - $ ./autobuild/agl/autobuild package - - make[1]: Entering directory '/home/boron/agl-app/newapp/build' - make[2]: Entering directory '/home/boron/agl-app/newapp/build' - make[3]: Entering directory '/home/boron/agl-app/newapp/build' - make[3]: Leaving directory '/home/boron/agl-app/newapp/build' - [100%] Built target autobuild - make[2]: Leaving directory '/home/boron/agl-app/newapp/build' - make[1]: Leaving directory '/home/boron/agl-app/newapp/build' - make[1]: Entering directory '/home/boron/agl-app/newapp/build' - make[2]: Entering directory '/home/boron/agl-app/newapp/build' - make[3]: Entering directory '/home/boron/agl-app/newapp/build' - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - Scanning dependencies of target prepare_package - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - [ 6%] Generating package - [ 12%] Generating package/bin - [ 18%] Generating package/etc - [ 25%] Generating package/lib - [ 31%] Generating package/htdocs - [ 37%] Generating package/var - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - [ 37%] Built target prepare_package - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - Scanning dependencies of target prepare_package_test - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - [ 43%] Generating package-test - [ 50%] Generating package-test/bin - [ 56%] Generating package-test/etc - [ 62%] Generating package-test/lib - [ 68%] Generating package-test/htdocs - [ 75%] Generating package-test/var - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - [ 75%] Built target prepare_package_test - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - Scanning dependencies of target populate - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - [ 75%] Built target populate - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - Scanning dependencies of target widget_files - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - [ 81%] Generating package/icon.png - [ 87%] Generating package/config.xml - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - [ 93%] Built target widget_files - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - Scanning dependencies of target widget - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - make[4]: Entering directory '/home/boron/agl-app/newapp/build' - [100%] Generating hellocount.wgt - NOTICE: -- PACKING widget hellocount.wgt from directory /home/boron/agl-app/newapp/build/package - ++ Install widget file using in the target : afm-util install hellocount.wgt - make[4]: Leaving directory '/home/boron/agl-app/newapp/build' - [100%] Built target widget - make[3]: Leaving directory '/home/boron/agl-app/newapp/build' - make[2]: Leaving directory '/home/boron/agl-app/newapp/build' - make[1]: Leaving directory '/home/boron/agl-app/newapp/build' - ``` - - - The `hellocount.wgt` file is packaged and available at `~/agl-app/newapp/build`. - -### 9. Install the service - - - Local System : - ```sh - # Copy hellocount.wgt to remote AGL system - $ scp ~/agl-app/newapp/build/hellocount.wgt root@:/home/0/ - ``` - - - Remote AGL System : - ```sh - # Install using the service using afm-util - $ afm-util install ./hellocount.wgt - # Reboot the system - $ reboot -f - ``` \ No newline at end of file +TBD \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/1_Usage.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/1_Usage.md deleted file mode 100644 index 80c2c08..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/1_Usage.md +++ /dev/null @@ -1,83 +0,0 @@ ---- -title: Usage ---- - -## Installation - -The afb-helpers library is integrated by default in the AGL SDK since the Guppy -version (>=7) and is also available as a package for the AGL supported linux -distributions. - -You could find the SDK build from Yocto which embed the afb-helpers library -here: - -- **x86** : [qemux86-64](https://download.automotivelinux.org/AGL/snapshots/master/latest/qemux86-64/deploy/sdk/poky-agl-glibc-x86_64-agl-demo-platform-crosssdk-corei7-64-qemux86-64-toolchain-10.90.0+snapshot.sh) - -- **ARM 32 bit** : [qemuarm](https://download.automotivelinux.org/AGL/snapshots/master/latest/qemuarm/deploy/sdk/poky-agl-glibc-x86_64-agl-demo-platform-crosssdk-armv7vet2hf-neon-vfpv4-qemuarm-toolchain-10.90.0+snapshot.sh) - -- **AARCH64 - ARM 64bit** : [qemuarm64](https://download.automotivelinux.org/AGL/snapshots/master/latest/qemuarm64/deploy/sdk/poky-agl-glibc-x86_64-agl-demo-platform-crosssdk-aarch64-qemuarm64-toolchain-10.90.0+snapshot.sh) - -Then use your package manager to install the library. - -### OpenSuse - -```bash -sudo zypper ref -sudo zypper install agl-libafb-helpers-devel -``` - -### Fedora - -```bash -sudo dnf ref -sudo dnf install agl-libafb-helpers-devel -``` - -### Ubuntu/Debian - -```bash -sudo apt-get update -sudo apt-get install agl-libafb-helpers-dev -``` - -## (Optional) Remove the git submodule version - -If you already use the afb-helpers component but using the submodule version -then you have to get rid of it to be sure to link and use the library version. -To do so, you have to do the following: - -* Deinitialize the submodule using `git` - -```bash -# This example assumes that the git submodule is named app-afb-helpers-submodule -# and is located at your root project repository. -git submodule deinit app-afb-helpers-submodule -``` - -* Remove the submodule relatives lines from the `.gitmodules` file - -```bash -vim .gitmodules -``` - -* Remove the `afb-helpers` target link from any CMake target you specified. - Those lines look like: - -```bash -TARGET_LINK_LIBRARIES(${TARGET_NAME} - afb-helpers # REMOVE THIS LINE - ${link_libraries} - ) -``` - -## Add the libafb-helpers as a static library to your binding - -In your `config.cmake` file, add a dependency to the controller library, i.e: - -```cmake -set(PKG_REQUIRED_LIST - json-c - afb-daemon - afb-helpers --> this is the afb-helpers library dependency name. -) -``` \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/2_AFB_Timer.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/2_AFB_Timer.md deleted file mode 100644 index 3af5385..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/2_AFB_Timer.md +++ /dev/null @@ -1,50 +0,0 @@ ---- -title: AFB Timer functions ---- - -## TimerHandleT - -Members are: - -* `count`: integer representing the number of times the timers should run. -* `delay`: millisecond integer representing the delay to wait before and between - the callback run. -* `uid`: a string identifying the timer. -* `context`: an opaq pointer that could be used in the callback function. -* `evtSource`: a systemd event source struct. Should be NULL. -* `api`: the AFB api pointer. -* `callback`: a function pointer for the callback to call at timer expiration -* `freeCB`: a function pointer called after expiration of the timer. Mainly meant - to release the context pointer by example. - -## void TimerEvtStart(afb_api_t api, TimerHandleT *timerHandle, timerCallbackT callback, void *context) - -Start a timer which invokes the callback when the delay expires for `count` -times. - -* `api`: AFB api pointer. -* `timerHandle`: pointer to struct representing a timer. -* `callback`: a function pointer for the callback to call at timer expiration -* `context`: an opaq pointer that could be used in the callback function. - -## void TimerEvtStop(TimerHandleT *timerHandle) - -Manually stop the timer's run. If the `count` isn't finished then it will end -the timer and no other runs will occur. - -* `timerHandle`: pointer to struct representing a timer. - -## uint64_t LockWait(afb_api_t api, uint64_t utimeout) - -It is function acting like a non-blocking sleep for an API. It lets the main API -event loop runs while you are waiting and will unlock at the first received -event and returns the remaining time to wait if an event occurs or 0 if no events -occured and timeout hits. Then you have to manually ensure that once an event -has been received that it was the one you are waiting for and if not launch again -the wait with the remaining time returned. - -* `api`: AFB api pointer. -* `timeout`: timeout in microsecond. - -Returns the remaining time in microsecond to wait if an event occurs or 0 if no -events occured and timeout hits. \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/3_CURL_wrapper.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/3_CURL_wrapper.md deleted file mode 100644 index c0361fe..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/3_CURL_wrapper.md +++ /dev/null @@ -1,113 +0,0 @@ ---- -title: CURL wrapping functions ---- - -## int curl_wrap_perform (CURL * curl, char **result, size_t * size) - -Perform the CURL operation for 'curl' and put the result in memory. If 'result' -isn't NULL it receives the returned content that then must be freed. If 'size' -isn't NULL, it receives the size of the returned content. Note that if not NULL, -the real content is one byte greater than the read size and the last byte -zero. This facility allows to handle the returned content as a null terminated -C-string. - -## void curl_wrap_do(CURL *curl, void (*callback)(void *closure, int status, CURL *curl, const char *result, size_t size), void *closure) - -Will perform the CURL operation and on success invokes the callback with the -result and size of the operation or error on a failure. - -## int curl_wrap_content_type_is (CURL * curl, const char *value) - -Request `Content-Type` information from the curl session with this function - -Returns non-zero value if the CURL content type match the `value` and 0 otherwize - -## long curl_wrap_response_code_get(CURL *curl) - -Request the response code to a CURL operation. - -Returns the response code received on success or 0 on failure. - -## CURL *curl_wrap_prepare_get_url(const char *url) - -Prepare a GET CURL operation on the url given as parameter and Returns the CURL -pointer. - -## CURL *curl_wrap_prepare_get(const char *base, const char *path, const char * const *args) - -Prepare a GET CURL operation on the decomposed url and escape it. The `url` has been -decomposed in 3 parts: - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `args`: optionnal array of arguments provided for the GET request. - -Returns the prepared CURL request. - -## int curl_wrap_add_header(CURL *curl, const char *header) - -Add a header to a CURL operation. - -Returns the prepared CURL request. - -## int curl_wrap_add_header_value(CURL *curl, const char *name, const char *value) - -Add a tuple `name`, `value` to the header of a CURL operation. - -Returns the prepared CURL request. - -## CURL *curl_wrap_prepare_post_url_data(const char *url, const char *datatype, const char *data, size_t szdata) - -Prepare a POST CURL operation on the provided `url`. - -* `url`: a HTTP url. -* `datatype`: HTTP `Content-Type` to use for the operation. -* `data`: data to send. -* `szdata`: size of the data to send. - -Returns the prepared CURL request. - -## CURL *curl_wrap_prepare_post_simple_unescaped(const char *base, const char *path, const char *args) - -Prepare a POST CURL operation on an unescaped `url` with arguments provided as -a simple string. - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `args`: optionnals argument for the POST http request. - -Returns the prepared CURL request. - -## CURL *curl_wrap_prepare_post_simple_escaped(const char *base, const char *path, char *args) - -Prepare a POST CURL operation on an escaped `url` with arguments provided as -a simple string. - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `args`: optionnals argument for the POST http request. - -Returns the prepared CURL request. - -## CURL *curl_wrap_prepare_post_unescaped(const char *base, const char *path, const char *separator, const char * const *args) - -Prepare a POST CURL operation on an unescaped `url` with arguments provided as -an array of string concatened with a provided separator string. - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `separator`: string used as a separator when concatening the arguments. -* `args`: optionnal array of arguments for the POST http request. - -Returns the prepared CURL request. - -## CURL *curl_wrap_prepare_post_escaped(const char *base, const char *path, const char * const *args) - -Prepare a POST CURL operation on an unescaped `url` with arguments provided as -an array of string concatened without any separator. - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `args`: optionnal array of arguments for the POST http request. - -Returns the prepared CURL request. \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/4_URL_Escaping.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/4_URL_Escaping.md deleted file mode 100644 index 4070acb..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/4_URL_Escaping.md +++ /dev/null @@ -1,39 +0,0 @@ ---- -title: Escaping helpers functions ---- - -## char *escape_url(const char *base, const char *path, const char * const *args, size_t *length) - -Escape an `url` and `arguments` and returned it as a string. - -* `base`: representing the FQDN of the url. -* `path`: the path to the requested page. -* `args`: optionnal array of arguments provided for the GET request. -* `length`: length of the returned `url`. - -Returns the escaped `url`. - -## const char *escape_args(const char * const *args, size_t *length) - -Escape an array of arguments and returned the lenght of the escaped arguments -string. - -* `args`: array of arguments provided for the GET request. -* `length`: length of the returned `arguments`. - -Returns the escaped `arguments`. - -## const char *escape_str(const char *str, size_t *length) - -Escape a string and returns it. - -* `str`: the string to escape. -* `length`: length of the returned string. - -Returns the escaped string. - -## const char **unescape_args(const char *args) - -Unescape an argument and returns it. - -* `args`: the argument to unescape. diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/5_Filescan_Utils.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/5_Filescan_Utils.md deleted file mode 100644 index 5b220e1..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/5_Filescan_Utils.md +++ /dev/null @@ -1,82 +0,0 @@ ---- -title: Filescan Utils functions ---- - -## const char *GetMiddleName(const char *name) - -Get rid of the binder name prefix 'afbd-' - -* name will be typically the full binder name - -Returns the process middle name of the running binder. - -## const char *GetBinderName() - -Get the Binder Name without the prefix set by the AGL appfw 'afbd-' - -Returns the Binder name without the prefix. - -## json_object* ScanForConfig (const char* searchPath, CtlScanDirModeT mode, const char *prefix, const char *extension) - -Scan a directory searching all files matching pattern: 'prefix*extention'. - -* `searchPath`: directory where to begin the searching. -* `mode`: either or not the search will be recursive. -* `prefix`: file prefix that will be looking for. -* `extention`: file extention that will be looking for. - -Returns a json_object array of object with 2 parts a 'fullpath' describing the -fullpath to reach the file and 'filename' containing the matched files. - -## char *GetAFBRootDirPathUsingFd(int fd) - -Get the binder root directory path (the path specified with '--rootdir' option -at binder launch, if the option is not used, the path from where the binder -is launched) using binder root directory file descriptor. - -* `fd` : Binder root directory file descriptor. - -Returns a string representing the path to binder root directory. - -## char *GetAFBRootDirPath(afb_api_t apiHandle) - -For binding with a version >= 3, same as 'GetAFBRootDirPathUsingFd' function, -but use pointer to the AFB API as parameter instead of -binder root directory file descriptor. - -* `apiHandle` : pointer to the AFB API. - -Returns a string representing the path to binder root directory. - -## char* GetBindingDirPath() - -For binding with a version <= 2, same as 'GetAFBRootDirPath' function, -but the pointer to the AFB API is not needed. -Kept for compatibility issues. - -## char* GetBindingDirPath(afb_api_t api) - -For binding with a version >= 3, same as 'GetAFBRootDirPath' function. -Deprecated, please use 'GetAFBRootDirPath' function. -Kept for compatibility issues. - -## char *GetRunningBindingDirPath(afb_api_t api) - -For binding with a version >= 3, get the binding directory path -(the path to the directory that contains the binding). - -* `api` : pointer to the AFB API. - -Returns a string representing the path to the binding directory. - -## const char *getEnvDirList(const char *prefix, const char *suffix) - -Get the environment directory colon separated path list. This take the prefix -add the binder's name then the suffix as environment variable name and also -search for another variable without the binder's name (so only prefix+suffix). - -* `prefix`: Environment variable prefix -* `suffix`: Environment variable suffix - -Returns a string representing a colon separated path list or NULL is case of -error or none environment variables found. \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/6_Qt_AFB_Websocket_client.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/6_Qt_AFB_Websocket_client.md deleted file mode 100644 index 5572548..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/6_Qt_AFB_Websocket_client.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -title: Qt AFB Websocket client ---- - -## QAfbWebsocketClient(QObject* parent = nullptr) - -Default constructor. - -* `parent`: Parent object. - -## QAbstractSocket::SocketError error() - -Get and return the last error code. - -## QString errorString() - -Get and return the last error as a string. - -## bool isValid() - -Check if connection is ready or not. - -Returns `true` if the connected is ready to read and write, `false` otherwise. - -## void call(const QString& api, const QString& verb, const QJsonValue& arg = QJsonValue(), closure_t closure = nullptr) - -Call an api's verb with an argument. - -* `api`: Api to call. -* `verb`: Verb to call. -* `arg`: Argument to pass. -* `closure`: callback function to call at the verb reply - -## void QAfbWebsocketClient::sendTextMessage(QString msg) - -Send a text message over the websocket. - -This is use for test only, you should not use this method because it sent text -**as-is**, so you have to follow the binder's protocol by your self. - -* `msg`: Message to send. \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/7_JSON_library_for_modern_C++.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/7_JSON_library_for_modern_C++.md deleted file mode 100644 index e807476..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/7_JSON_library_for_modern_C++.md +++ /dev/null @@ -1,894 +0,0 @@ ---- -title: JSON library for modern C++ ---- - -## Design goals - -There are myriads of [JSON](http://json.org) libraries out there, and each may even have its reason to exist. Our class had these design goals: - -- **Intuitive syntax**. In languages such as Python, JSON feels like a first class data type. We used all the operator magic of modern C++ to achieve the same feeling in your code. Check out the [examples below](#examples) and you'll know what I mean. - -- **Trivial integration**. Our whole code consists of a single header file [`json.hpp`](https://github.com/nlohmann/json/blob/develop/src/json.hpp). That's it. No library, no subproject, no dependencies, no complex build system. The class is written in vanilla C++11. All in all, everything should require no adjustment of your compiler flags or project settings. - -- **Serious testing**. Our class is heavily [unit-tested](https://github.com/nlohmann/json/blob/master/test/src/unit.cpp) and covers [100%](https://coveralls.io/r/nlohmann/json) of the code, including all exceptional behavior. Furthermore, we checked with [Valgrind](http://valgrind.org) that there are no memory leaks. To maintain high quality, the project is following the [Core Infrastructure Initiative (CII) best practices](https://bestpractices.coreinfrastructure.org/projects/289). - -Other aspects were not so important to us: - -- **Memory efficiency**. Each JSON object has an overhead of one pointer (the maximal size of a union) and one enumeration element (1 byte). The default generalization uses the following C++ data types: `std::string` for strings, `int64_t`, `uint64_t` or `double` for numbers, `std::map` for objects, `std::vector` for arrays, and `bool` for Booleans. However, you can template the generalized class `basic_json` to your needs. - -- **Speed**. There are certainly [faster JSON libraries](https://github.com/miloyip/nativejson-benchmark#parsing-time) out there. However, if your goal is to speed up your development by adding JSON support with a single header, then this library is the way to go. If you know how to use a `std::vector` or `std::map`, you are already set. - -See the [contribution guidelines](https://github.com/nlohmann/json/blob/master/.github/CONTRIBUTING.md#please-dont) for more information. - -## Integration - -The single required source, file `json.hpp` is in the `src` directory or [released here](https://github.com/nlohmann/json/releases). All you need to do is add - -```cpp -#include "json.hpp" - -// for convenience -using json = nlohmann::json; -``` - -to the files you want to use JSON objects. That's it. Do not forget to set the necessary switches to enable C++11 (e.g., `-std=c++11` for GCC and Clang). - -:beer: If you are using OS X and [Homebrew](http://brew.sh), just type `brew tap nlohmann/json` and `brew install nlohmann_json` and you're set. If you want the bleeding edge rather than the latest release, use `brew install nlohmann_json --HEAD`. - -If you are using the [Meson Build System](http://mesonbuild.com), then you can wrap this repo as a subproject. - -If you are using [Conan](https://www.conan.io/) to manage your dependencies, merely add `jsonformoderncpp/x.y.z@vthiery/stable` to your `conanfile.py`'s requires, where `x.y.z` is the release version you want to use. Please file issues [here](https://github.com/vthiery/conan-jsonformoderncpp/issues) if you experience problems with the packages. - -If you are using [hunter](https://github.com/ruslo/hunter/) on your project for external dependencies, then you can use the [nlohman_json package](https://github.com/ruslo/hunter/wiki/pkg.nlohmann_json). Please see the hunter project for any issues regarding the packaging. - -:warning: [Version 3.0.0](https://github.com/nlohmann/json/wiki/Road-toward-3.0.0) is currently under development. Branch `develop` is used for the ongoing work and is probably **unstable**. Please use the `master` branch for the last stable version 2.1.1. - -## Examples - -Beside the examples below, you may want to check the [documentation](https://nlohmann.github.io/json/) where each function contains a separate code example (e.g., check out [`emplace()`](https://nlohmann.github.io/json/classnlohmann_1_1basic__json_a602f275f0359ab181221384989810604.html#a602f275f0359ab181221384989810604)). All [example files](https://github.com/nlohmann/json/tree/develop/doc/examples) can be compiled and executed on their own (e.g., file [emplace.cpp](https://github.com/nlohmann/json/blob/develop/doc/examples/emplace.cpp)). - -### JSON as first-class data type - -Here are some examples to give you an idea how to use the class. - -Assume you want to create the JSON object - -```json -{ - "pi": 3.141, - "happy": true, - "name": "Niels", - "nothing": null, - "answer": { - "everything": 42 - }, - "list": [1, 0, 2], - "object": { - "currency": "USD", - "value": 42.99 - } -} -``` - -With the JSON class, you could write: - -```cpp -// create an empty structure (null) -json j; - -// add a number that is stored as double (note the implicit conversion of j to an object) -j["pi"] = 3.141; - -// add a Boolean that is stored as bool -j["happy"] = true; - -// add a string that is stored as std::string -j["name"] = "Niels"; - -// add another null object by passing nullptr -j["nothing"] = nullptr; - -// add an object inside the object -j["answer"]["everything"] = 42; - -// add an array that is stored as std::vector (using an initializer list) -j["list"] = { 1, 0, 2 }; - -// add another object (using an initializer list of pairs) -j["object"] = { {"currency", "USD"}, {"value", 42.99} }; - -// instead, you could also write (which looks very similar to the JSON above) -json j2 = { - {"pi", 3.141}, - {"happy", true}, - {"name", "Niels"}, - {"nothing", nullptr}, - {"answer", { - {"everything", 42} - }}, - {"list", {1, 0, 2}}, - {"object", { - {"currency", "USD"}, - {"value", 42.99} - }} -}; -``` - -Note that in all these cases, you never need to "tell" the compiler which JSON value you want to use. If you want to be explicit or express some edge cases, the functions `json::array` and `json::object` will help: - -```cpp -// a way to express the empty array [] -json empty_array_explicit = json::array(); - -// ways to express the empty object {} -json empty_object_implicit = json({}); -json empty_object_explicit = json::object(); - -// a way to express an _array_ of key/value pairs [["currency", "USD"], ["value", 42.99]] -json array_not_object = { json::array({"currency", "USD"}), json::array({"value", 42.99}) }; -``` - -### Serialization / Deserialization - -#### To/from strings - -You can create an object (deserialization) by appending `_json` to a string literal: - -```cpp -// create object from string literal -json j = "{ \"happy\": true, \"pi\": 3.141 }"_json; - -// or even nicer with a raw string literal -auto j2 = R"( - { - "happy": true, - "pi": 3.141 - } -)"_json; -``` - -Note that without appending the `_json` suffix, the passed string literal is not parsed, but just used as JSON string value. That is, `json j = "{ \"happy\": true, \"pi\": 3.141 }"` would just store the string `"{ "happy": true, "pi": 3.141 }"` rather than parsing the actual object. - -The above example can also be expressed explicitly using `json::parse()`: - -```cpp -// parse explicitly -auto j3 = json::parse("{ \"happy\": true, \"pi\": 3.141 }"); -``` - -You can also get a string representation (serialize): - -```cpp -// explicit conversion to string -std::string s = j.dump(); // {\"happy\":true,\"pi\":3.141} - -// serialization with pretty printing -// pass in the amount of spaces to indent -std::cout << j.dump(4) << std::endl; -// { -// "happy": true, -// "pi": 3.141 -// } -``` - -#### To/from streams (e.g. files, string streams) - -You can also use streams to serialize and deserialize: - -```cpp -// deserialize from standard input -json j; -std::cin >> j; - -// serialize to standard output -std::cout << j; - -// the setw manipulator was overloaded to set the indentation for pretty printing -std::cout << std::setw(4) << j << std::endl; -``` - -These operators work for any subclasses of `std::istream` or `std::ostream`. Here is the same example with files: - -```cpp -// read a JSON file -std::ifstream i("file.json"); -json j; -i >> j; - -// write prettified JSON to another file -std::ofstream o("pretty.json"); -o << std::setw(4) << j << std::endl; -``` - -Please note that setting the exception bit for `failbit` is inappropriate for this use case. It will result in program termination due to the `noexcept` specifier in use. - -#### Read from iterator range - -You can also read JSON from an iterator range; that is, from any container accessible by iterators whose content is stored as contiguous byte sequence, for instance a `std::vector`: - -```cpp -std::vector v = {'t', 'r', 'u', 'e'}; -json j = json::parse(v.begin(), v.end()); -``` - -You may leave the iterators for the range [begin, end): - -```cpp -std::vector v = {'t', 'r', 'u', 'e'}; -json j = json::parse(v); -``` - -### STL-like access - -We designed the JSON class to behave just like an STL container. In fact, it satisfies the [**ReversibleContainer**](http://en.cppreference.com/w/cpp/concept/ReversibleContainer) requirement. - -```cpp -// create an array using push_back -json j; -j.push_back("foo"); -j.push_back(1); -j.push_back(true); - -// also use emplace_back -j.emplace_back(1.78); - -// iterate the array -for (json::iterator it = j.begin(); it != j.end(); ++it) { - std::cout << *it << '\n'; -} - -// range-based for -for (auto& element : j) { - std::cout << element << '\n'; -} - -// getter/setter -const std::string tmp = j[0]; -j[1] = 42; -bool foo = j.at(2); - -// comparison -j == "[\"foo\", 1, true]"_json; // true - -// other stuff -j.size(); // 3 entries -j.empty(); // false -j.type(); // json::value_t::array -j.clear(); // the array is empty again - -// convenience type checkers -j.is_null(); -j.is_boolean(); -j.is_number(); -j.is_object(); -j.is_array(); -j.is_string(); - -// create an object -json o; -o["foo"] = 23; -o["bar"] = false; -o["baz"] = 3.141; - -// also use emplace -o.emplace("weather", "sunny"); - -// special iterator member functions for objects -for (json::iterator it = o.begin(); it != o.end(); ++it) { - std::cout << it.key() << " : " << it.value() << "\n"; -} - -// find an entry -if (o.find("foo") != o.end()) { - // there is an entry with key "foo" -} - -// or simpler using count() -int foo_present = o.count("foo"); // 1 -int fob_present = o.count("fob"); // 0 - -// delete an entry -o.erase("foo"); -``` - -### Conversion from STL containers - -Any sequence container (`std::array`, `std::vector`, `std::deque`, `std::forward_list`, `std::list`) whose values can be used to construct JSON types (e.g., integers, floating point numbers, Booleans, string types, or again STL containers described in this section) can be used to create a JSON array. The same holds for similar associative containers (`std::set`, `std::multiset`, `std::unordered_set`, `std::unordered_multiset`), but in these cases the order of the elements of the array depends how the elements are ordered in the respective STL container. - -```cpp -std::vector c_vector {1, 2, 3, 4}; -json j_vec(c_vector); -// [1, 2, 3, 4] - -std::deque c_deque {1.2, 2.3, 3.4, 5.6}; -json j_deque(c_deque); -// [1.2, 2.3, 3.4, 5.6] - -std::list c_list {true, true, false, true}; -json j_list(c_list); -// [true, true, false, true] - -std::forward_list c_flist {12345678909876, 23456789098765, 34567890987654, 45678909876543}; -json j_flist(c_flist); -// [12345678909876, 23456789098765, 34567890987654, 45678909876543] - -std::array c_array {{1, 2, 3, 4}}; -json j_array(c_array); -// [1, 2, 3, 4] - -std::set c_set {"one", "two", "three", "four", "one"}; -json j_set(c_set); // only one entry for "one" is used -// ["four", "one", "three", "two"] - -std::unordered_set c_uset {"one", "two", "three", "four", "one"}; -json j_uset(c_uset); // only one entry for "one" is used -// maybe ["two", "three", "four", "one"] - -std::multiset c_mset {"one", "two", "one", "four"}; -json j_mset(c_mset); // both entries for "one" are used -// maybe ["one", "two", "one", "four"] - -std::unordered_multiset c_umset {"one", "two", "one", "four"}; -json j_umset(c_umset); // both entries for "one" are used -// maybe ["one", "two", "one", "four"] -``` - -Likewise, any associative key-value containers (`std::map`, `std::multimap`, `std::unordered_map`, `std::unordered_multimap`) whose keys can construct an `std::string` and whose values can be used to construct JSON types (see examples above) can be used to create a JSON object. Note that in case of multimaps only one key is used in the JSON object and the value depends on the internal order of the STL container. - -```cpp -std::map c_map { {"one", 1}, {"two", 2}, {"three", 3} }; -json j_map(c_map); -// {"one": 1, "three": 3, "two": 2 } - -std::unordered_map c_umap { {"one", 1.2}, {"two", 2.3}, {"three", 3.4} }; -json j_umap(c_umap); -// {"one": 1.2, "two": 2.3, "three": 3.4} - -std::multimap c_mmap { {"one", true}, {"two", true}, {"three", false}, {"three", true} }; -json j_mmap(c_mmap); // only one entry for key "three" is used -// maybe {"one": true, "two": true, "three": true} - -std::unordered_multimap c_ummap { {"one", true}, {"two", true}, {"three", false}, {"three", true} }; -json j_ummap(c_ummap); // only one entry for key "three" is used -// maybe {"one": true, "two": true, "three": true} -``` - -### JSON Pointer and JSON Patch - -The library supports **JSON Pointer** ([RFC 6901](https://tools.ietf.org/html/rfc6901)) as alternative means to address structured values. On top of this, **JSON Patch** ([RFC 6902](https://tools.ietf.org/html/rfc6902)) allows to describe differences between two JSON values - effectively allowing patch and diff operations known from Unix. - -```cpp -// a JSON value -json j_original = R"({ - "baz": ["one", "two", "three"], - "foo": "bar" -})"_json; - -// access members with a JSON pointer (RFC 6901) -j_original["/baz/1"_json_pointer]; -// "two" - -// a JSON patch (RFC 6902) -json j_patch = R"([ - { "op": "replace", "path": "/baz", "value": "boo" }, - { "op": "add", "path": "/hello", "value": ["world"] }, - { "op": "remove", "path": "/foo"} -])"_json; - -// apply the patch -json j_result = j_original.patch(j_patch); -// { -// "baz": "boo", -// "hello": ["world"] -// } - -// calculate a JSON patch from two JSON values -json::diff(j_result, j_original); -// [ -// { "op":" replace", "path": "/baz", "value": ["one", "two", "three"] }, -// { "op": "remove","path": "/hello" }, -// { "op": "add", "path": "/foo", "value": "bar" } -// ] -``` - -### Implicit conversions - -The type of the JSON object is determined automatically by the expression to store. Likewise, the stored value is implicitly converted. - -```cpp -// strings -std::string s1 = "Hello, world!"; -json js = s1; -std::string s2 = js; - -// Booleans -bool b1 = true; -json jb = b1; -bool b2 = jb; - -// numbers -int i = 42; -json jn = i; -double f = jn; - -// etc. -``` - -You can also explicitly ask for the value: - -```cpp -std::string vs = js.get(); -bool vb = jb.get(); -int vi = jn.get(); - -// etc. -``` - -### Arbitrary types conversions - -Every type can be serialized in JSON, not just STL-containers and scalar types. Usually, you would do something along those lines: - -```cpp -namespace ns { - // a simple struct to model a person - struct person { - std::string name; - std::string address; - int age; - }; -} - -ns::person p = {"Ned Flanders", "744 Evergreen Terrace", 60}; - -// convert to JSON: copy each value into the JSON object -json j; -j["name"] = p.name; -j["address"] = p.address; -j["age"] = p.age; - -// ... - -// convert from JSON: copy each value from the JSON object -ns::person p { - j["name"].get(), - j["address"].get(), - j["age"].get() -}; -``` - -It works, but that's quite a lot of boilerplate... Fortunately, there's a better way: - -```cpp -// create a person -ns::person p {"Ned Flanders", "744 Evergreen Terrace", 60}; - -// conversion: person -> json -json j = p; - -std::cout << j << std::endl; -// {"address":"744 Evergreen Terrace","age":60,"name":"Ned Flanders"} - -// conversion: json -> person -ns::person p2 = j; - -// that's it -assert(p == p2); -``` - -#### Basic usage - -To make this work with one of your types, you only need to provide two functions: - -```cpp -using nlohmann::json; - -namespace ns { - void to_json(json& j, const person& p) { - j = json{ {"name", p.name}, {"address", p.address}, {"age", p.age} }; - } - - void from_json(const json& j, person& p) { - p.name = j.at("name").get(); - p.address = j.at("address").get(); - p.age = j.at("age").get(); - } -} // namespace ns -``` - -That's all! When calling the `json` constructor with your type, your custom `to_json` method will be automatically called. -Likewise, when calling `get()`, the `from_json` method will be called. - -Some important things: - -- Those methods **MUST** be in your type's namespace (which can be the global namespace), or the library will not be able to locate them (in this example, they are in namespace `ns`, where `person` is defined). -- When using `get()`, `your_type` **MUST** be [DefaultConstructible](http://en.cppreference.com/w/cpp/concept/DefaultConstructible). (There is a way to bypass this requirement described later.) -- In function `from_json`, use function [`at()`](https://nlohmann.github.io/json/classnlohmann_1_1basic__json_a93403e803947b86f4da2d1fb3345cf2c.html#a93403e803947b86f4da2d1fb3345cf2c) to access the object values rather than `operator[]`. In case a key does not exists, `at` throws an exception that you can handle, whereas `operator[]` exhibits undefined behavior. -- In case your type contains several `operator=` definitions, code like `your_variable = your_json;` [may not compile](https://github.com/nlohmann/json/issues/667). You need to write `your_variable = your_json.get();` instead. -- You do not need to add serializers or deserializers for STL types like `std::vector`: the library already implements these. - -#### How do I convert third-party types? - -This requires a bit more advanced technique. But first, let's see how this conversion mechanism works: - -The library uses **JSON Serializers** to convert types to json. -The default serializer for `nlohmann::json` is `nlohmann::adl_serializer` (ADL means [Argument-Dependent Lookup](http://en.cppreference.com/w/cpp/language/adl)). - -It is implemented like this (simplified): - -```cpp -template -struct adl_serializer { - static void to_json(json& j, const T& value) { - // calls the "to_json" method in T's namespace - } - - static void from_json(const json& j, T& value) { - // same thing, but with the "from_json" method - } -}; -``` - -This serializer works fine when you have control over the type's namespace. However, what about `boost::optional`, or `std::filesystem::path` (C++17)? Hijacking the `boost` namespace is pretty bad, and it's illegal to add something other than template specializations to `std`... - -To solve this, you need to add a specialization of `adl_serializer` to the `nlohmann` namespace, here's an example: - -```cpp -// partial specialization (full specialization works too) -namespace nlohmann { - template - struct adl_serializer> { - static void to_json(json& j, const boost::optional& opt) { - if (opt == boost::none) { - j = nullptr; - } else { - j = *opt; // this will call adl_serializer::to_json which will - // find the free function to_json in T's namespace! - } - } - - static void from_json(const json& j, boost::optional& opt) { - if (j.is_null()) { - opt = boost::none; - } else { - opt = j.get(); // same as above, but with - // adl_serializer::from_json - } - } - }; -} -``` - -#### How can I use `get()` for non-default constructible/non-copyable types? - -There is a way, if your type is [MoveConstructible](http://en.cppreference.com/w/cpp/concept/MoveConstructible). You will need to specialize the `adl_serializer` as well, but with a special `from_json` overload: - -```cpp -struct move_only_type { - move_only_type() = delete; - move_only_type(int ii): i(ii) {} - move_only_type(const move_only_type&) = delete; - move_only_type(move_only_type&&) = default; - - int i; -}; - -namespace nlohmann { - template <> - struct adl_serializer { - // note: the return type is no longer 'void', and the method only takes - // one argument - static move_only_type from_json(const json& j) { - return {j.get()}; - } - - // Here's the catch! You must provide a to_json method! Otherwise you - // will not be able to convert move_only_type to json, since you fully - // specialized adl_serializer on that type - static void to_json(json& j, move_only_type t) { - j = t.i; - } - }; -} -``` - -#### Can I write my own serializer? (Advanced use) - -Yes. You might want to take a look at [`unit-udt.cpp`](https://github.com/nlohmann/json/blob/develop/test/src/unit-udt.cpp) in the test suite, to see a few examples. - -If you write your own serializer, you'll need to do a few things: - -- use a different `basic_json` alias than `nlohmann::json` (the last template parameter of `basic_json` is the `JSONSerializer`) -- use your `basic_json` alias (or a template parameter) in all your `to_json`/`from_json` methods -- use `nlohmann::to_json` and `nlohmann::from_json` when you need ADL - -Here is an example, without simplifications, that only accepts types with a size <= 32, and uses ADL. - -```cpp -// You should use void as a second template argument -// if you don't need compile-time checks on T -template::type> -struct less_than_32_serializer { - template - static void to_json(BasicJsonType& j, T value) { - // we want to use ADL, and call the correct to_json overload - using nlohmann::to_json; // this method is called by adl_serializer, - // this is where the magic happens - to_json(j, value); - } - - template - static void from_json(const BasicJsonType& j, T& value) { - // same thing here - using nlohmann::from_json; - from_json(j, value); - } -}; -``` - -Be **very** careful when reimplementing your serializer, you can stack overflow if you don't pay attention: - -```cpp -template -struct bad_serializer -{ - template - static void to_json(BasicJsonType& j, const T& value) { - // this calls BasicJsonType::json_serializer::to_json(j, value); - // if BasicJsonType::json_serializer == bad_serializer ... oops! - j = value; - } - - template - static void to_json(const BasicJsonType& j, T& value) { - // this calls BasicJsonType::json_serializer::from_json(j, value); - // if BasicJsonType::json_serializer == bad_serializer ... oops! - value = j.template get(); // oops! - } -}; -``` - -### Binary formats (CBOR and MessagePack) - -Though JSON is a ubiquitous data format, it is not a very compact format suitable for data exchange, for instance over a network. Hence, the library supports [CBOR](http://cbor.io) (Concise Binary Object Representation) and [MessagePack](http://msgpack.org) to efficiently encode JSON values to byte vectors and to decode such vectors. - -```cpp -// create a JSON value -json j = R"({"compact": true, "schema": 0})"_json; - -// serialize to CBOR -std::vector v_cbor = json::to_cbor(j); - -// 0xa2, 0x67, 0x63, 0x6f, 0x6d, 0x70, 0x61, 0x63, 0x74, 0xf5, 0x66, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x00 - -// roundtrip -json j_from_cbor = json::from_cbor(v_cbor); - -// serialize to MessagePack -std::vector v_msgpack = json::to_msgpack(j); - -// 0x82, 0xa7, 0x63, 0x6f, 0x6d, 0x70, 0x61, 0x63, 0x74, 0xc3, 0xa6, 0x73, 0x63, 0x68, 0x65, 0x6d, 0x61, 0x00 - -// roundtrip -json j_from_msgpack = json::from_msgpack(v_msgpack); -``` - -## Supported compilers - -Though it's 2016 already, the support for C++11 is still a bit sparse. Currently, the following compilers are known to work: - -- GCC 4.9 - 7.1 (and possibly later) -- Clang 3.4 - 5.0 (and possibly later) -- Microsoft Visual C++ 2015 / Build Tools 14.0.25123.0 (and possibly later) -- Microsoft Visual C++ 2017 / Build Tools 15.1.548.43366 (and possibly later) - -I would be happy to learn about other compilers/versions. - -Please note: - -- GCC 4.8 does not work because of two bugs ([55817](https://gcc.gnu.org/bugzilla/show_bug.cgi?id=55817) and [57824](https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57824)) in the C++11 support. Note there is a [pull request](https://github.com/nlohmann/json/pull/212) to fix some of the issues. -- Android defaults to using very old compilers and C++ libraries. To fix this, add the following to your `Application.mk`. This will switch to the LLVM C++ library, the Clang compiler, and enable C++11 and other features disabled by default. - -```bb - APP_STL := c++_shared - NDK_TOOLCHAIN_VERSION := clang3.6 - APP_CPPFLAGS += -frtti -fexceptions -``` - -The code compiles successfully with [Android NDK](https://developer.android.com/ndk/index.html?hl=ml), Revision 9 - 11 (and possibly later) and [CrystaX's Android NDK](https://www.crystax.net/en/android/ndk) version 10. - -- For GCC running on MinGW or Android SDK, the error `'to_string' is not a member of 'std'` (or similarly, for `strtod`) may occur. Note this is not an issue with the code, but rather with the compiler itself. On Android, see above to build with a newer environment. For MinGW, please refer to [this site](http://tehsausage.com/mingw-to-string) and [this discussion](https://github.com/nlohmann/json/issues/136) for information on how to fix this bug. For Android NDK using `APP_STL := gnustl_static`, please refer to [this discussion](https://github.com/nlohmann/json/issues/219). - -The following compilers are currently used in continuous integration at [Travis](https://travis-ci.org/nlohmann/json) and [AppVeyor](https://ci.appveyor.com/project/nlohmann/json): - -| Compiler | Operating System | Version String | -|-----------------|------------------------------|----------------| -| GCC 4.9.4 | Ubuntu 14.04.5 LTS | g++-4.9 (Ubuntu 4.9.4-2ubuntu1~14.04.1) 4.9.4 | -| GCC 5.4.1 | Ubuntu 14.04.5 LTS | g++-5 (Ubuntu 5.4.1-2ubuntu1~14.04) 5.4.1 20160904 | -| GCC 6.3.0 | Ubuntu 14.04.5 LTS | g++-6 (Ubuntu/Linaro 6.3.0-18ubuntu2~14.04) 6.3.0 20170519 | -| GCC 7.1.0 | Ubuntu 14.04.5 LTS | g++-7 (Ubuntu 7.1.0-5ubuntu2~14.04) 7.1.0 -| Clang 3.5.0 | Ubuntu 14.04.5 LTS | clang version 3.5.0-4ubuntu2~trusty2 (tags/RELEASE_350/final) | -| Clang 3.6.2 | Ubuntu 14.04.5 LTS | clang version 3.6.2-svn240577-1~exp1 (branches/release_36) | -| Clang 3.7.1 | Ubuntu 14.04.5 LTS | clang version 3.7.1-svn253571-1~exp1 (branches/release_37) | -| Clang 3.8.0 | Ubuntu 14.04.5 LTS | clang version 3.8.0-2ubuntu3~trusty5 (tags/RELEASE_380/final) | -| Clang 3.9.1 | Ubuntu 14.04.5 LTS | clang version 3.9.1-4ubuntu3~14.04.2 (tags/RELEASE_391/rc2) | -| Clang 4.0.1 | Ubuntu 14.04.5 LTS | clang version 4.0.1-svn305264-1~exp1 (branches/release_40) | -| Clang 5.0.0 | Ubuntu 14.04.5 LTS | clang version 5.0.0-svn310902-1~exp1 (branches/release_50) | -| Clang Xcode 6.4 | Darwin Kernel Version 14.3.0 (OSX 10.10.3) | Apple LLVM version 6.1.0 (clang-602.0.53) (based on LLVM 3.6.0svn) | -| Clang Xcode 7.3 | Darwin Kernel Version 15.0.0 (OSX 10.10.5) | Apple LLVM version 7.3.0 (clang-703.0.29) | -| Clang Xcode 8.0 | Darwin Kernel Version 15.6.0 | Apple LLVM version 8.0.0 (clang-800.0.38) | -| Clang Xcode 8.1 | Darwin Kernel Version 16.1.0 (macOS 10.12.1) | Apple LLVM version 8.0.0 (clang-800.0.42.1) | -| Clang Xcode 8.2 | Darwin Kernel Version 16.1.0 (macOS 10.12.1) | Apple LLVM version 8.0.0 (clang-800.0.42.1) | -| Clang Xcode 8.3 | Darwin Kernel Version 16.5.0 (macOS 10.12.4) | Apple LLVM version 8.1.0 (clang-802.0.38) | -| Clang Xcode 9 beta | Darwin Kernel Version 16.6.0 (macOS 10.12.5) | Apple LLVM version 9.0.0 (clang-900.0.26) | -| Visual Studio 14 2015 | Windows Server 2012 R2 (x64) | Microsoft (R) Build Engine version 14.0.25420.1 | -| Visual Studio 2017 | Windows Server 2016 | Microsoft (R) Build Engine version 15.1.1012.6693 | - -## License - -The class is licensed under the [MIT License](http://opensource.org/licenses/MIT): - -Copyright © 2013-2017 [Niels Lohmann](http://nlohmann.me) - -Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -## Thanks - -I deeply appreciate the help of the following people. - -- [Teemperor](https://github.com/Teemperor) implemented CMake support and lcov integration, realized escape and Unicode handling in the string parser, and fixed the JSON serialization. -- [elliotgoodrich](https://github.com/elliotgoodrich) fixed an issue with double deletion in the iterator classes. -- [kirkshoop](https://github.com/kirkshoop) made the iterators of the class composable to other libraries. -- [wancw](https://github.com/wanwc) fixed a bug that hindered the class to compile with Clang. -- Tomas Åblad found a bug in the iterator implementation. -- [Joshua C. Randall](https://github.com/jrandall) fixed a bug in the floating-point serialization. -- [Aaron Burghardt](https://github.com/aburgh) implemented code to parse streams incrementally. Furthermore, he greatly improved the parser class by allowing the definition of a filter function to discard undesired elements while parsing. -- [Daniel Kopeček](https://github.com/dkopecek) fixed a bug in the compilation with GCC 5.0. -- [Florian Weber](https://github.com/Florianjw) fixed a bug in and improved the performance of the comparison operators. -- [Eric Cornelius](https://github.com/EricMCornelius) pointed out a bug in the handling with NaN and infinity values. He also improved the performance of the string escaping. -- [易思龙](https://github.com/likebeta) implemented a conversion from anonymous enums. -- [kepkin](https://github.com/kepkin) patiently pushed forward the support for Microsoft Visual studio. -- [gregmarr](https://github.com/gregmarr) simplified the implementation of reverse iterators and helped with numerous hints and improvements. In particular, he pushed forward the implementation of user-defined types. -- [Caio Luppi](https://github.com/caiovlp) fixed a bug in the Unicode handling. -- [dariomt](https://github.com/dariomt) fixed some typos in the examples. -- [Daniel Frey](https://github.com/d-frey) cleaned up some pointers and implemented exception-safe memory allocation. -- [Colin Hirsch](https://github.com/ColinH) took care of a small namespace issue. -- [Huu Nguyen](https://github.com/whoshuu) correct a variable name in the documentation. -- [Silverweed](https://github.com/silverweed) overloaded `parse()` to accept an rvalue reference. -- [dariomt](https://github.com/dariomt) fixed a subtlety in MSVC type support and implemented the `get_ref()` function to get a reference to stored values. -- [ZahlGraf](https://github.com/ZahlGraf) added a workaround that allows compilation using Android NDK. -- [whackashoe](https://github.com/whackashoe) replaced a function that was marked as unsafe by Visual Studio. -- [406345](https://github.com/406345) fixed two small warnings. -- [Glen Fernandes](https://github.com/glenfe) noted a potential portability problem in the `has_mapped_type` function. -- [Corbin Hughes](https://github.com/nibroc) fixed some typos in the contribution guidelines. -- [twelsby](https://github.com/twelsby) fixed the array subscript operator, an issue that failed the MSVC build, and floating-point parsing/dumping. He further added support for unsigned integer numbers and implemented better roundtrip support for parsed numbers. -- [Volker Diels-Grabsch](https://github.com/vog) fixed a link in the README file. -- [msm-](https://github.com/msm-) added support for american fuzzy lop. -- [Annihil](https://github.com/Annihil) fixed an example in the README file. -- [Themercee](https://github.com/Themercee) noted a wrong URL in the README file. -- [Lv Zheng](https://github.com/lv-zheng) fixed a namespace issue with `int64_t` and `uint64_t`. -- [abc100m](https://github.com/abc100m) analyzed the issues with GCC 4.8 and proposed a [partial solution](https://github.com/nlohmann/json/pull/212). -- [zewt](https://github.com/zewt) added useful notes to the README file about Android. -- [Róbert Márki](https://github.com/robertmrk) added a fix to use move iterators and improved the integration via CMake. -- [Chris Kitching](https://github.com/ChrisKitching) cleaned up the CMake files. -- [Tom Needham](https://github.com/06needhamt) fixed a subtle bug with MSVC 2015 which was also proposed by [Michael K.](https://github.com/Epidal). -- [Mário Feroldi](https://github.com/thelostt) fixed a small typo. -- [duncanwerner](https://github.com/duncanwerner) found a really embarrassing performance regression in the 2.0.0 release. -- [Damien](https://github.com/dtoma) fixed one of the last conversion warnings. -- [Thomas Braun](https://github.com/t-b) fixed a warning in a test case. -- [Théo DELRIEU](https://github.com/theodelrieu) patiently and constructively oversaw the long way toward [iterator-range parsing](https://github.com/nlohmann/json/issues/290). He also implemented the magic behind the serialization/deserialization of user-defined types. -- [Stefan](https://github.com/5tefan) fixed a minor issue in the documentation. -- [Vasil Dimov](https://github.com/vasild) fixed the documentation regarding conversions from `std::multiset`. -- [ChristophJud](https://github.com/ChristophJud) overworked the CMake files to ease project inclusion. -- [Vladimir Petrigo](https://github.com/vpetrigo) made a SFINAE hack more readable and added Visual Studio 17 to the build matrix. -- [Denis Andrejew](https://github.com/seeekr) fixed a grammar issue in the README file. -- [Pierre-Antoine Lacaze](https://github.com/palacaze) found a subtle bug in the `dump()` function. -- [TurpentineDistillery](https://github.com/TurpentineDistillery) pointed to [`std::locale::classic()`](http://en.cppreference.com/w/cpp/locale/locale/classic) to avoid too much locale joggling, found some nice performance improvements in the parser, improved the benchmarking code, and realized locale-independent number parsing and printing. -- [cgzones](https://github.com/cgzones) had an idea how to fix the Coverity scan. -- [Jared Grubb](https://github.com/jaredgrubb) silenced a nasty documentation warning. -- [Yixin Zhang](https://github.com/qwename) fixed an integer overflow check. -- [Bosswestfalen](https://github.com/Bosswestfalen) merged two iterator classes into a smaller one. -- [Daniel599](https://github.com/Daniel599) helped to get Travis execute the tests with Clang's sanitizers. -- [Jonathan Lee](https://github.com/vjon) fixed an example in the README file. -- [gnzlbg](https://github.com/gnzlbg) supported the implementation of user-defined types. -- [Alexej Harm](https://github.com/qis) helped to get the user-defined types working with Visual Studio. -- [Jared Grubb](https://github.com/jaredgrubb) supported the implementation of user-defined types. -- [EnricoBilla](https://github.com/EnricoBilla) noted a typo in an example. -- [Martin Hořeňovský](https://github.com/horenmar) found a way for a 2x speedup for the compilation time of the test suite. -- [ukhegg](https://github.com/ukhegg) found proposed an improvement for the examples section. -- [rswanson-ihi](https://github.com/rswanson-ihi) noted a typo in the README. -- [Mihai Stan](https://github.com/stanmihai4) fixed a bug in the comparison with `nullptr`s. -- [Tushar Maheshwari](https://github.com/tusharpm) added [cotire](https://github.com/sakra/cotire) support to speed up the compilation. -- [TedLyngmo](https://github.com/TedLyngmo) noted a typo in the README, removed unnecessary bit arithmetic, and fixed some `-Weffc++` warnings. -- [Krzysztof Woś](https://github.com/krzysztofwos) made exceptions more visible. -- [ftillier](https://github.com/ftillier) fixed a compiler warning. -- [tinloaf](https://github.com/tinloaf) made sure all pushed warnings are properly popped. -- [Fytch](https://github.com/Fytch) found a bug in the documentation. -- [Jay Sistar](https://github.com/Type1J) implemented a Meson build description. -- [Henry Lee](https://github.com/HenryRLee) fixed a warning in ICC and improved the iterator implementation. -- [Vincent Thiery](https://github.com/vthiery) maintains a package for the Conan package manager. -- [Steffen](https://github.com/koemeet) fixed a potential issue with MSVC and `std::min`. -- [Mike Tzou](https://github.com/Chocobo1) fixed some typos. -- [amrcode](https://github.com/amrcode) noted a missleading documentation about comparison of floats. -- [Oleg Endo](https://github.com/olegendo) reduced the memory consumption by replacing `` with ``. -- [dan-42](https://github.com/dan-42) cleaned up the CMake files to simplify including/reusing of the library. -- [Nikita Ofitserov](https://github.com/himikof) allowed for moving values from initializer lists. -- [Greg Hurrell](https://github.com/wincent) fixed a typo. -- [Dmitry Kukovinets](https://github.com/DmitryKuk) fixed a typo. -- [kbthomp1](https://github.com/kbthomp1) fixed an issue related to the Intel OSX compiler. -- [Markus Werle](https://github.com/daixtrose) fixed a typo. -- [WebProdPP](https://github.com/WebProdPP) fixed a subtle error in a precondition check. - -Thanks a lot for helping out! Please [let me know](mailto:mail@nlohmann.me) if I forgot someone. - -## Used third-party tools - -The library itself contains of a single header file licensed under the MIT license. However, it is built, tested, documented, and whatnot using a lot of third-party tools and services. Thanks a lot! - -- [**American fuzzy lop**](http://lcamtuf.coredump.cx/afl/) for fuzz testing -- [**AppVeyor**](https://www.appveyor.com) for [continuous integration](https://ci.appveyor.com/project/nlohmann/json) on Windows -- [**Artistic Style**](http://astyle.sourceforge.net) for automatic source code identation -- [**benchpress**](https://github.com/sbs-ableton/benchpress) to benchmark the code -- [**Catch**](https://github.com/philsquared/Catch) for the unit tests -- [**Clang**](http://clang.llvm.org) for compilation with code sanitizers -- [**Cmake**](https://cmake.org) for build automation -- [**Codacity**](https://www.codacy.com) for further [code analysis](https://www.codacy.com/app/nlohmann/json) -- [**cotire**](https://github.com/sakra/cotire) to speed of compilation -- [**Coveralls**](https://coveralls.io) to measure [code coverage](https://coveralls.io/github/nlohmann/json) -- [**Coverity Scan**](https://scan.coverity.com) for [static analysis](https://scan.coverity.com/projects/nlohmann-json) -- [**cppcheck**](http://cppcheck.sourceforge.net) for static analysis -- [**cxxopts**](https://github.com/jarro2783/cxxopts) to let benchpress parse command-line parameters -- [**Doxygen**](http://www.stack.nl/~dimitri/doxygen/) to generate [documentation](https://nlohmann.github.io/json/) -- [**git-update-ghpages**](https://github.com/rstacruz/git-update-ghpages) to upload the documentation to gh-pages -- [**Github Changelog Generator**](https://github.com/skywinder/github-changelog-generator) to generate the [ChangeLog](https://github.com/nlohmann/json/blob/develop/ChangeLog.md) -- [**libFuzzer**](http://llvm.org/docs/LibFuzzer.html) to implement fuzz testing for OSS-Fuzz -- [**OSS-Fuzz**](https://github.com/google/oss-fuzz) for continuous fuzz testing of the library -- [**send_to_wandbox**](https://github.com/nlohmann/json/blob/develop/doc/scripts/send_to_wandbox.py) to send code examples to [Wandbox](http://melpon.org/wandbox) -- [**Travis**](https://travis-ci.org) for [continuous integration](https://travis-ci.org/nlohmann/json) on Linux and macOS -- [**Valgrind**](http://valgrind.org) to check for correct memory management -- [**Wandbox**](http://melpon.org/wandbox) for [online examples](http://melpon.org/wandbox/permlink/4NEU6ZZMoM9lpIex) - -## Projects using JSON for Modern C++ - -The library is currently used in Apple macOS Sierra and iOS 10. I am not sure what they are using the library for, but I am happy that it runs on so many devices. - -## Notes - -- The code contains numerous debug **assertions** which can be switched off by defining the preprocessor macro `NDEBUG`, see the [documentation of `assert`](http://en.cppreference.com/w/cpp/error/assert). In particular, note [`operator[]`](https://nlohmann.github.io/json/classnlohmann_1_1basic__json_a2e26bd0b0168abb61f67ad5bcd5b9fa1.html#a2e26bd0b0168abb61f67ad5bcd5b9fa1) implements **unchecked access** for const objects: If the given key is not present, the behavior is undefined (think of a dereferenced null pointer) and yields an [assertion failure](https://github.com/nlohmann/json/issues/289) if assertions are switched on. If you are not sure whether an element in an object exists, use checked access with the [`at()` function](https://nlohmann.github.io/json/classnlohmann_1_1basic__json_a674de1ee73e6bf4843fc5dc1351fb726.html#a674de1ee73e6bf4843fc5dc1351fb726). -- As the exact type of a number is not defined in the [JSON specification](http://rfc7159.net/rfc7159), this library tries to choose the best fitting C++ number type automatically. As a result, the type `double` may be used to store numbers which may yield [**floating-point exceptions**](https://github.com/nlohmann/json/issues/181) in certain rare situations if floating-point exceptions have been unmasked in the calling code. These exceptions are not caused by the library and need to be fixed in the calling code, such as by re-masking the exceptions prior to calling library functions. -- The library supports **Unicode input** as follows: - - Only **UTF-8** encoded input is supported which is the default encoding for JSON according to [RFC 7159](http://rfc7159.net/rfc7159#rfc.section.8.1). - - Other encodings such as Latin-1, UTF-16, or UTF-32 are not supported and will yield parse errors. - - [Unicode noncharacters](http://www.unicode.org/faq/private_use.html#nonchar1) will not be replaced by the library. - - Invalid surrogates (e.g., incomplete pairs such as `\uDEAD`) will yield parse errors. - - The strings stored in the library are UTF-8 encoded. When using the default string type (`std::string`), note that its length/size functions return the number of stored bytes rather than the number of characters or glyphs. -- The code can be compiled without C++ **runtime type identification** features; that is, you can use the `-fno-rtti` compiler flag. -- **Exceptions** are used widely within the library. They can, however, be switched off with either using the compiler flag `-fno-exceptions` or by defining the symbol `JSON_NOEXCEPTION`. In this case, exceptions are replaced by an `abort()` call. -- By default, the library does not preserve the **insertion order of object elements**. This is standards-compliant, as the [JSON standard](https://tools.ietf.org/html/rfc7159.html) defines objects as "an unordered collection of zero or more name/value pairs". If you do want to preserve the insertion order, you can specialize the object type with containers like [`tsl::ordered_map`](https://github.com/Tessil/ordered-map) or [`nlohmann::fifo_map`](https://github.com/nlohmann/fifo_map). - -## Execute unit tests - -To compile and run the tests, you need to execute - -```sh -$ make json_unit -Ctest -$ ./test/json_unit "*" - -=============================================================================== -All tests passed (14504461 assertions in 48 test cases) -``` - -Alternatively, you can use [CMake](https://cmake.org) and run - -```sh -mkdir build -cd build -cmake .. -make -ctest -``` - -For more information, have a look at the file [.travis.yml](https://github.com/nlohmann/json/blob/master/.travis.yml). \ No newline at end of file diff --git a/docs/3_Developer_Guides/4_AFB_Helper_Guide/8_C_JSON_Wrapper.md b/docs/3_Developer_Guides/4_AFB_Helper_Guide/8_C_JSON_Wrapper.md deleted file mode 100644 index e106a18..0000000 --- a/docs/3_Developer_Guides/4_AFB_Helper_Guide/8_C_JSON_Wrapper.md +++ /dev/null @@ -1,341 +0,0 @@ ---- -title: C JSON Wrapper ---- - - - -WRAP-JSON facility -================== - -The facility wrap-json is based on the pack/unpack API on the -library jansson. The two chapters below are copied from the -documentation of jansson library copyrighted by Petri Lehtinen -(see at end). - -Building Values ---------------- - -This section describes functions that help to create, or *pack*, complex -JSON values, especially nested objects and arrays. Value building is -based on a *format string* that is used to tell the functions about the -expected arguments. - -For example, the format string `"i"` specifies a single integer value, -while the format string `"[ssb]"` or the equivalent `"[s, s, b]"` -specifies an array value with two strings and a boolean as its items: - - /* Create the JSON integer 42 */ - wrap_json_pack(&result, "i", 42); - - /* Create the JSON array ["foo", "bar", true] */ - wrap_json_pack(&result, "[ssb]", "foo", "bar", 1); - -Here's the full list of format specifiers. The type in parentheses -denotes the resulting JSON type, and the type in brackets (if any) -denotes the C type that is expected as the corresponding argument or -arguments. - -- `s` (string) \[const char \*\] - - Convert a null terminated UTF-8 string to a JSON string. - -- `s?` (string) \[const char \*\] - - Like `s`, but if the argument is *NULL*, output a JSON null value. - -- `s*` (string) \[const char \*\] - - Like `s`, but if the argument is *NULL*, do not output any value. - This format can only be used inside an object or an array. If used - inside an object, the corresponding key is additionally suppressed - when the value is omitted. See below for an example. - -- `s#` (string) \[const char \*, int\] - - Convert a UTF-8 buffer of a given length to a JSON string. - -- `s%` (string) \[const char \*, size\_t\] - - Like `s#` but the length argument is of type size\_t. - -- `+` \[const char \*\] - - Like `s`, but concatenate to the previous string. Only valid after - `s`, `s#`, `+` or `+#`. - -- `+#` \[const char \*, int\] - - Like `s#`, but concatenate to the previous string. Only valid after - `s`, `s#`, `+` or `+#`. - -- `+%` (string) \[const char \*, size\_t\] - - Like `+#` but the length argument is of type size\_t. - -- `y` (byte array) \[const uint8_t \*, size\_t\] - - Convert the byte array whose length is given to - its base64url string representation. - -- `Y` (byte array) \[const uint8_t \*, size\_t\] - - Like 'y' but output is base64. - -- `y?`, `Y?` (byte array or null) \[const uint8_t \*, size\_t\] - - Like 'y' or 'Y' but allows to output a JSON null value - either when the buffer is *NULL* or when the size is *0*. - -- `y*`, `y*` (optional byte array) \[const uint8_t \*, size\_t\] - - Like 'y' or 'Y' but do not put JSON value - either when the buffer is *NULL* or when the size is *0*. - This format can only be used inside an object or an array. If used - inside an object, the corresponding key is additionally suppressed - when the value is omitted. See below for an example. - -- `n` (null) - - Output a JSON null value. No argument is consumed. - -- `b` (boolean) \[int\] - - Convert a C int to JSON boolean value. Zero is converted to `false` - and non-zero to `true`. - -- `i` (integer) \[int\] - - Convert a C int to JSON integer. - -- `I` (integer) \[json\_int\_t\] - - Convert a C json\_int\_t to JSON integer. - -- `f` (real) \[double\] - - Convert a C double to JSON real. - -- `o` (any value) \[json\_t \*\] - - Output any given JSON value as-is. If the value is added to an array - or object, the reference to the value passed to `o` is stolen by the - container. - -- `O` (any value) \[json\_t \*\] - - Like `o`, but the argument's reference count is incremented. This is - useful if you pack into an array or object and want to keep the - reference for the JSON value consumed by `O` to yourself. - -- `o?`, `O?` (any value) \[json\_t \*\] - - Like `o` and `O`, respectively, but if the argument is *NULL*, - output a JSON null value. - -- `o*`, `O*` (any value) \[json\_t \*\] - - Like `o` and `O`, respectively, but if the argument is *NULL*, do - not output any value. This format can only be used inside an object - or an array. If used inside an object, the corresponding key is - additionally suppressed. See below for an example. - -- `[fmt]` (array) - - Build an array with contents from the inner format string. `fmt` may - contain objects and arrays, i.e. recursive value building is - supported. - -- `{fmt}` (object) - - Build an object with contents from the inner format string `fmt`. - The first, third, etc. format specifier represent a key, and must be - a string (see `s`, `s#`, `+` and `+#` above), as object keys are - always strings. The second, fourth, etc. format specifier represent - a value. Any value may be an object or array, i.e. recursive value - building is supported. - -Whitespace, `:` and `,` are ignored. - -More examples: - - /* Build an empty JSON object */ - wrap_json_pack(&result, "{}"); - - /* Build the JSON object {"foo": 42, "bar": 7} */ - wrap_json_pack(&result, "{sisi}", "foo", 42, "bar", 7); - - /* Like above, ':', ',' and whitespace are ignored */ - wrap_json_pack(&result, "{s:i, s:i}", "foo", 42, "bar", 7); - - /* Build the JSON array [[1, 2], {"cool": true}] */ - wrap_json_pack(&result, "[[i,i],{s:b}]", 1, 2, "cool", 1); - - /* Build a string from a non-null terminated buffer */ - char buffer[4] = {'t', 'e', 's', 't'}; - wrap_json_pack(&result, "s#", buffer, 4); - - /* Concatenate strings together to build the JSON string "foobarbaz" */ - wrap_json_pack(&result, "s++", "foo", "bar", "baz"); - - /* Create an empty object or array when optional members are missing */ - wrap_json_pack(&result, "{s:s*,s:o*,s:O*}", "foo", NULL, "bar", NULL, "baz", NULL); - wrap_json_pack(&result, "[s*,o*,O*]", NULL, NULL, NULL); - -Parsing and Validating Values ------------------------------ - -This section describes functions that help to validate complex values -and extract, or *unpack*, data from them. Like building values -<apiref-pack>, this is also based on format strings. - -While a JSON value is unpacked, the type specified in the format string -is checked to match that of the JSON value. This is the validation part -of the process. In addition to this, the unpacking functions can also -check that all items of arrays and objects are unpacked. This check be -enabled with the format specifier `!` or by using the flag -`JSON_STRICT`. See below for details. - -Here's the full list of format specifiers. The type in parentheses -denotes the JSON type, and the type in brackets (if any) denotes the C -type whose address should be passed. - -- `s` (string) \[const char \*\] - - Convert a JSON string to a pointer to a null terminated UTF-8 - string. The resulting string is extracted by using - json\_string\_value() internally, so it exists as long as there are - still references to the corresponding JSON string. - -- `s%` (string) \[const char \*, size\_t \*\] - - Convert a JSON string to a pointer to a null terminated UTF-8 string - and its length. - -- `y` (byte array) \[uint8_t \*\*, size\_t \*\] - - Convert an input string base64url encoded to its - byte array representation. The result and its length - are stored. The returned buffer must be freed by the caller. - -- `Y` (byte array) \[uint8_t \*\*, size\_t \*\] - - Like 'y' but input is base64. - -- `n` (null) - - Expect a JSON null value. Nothing is extracted. - -- `b` (boolean) \[int\] - - Convert a JSON boolean value to a C int, so that `true` is converted - to 1 and `false` to 0. - -- `i` (integer) \[int\] - - Convert a JSON integer to C int. - -- `I` (integer) \[json\_int\_t\] - - Convert a JSON integer to C json\_int\_t. - -- `f` (real) \[double\] - - Convert a JSON real to C double. - -- `F` (integer or real) \[double\] - - Convert a JSON number (integer or real) to C double. - -- `o` (any value) \[json\_t \*\] - - Store a JSON value with no conversion to a json\_t pointer. - -- `O` (any value) \[json\_t \*\] - - Like `O`, but the JSON value's reference count is incremented. - -- `[fmt]` (array) - - Convert each item in the JSON array according to the inner format - string. `fmt` may contain objects and arrays, i.e. recursive value - extraction is supported. - -- `{fmt}` (object) - - Convert each item in the JSON object according to the inner format - string `fmt`. The first, third, etc. format specifier represent a - key, and must be `s`. The corresponding argument to unpack functions - is read as the object key. The second fourth, etc. format specifier - represent a value and is written to the address given as the - corresponding argument. **Note** that every other argument is read - from and every other is written to. - - `fmt` may contain objects and arrays as values, i.e. recursive value - extraction is supported. - -- `!` - - This special format specifier is used to enable the check that all - object and array items are accessed, on a per-value basis. It must - appear inside an array or object as the last format specifier before - the closing bracket or brace. - -- `*` - - This special format specifier is the opposite of `!`. This is the default. - It must appear inside an array or object as the last format specifier - before the closing bracket or brace. - -Whitespace, `:` and `,` are ignored. - -Examples: - - /* root is the JSON integer 42 */ - int myint; - wrap_json_unpack(root, "i", &myint); - assert(myint == 42); - - /* root is the JSON object {"foo": "bar", "quux": true} */ - const char *str; - int boolean; - wrap_json_unpack(root, "{s:s, s:b}", "foo", &str, "quux", &boolean); - assert(strcmp(str, "bar") == 0 && boolean == 1); - - /* root is the JSON array [[1, 2], {"baz": null} */ - wrap_json_check(root, "[[i,i], {s:n}]", "baz"); - /* returns 0 for validation success, nothing is extracted */ - - /* root is the JSON array [1, 2, 3, 4, 5] */ - int myint1, myint2; - wrap_json_unpack(root, "[ii!]", &myint1, &myint2); - /* returns -1 for failed validation */ - - /* root is an empty JSON object */ - int myint = 0, myint2 = 0, myint3 = 0; - wrap_json_unpack(root, "{s?i, s?[ii]}", - "foo", &myint1, - "bar", &myint2, &myint3); - /* myint1, myint2 or myint3 is no touched as "foo" and "bar" don't exist */ - -Copyright ---------- - -Copyright (c) 2009-2016 Petri Lehtinen - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/1_Project_Architecture.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/1_Project_Architecture.md deleted file mode 100644 index 0602ea1..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/1_Project_Architecture.md +++ /dev/null @@ -1,74 +0,0 @@ ---- -title: Project Architecture ---- - -The following tree structure represents a typical CMake project -directory structure: - -```tree - -| -├── CMakeLists.txt -│ -├── autobuild/ -│ ├── agl -│ │ └── autobuild -│ ├── linux -│ │ └── autobuild -│ └── windows -│ └── autobuild -├── conf.d/ -│ ├── packaging/ -│ │ ├── rpm -│ │ │ └── package.spec -│ │ └── deb -│ │ ├── package.dsc -│ │ ├── debian.package.install -│ │ ├── debian.changelog -│ │ ├── debian.compat -│ │ ├── debian.control -│ │ └── debian.rules -│ ├── cmake -│ │ ├── 00-debian-osconfig.cmake -│ │ ├── 00-suse-osconfig.cmake -│ │ ├── 01-default-osconfig.cmake -│ │ └── config.cmake -│ └── wgt -│ ├── icon.png -│ └── config.xml.in -├── -│ └── -├── -│ └── -└── - └── -``` - -| File or Directory | Parent | Description | -|----|----|----| -| *root_path* | n/a | CMake project root path. Holds the master CMakeLists.txt file and all general project files. -| CMakeLists.txt | The master CMakeLists.txt file. -| autobuild/ | *root_path* | Scripts generated from app-templates to build packages the same way for differents platforms. -| conf.d/ | *root_path* | Holds needed files to build, install, debug, and package an AGL application project. -| packaging/ | conf.d/ | Contains output files used to build packages. -| cmake/ | conf.d/ | Minimally contains the config.cmake file, which is modified from the sample provided in the app-templates submodule. -| wgt/ | conf.d/ | Contains config.xml.in and optionaly the test-config.xml.in template files that are modified from the sample provided with the CMake module for the needs of the project. For more details, see the config.xml.in.sample and test-config.xml.in.sample files. -| *target* | *root_path* | A target to build, which is typically a library or executable. - -When building projects using CMake, the build process automatically detects -the `CMakeLists.txt` and `*.cmake` files. -To help with this process, the `PROJECT_SRC_DIR_PATTERN` variable -is used for recursive pattern searching from the CMake project's -*root_path* downward. -Each sub-folder below *root_path* in the project is searched and included -during compilation. -The directories matching the pattern `PROJECT_SRC_DIR_PATTERN` variable -are scanned. - -**NOTE:** The `PROJECT_SRC_DIR_PATTERN` variable defaults to "*". - -When the `CMakeLists.txt` file is found, the directory in which it is found -is automatically added to the CMake project. - -Similarly, when a file whose extension is `.cmake` is found, the directory in -which that file resides is also added to the CMake project. \ No newline at end of file diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/2_Configuring_AGL_CMake_Templates.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/2_Configuring_AGL_CMake_Templates.md deleted file mode 100644 index a4570ee..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/2_Configuring_AGL_CMake_Templates.md +++ /dev/null @@ -1,136 +0,0 @@ ---- -title: Configuring AGL CMake Templates ---- - -Configuration consists of editing the `config.cmake` file for your -specific project. - -## Creating Your `config.cmake` File - -First, you need to create a `confd/cmake` file in your CMake project -directory. - -```bash -mkdir -p conf.d/cmake -``` - -Next, use one of the following commands to copy a `cmake.sample` file to -your `config.cmake` file. -The first command applies if you have the SDK installed, while the -second command applies if you installed the modules on your native Linux system. - -**NOTE:** The `OECORE_NATIVE_SYSROOT` variable is defined once you have -a project folder, the AGL SDK source files, and the CMake modules installed. - -```bash -mkdir -p conf.d/cmake -# From the SDK sysroot >= RC2 of the 7.0.0 Guppy release -cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/config.cmake.sample conf.d/cmake/config.cmake -``` - -Once you have created your `config.cmake` file, you need to make the changes -specific to your project. - -## Creating Your `CMakeLists.txt` File - -To create this file, use the example in the **cmake module**. -Use one of the following two commands to create your file. -The first command applies if you have the SDK installed, while the -second command applies if you installed the modules on your native Linux system. - -**NOTE:** The `OECORE_NATIVE_SYSROOT` variable is defined once you have -a project folder, the AGL SDK source files, and the CMake modules installed. - -```bash -# From the SDK sysroot >= RC2 of the 7.0.0 Guppy release -cp ${OECORE_NATIVE_SYSROOT}/usr/share/doc/CMakeAfbTemplates/samples.d/CMakeLists.txt.sample CMakeLists.txt -``` - -## Creating Your CMake Targets - -Creating a CMake target is the result of editing your `CMakeLists.txt` file. - -For each target that is part of your project, you need to use the -***PROJECT_TARGET_ADD*** statement. -Using this statement includes the target in your project. - -Using the ***PROJECT_TARGET_ADD*** statement makes the CMake ***TARGET_NAME*** -variable available until the next ***PROJECT_TARGET_ADD*** statement is -encountered that uses a new target name. - -Following is typical use within the `CMakeLists.txt` file to create a target: - -```cmake -PROJECT_TARGET_ADD(target_name) --> Adds *target_name* to the project. -*target_name* is a sub-folder in the CMake project. - -add_executable/add_library(${TARGET_NAME}.... --> Defines the target sources. - -SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES.... --> Configures the target properties -so they can be used by macros. - -INSTALL(TARGETS ${TARGET_NAME}.... -``` - -## Target Properties - -Target properties are used to determine the nature of the -target and where the target is stored within the package being built. - -Use the **LABELS** property to specify the target type that you want -included in the widget package. -You can choose the following target types: - -Choose between: - -- **BINDING**: A shared library loaded by the AGL Application Framework. -- **BINDINGV2**: A shared library loaded by the AGL Application Framework. - This library must be accompanied by a JSON file named similar to the - *${OUTPUT_NAME}-apidef* of the target, which describes the API with OpenAPI - syntax (e.g: *mybinding-apidef*). - Alternatively, you can choose the name without the extension using the - **set_openapi_filename** macro. - If you use C++, you must set **PROJECT_LANGUAGES** through *CXX*. -- **BINDINGV3**: A shared library loaded by the AGL Application Framework. - This library must be accompanied by a JSON file named similar to the - *${OUTPUT_NAME}-apidef* of the target, which describes the API with OpenAPI - syntax (e.g: *mybinding-apidef*). - Alternatively, you can choose the name without the extension using the - **set_openapi_filename** macro. - If you use C++, you must set **PROJECT_LANGUAGES** through *CXX*. -- **PLUGIN**: A shared library meant to be used as a binding plugin, which - would load the library as a plugin consequently extending its - functionalities. - You should name the binding using a special extension that you choose - with `SUFFIX cmake target property`. - If you do not use the special extension, it defaults to **.ctlso**. -- **HTDOCS**: The root directory of a web application. - This target has to build its directory and puts its files in the - **${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME}**. -- **DATA**: Resources used by your application. - This target has to build its directory and puts its files in the - **${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME}**. -- **EXECUTABLE**: The entry point of your application executed by the AGL - Application Framework. -- **LIBRARY**: An external third-party library bundled with the binding. - The library is bundled in this manner because the platform does not - provide bundling. -- **BINDING-CONFIG**: Any files used as configuration by your binding. - -**TIP:** you should use the prefix _afb-_ (**Application Framework Binding**) -with your *BINDING* targets. - -Following is an example that uses the **BINDINGV3** property: - -```cmake -SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES - PREFIX "afb-" - LABELS "BINDINGV3" - OUTPUT_NAME "file_output_name") -``` - -**CAUTION**: You do not need to specify an **INSTALL** command for these -targets. -Installation is performed by the template. -Targets are installed in the **${CMAKE_INSTALL_PREFIX}/${PROJECT_NAME}** -directory. \ No newline at end of file diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/3_Advanced_Usage.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/3_Advanced_Usage.md deleted file mode 100644 index 13edf32..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/3_Advanced_Usage.md +++ /dev/null @@ -1,305 +0,0 @@ ---- -title: Advanced Usage ---- - -This topic describes some advanced ways of using the CMake templates. - -## Building a Widget - -To build a widget, you need a `config.xml` file that describes -your application (widget) and how the Application Framework launches it. -Your repository contains a simple default file named -`config.xml.in` that should work for simple applications and should -not require interactions with other bindings. - -It is also recommended that you use the sample configuration -file that you can find in the location. -This file is named `config.xms.in.sample` and is more complete. -Copy the sample file to your `conf.d/wgt` directory and name it -`config.xml.in`. -Once you have your copy, edit the file to fit your needs. - -**CAUTION:** The default file is only meant to be used for a -simple widget application. -For more complicated applications that need to export -their API, or ship several applications in one widget -need to use the provided `config.xml.in.sample` file, which has -all new Application Framework features explained and provides -examples. - -## Using CMake Template Macros - -To leverage all CMake template features, you must specify properties -on your targets. -Some macros do not work unless you specify the target type. -If you do not specify a type (e.g. a custom target such as an -HTML5 application), the macro uses the `LABELS` property to -determine the target type. - -Aside from those values, the following optional values can be -assigned to the `LABELS` property. -These values define the resource types that make up your test materials: - -- **TEST-CONFIG**: JSON configuration files used by the `afb-test` - binding. - These files execute the tests. -- **TEST-DATA**: Resources used to test your binding. - Minimally, you need a test plan. - You should also consider fixtures and any files required by your tests. - These required files appear as part of a separate test widget. -- **TEST-PLUGIN**: A shared library used as a binding plugin. - A binding loads the library as a plugin to extend the binding's functionality. - You should use a special file extension when you name the library - by using the `SUFFIX` CMake target property. - If you do not choose an extension, `.ctlso` is used by default. -- **TEST-HTDOCS**: The root directory of a web application. - This target has to build its directory and put its files in - the `${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME}` directory. -- **TEST-EXECUTABLE**: The entry point of your application executed by the AGL - Application Framework. -- **TEST-LIBRARY**: An external third-party library bundled with the binding - for its own purpose. - The platform does not provide this library. - -Following is a mapping between `LABELS` and directories where files reside in -the widget: - -- **EXECUTABLE** : `/bin` -- **BINDING-CONFIG** : `/etc` -- **BINDING** | **BINDINGV2** | **BINDINGV3** | **LIBRARY** : `/lib` -- **PLUGIN** : `/lib/plugins` -- **HTDOCS** : `/htdocs` -- **BINDING-DATA** : `/var` -- **DATA** : `/var` - -Following is a mapping between test-dedicated `LABELS` and directories where -files reside in the widget: - -- **TEST-EXECUTABLE** : `/bin` -- **TEST-CONFIG** : `/etc` -- **TEST-PLUGIN** : `/lib/plugins` -- **TEST-HTDOCS** : `/htdocs` -- **TEST-DATA** : `/var` - -**TIP:** Use the prefix `afb-` (Application Framework Binding) -with your **BINDING** targets. - -Following is an example that sets the `LABELS` and `OUTPUT_NAME` properties: - -```cmake -SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES - LABELS "HTDOCS" - OUTPUT_NAME dist.prod - ) -``` - -**NOTE**: You do not need to specify an **INSTALL** command for these - targets. - Installation is handled by the template and installs using the - following path : **${CMAKE_INSTALL_PREFIX}/${PROJECT_NAME}** - - Also, if you want to set and use `rpath` with your target, you should use - and set the target property `INSTALL_RPATH`. - -## Adding an External Third-Party Library - -You can add an external third-party library that is built, linked, -and shipped with the project. -Or, you can link and ship the library only with the project. - -### Building, Linking, and Shipping an External Library with the Project - -If you need to include an external library that is not shipped -with the project, you can bundle the required library in the -`lib` widget directory. - -Templates includes facilities to help you work with external -libraries. -A standard method is to declare as many CMake ExternalProject -modules as you need to match the number of needed libraries. - -An ExternalProject module is a special CMake module that lets you define how -to download, update, patch, configure, build, and install an external project. -The project does not need to be a CMake project. -Additionally, you can provide custom steps to account for special -needs using ExternalProject step. -See the CMake -[ExternalProject documentation site](https://cmake.org/cmake/help/v3.5/module/ExternalProject.html?highlight=externalproject) -for more information. - -Following is an example that includes the `mxml` library for the -[unicens2-binding](https://github.com/iotbzh/unicens2-binding) -project: - -```cmake -set(MXML external-mxml) -set(MXML_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/mxml) -ExternalProject_Add(${MXML} - GIT_REPOSITORY https://github.com/michaelrsweet/mxml.git - GIT_TAG release-2.10 - SOURCE_DIR ${MXML_SOURCE_DIR} - CONFIGURE_COMMAND ./configure --build x86_64 --host aarch64 - BUILD_COMMAND make libmxml.so.1.5 - BUILD_IN_SOURCE 1 - INSTALL_COMMAND "" -) - -PROJECT_TARGET_ADD(mxml) - -add_library(${TARGET_NAME} SHARED IMPORTED GLOBAL) - -SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES - LABELS LIBRARY - IMPORTED_LOCATION ${MXML_SOURCE_DIR}/libmxml.so.1 - INTERFACE_INCLUDE_DIRECTORIES ${MXML_SOURCE_DIR} -) - -add_dependencies(${TARGET_NAME} ${MXML}) -``` - -The example defines an external project that drives the building of the library. -The example also defines a new CMake target whose type is **IMPORTED**. -The **IMPORTED** target type indicates the target has yet to be built using -CMake but is available at the location defined using the **IMPORTED_LOCATION** -target property. - -You might want to build the library as **SHARED** or **STATIC** depending on your needs -and goals. -Next, the example only has to modify the external project configure step and change -the filename used by **IMPORTED** library target defined after external project. - -The target's **LABELS** property is set to **LIBRARY** to ship it in the widget. - -In this example, the Unicens project also needs header -information from this library. -Consequently, the **INTERFACE_INCLUDE_DIRECTORIES** target property -is used. -Setting that property when another target links to that imported target -allows access to included directories. - -Finally, the example binds the target to the external project -by using a CMake dependency. - -The target can now be linked and used like any other CMake target. - -### Link and Ship an External Library with the Project - -If you already have a binary version of the library that you want to use and you -cannot or do not want to build the library, you can use the **IMPORTED** -library target. - -To illustrate, consider the same example in the previous section. -Following are the relevant modifications: - -```cmake -PROJECT_TARGET_ADD(mxml) - -add_library(${TARGET_NAME} SHARED IMPORTED GLOBAL) - -SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES - LABELS LIBRARY - IMPORTED_LOCATION /path_to_library/libmxml.so.1 - INTERFACE_INCLUDE_DIRECTORIES /path_to_mxml/include/dir -) -``` - -In the previous example, notice the changes to the -`IMPORTED_LOCATION` and `INTERFACE_INCLUDE_DIRECTORIES` statements. -These locate the binary version of the library. - -Finally, you can link any other library or executable target with this imported -library just as you would for any other target. - -## Macro Reference - -Following are several macros that are useful for advanced CMake usage. - -### PROJECT_TARGET_ADD - -This macro adds the target to your project. -Following is a typical example that adds the target to your project. -You need to provide the name of your target as the macro's parameter: - -Example: - -```cmake -PROJECT_TARGET_ADD(low-can-demo) -``` - -The macro makes the variable `${TARGET_NAME}` available and it is defined -using the specified name (e.g. `low-can-demo`). -The variable changes each time the `PROJECT_TARGET_ADD` macro is called. - -### project_subdirs_add - -This macro searches within specified subfolders of the CMake project for -any `CMakeLists.txt` file. -If the file is found, it is added to your project. -You can use this macro in a hybrid application (e.g. where the binding -exists in a subfolder). - -The following example searches within all subfolders: - -Usage : - -```cmake -project_subdirs_add() -``` - -You might want to restrict the subfolders being searched. -If so, you can specify a -[globbing](https://en.wikipedia.org/wiki/Glob_(programming)) pattern -as the argument. -Doing so effectively creates a search filter. - -Following is an example that specifies all directories that begin -with a number, are followed by the dash character, and then followed -by any characters: - -```cmake -project_subdirs_add("[0-9]-*") -``` - -### set_openapi_filename - -This macro is used with a **BINDINGV2** target and defines the -binding definition filename. -You can use it to also define a relative path to -the current `CMakeLists.txt` file. - -If you do not use this macro to specify the name of your definition file, -the default one is used, which is `${OUTPUT_NAME}-apidef` and uses -**OUTPUT_NAME** as the [target property]. - -**CAUTION** When specifying the binding definition filename, -you must not use the file's extension as part of the name. -Following is an example: - -```cmake -set_openapi_filename('binding/mybinding_definition') -``` - -[target property]: https://cmake.org/cmake/help/v3.6/prop_tgt/OUTPUT_NAME.html "OUTPUT_NAME property documentation" - -### add_input_files - -This macro creates a custom target dedicated for HTML5 and data resource files. -The macro provides syntax and schema verification for different languages that -include LUA, JSON and XML. - -Alongside the macro are tools used to check files. -You can configure the tools by setting the -following variables: - -- XML_CHECKER: Uses **xmllint** that is provided with major linux distributions. -- LUA_CHECKER: Uses **luac** that is provided with major linux distributions. -- JSON_CHECKER: Currently, not used by any tools. - -Following is an example: - -```cmake -add_input_file("${MY_FILES_LIST}") -``` - -**NOTE**: If an issue occurs during the "check" step of the macro, -the build halts. \ No newline at end of file diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/4_Advanced_Customization.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/4_Advanced_Customization.md deleted file mode 100644 index 2b5963c..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/4_Advanced_Customization.md +++ /dev/null @@ -1,112 +0,0 @@ ---- -title: Advanced Customization ---- - -This section describes how you can include additional CMake files -and custom template scripts. - -## Including Additional CMake Files - -You can include machine and system custom CMake files and -operating system custom CMake files. - -### Machine and System Custom CMake Files - -Advanced configuration is possible by automatically including -additional CMake files from specific locations. -Following are the locations from which you can add CMake -files. -Inclusions occur in the order shown here: - -- `/conf.d/app-templates/cmake/cmake.d` - normally located CMake project files -- `$HOME/.config/app-templates/cmake.d` - the home location -- `/etc/app-templates/cmake.d` - the system location - -The CMake files you include must be named using either of the following conventions: - -- `XX-common*.cmake` -- `XX-${PROJECT_NAME}*.cmake` - -In both formats, `XX` are numbers and indicate the order in which the file -is included. -The `*` character represents the filename. - -When naming the file, consider the projects in which the file needs to be -included. -If you want to include the file in all projects, use the keyword `common`. -If you want to include the file in a specific project, use the `${PROJECT_NAME}` -value. - -For example, if you want a CMake file whose name is `my_custom_file` -included first and you want it included in all projects, name the file -`01-common-my_custom_file.cmake`. -If you want the same file included in a single project defined by the -`PROJECT_NAME` variable, and you want it included after all other files, -name the file `99-${PROJECT_NAME}-my_custom_file.cmake`. - -When you include CMake files that use CMake variables, the values override -variables with the same name. -The exception to this rule is if you use a cached variable. -Following is an example: - -```cmake -set(VARIABLE_NAME 'value string random' CACHE STRING 'docstring') -``` - -In this example, the `VARIABLE_NAME` variable is defined as a cached -variable by using the **CACHE** keyword. -Consequently, `VARIABLE_NAME` does not get overridden as a result of -including a CMake file that sets the same variable. - -### Operating System Custom CMake Files - -Including custom CMake files based on the operating system -lets you personalize a project depending on the operating system -you are using. - -At the end of the `config.cmake` file `common.cmake` includes -CMake files to customize your project build depending on your platform. -The operating system is detected by using `/etc/os-release`, -which is the default method used in almost all Linux distributions. -Consequently, you can use the value of field **ID_LIKE** to -add a CMake file for that distribution. -The file comes from your `conf.d/cmake/` directory or relatively -from your `app-templates` submodule path `app-templates/../cmake/`. - -**NOTE:** If the **ID_LIKE** field does not exist, you can use the -**ID** field. - -Files that you add must be named according to the following file naming -convention: - -- `XX-${OSRELEASE}*.cmake` - -In the naming convention, `XX` represents numbers and is the order in which -you want a file included. -The ${OSRELEASE} value is taken from either the **ID_LIKE** or **ID** field -of the `/etc/os-release` file. - -You can also configure a CMake file to be included in cases where no -specific operating system can be found. -To do so, name your CMake file as follows: - -- `XX-default*.cmake` - -A good use case example for these two naming conventions is when you have -a several Linux distributions and all but one can use the same module. -For that case, name one CMake file using the `${OSRELEASE}` value and -name the CMake file to be used with the other distributions using -the `XX-default*.cmake` method. - -## Including Custom Template Scripts - -You can include your own custom template scripts that are passed to the -CMake command `configure_file`. - -Just create your own script and place it in either of the following directories: - -- `$HOME/.config/app-templates/scripts` - the home location -- `/etc/app-templates/scripts` - the system location - -Scripts only need to use the extension `.in` to be parsed and configured by -CMake. diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/5_Autobuild.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/5_Autobuild.md deleted file mode 100644 index c32a6da..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/5_Autobuild.md +++ /dev/null @@ -1,152 +0,0 @@ ---- -title: Autobuild ---- - -Applications based on the AGL framework should have a -full build and packaging solution that is independent of the -[Yocto Project](https://www.yoctoproject.org) workflow. - -You can create a script named **autobuild** to control applications -build operations. -AGL provides a BitBake class file (`aglwgt.bbclass`) that calls the -**autobuild** script for all operations. -The class file is located at the top level of the application repository. - -You can write the **autobuild** script using any of the following languages: - -* Makefile -* Bash -* Python - -The script executes directly after applying a `chmod()` command. -The caller, which can be the `aglwgt.bbclass`, a Jenkins job, or an actual person, -must make the **autobuild** executable before calling it. -To facilitate direct execution, you need to start the script with a -[shebang](https://en.wikipedia.org/wiki/Shebang_(Unix)) sequence: - -* '#!/usr/bin/make -f' for Makefile format -* '#!/usr/bin/bash' for Bash format - -The calling convention is similar to the convention used in `make`. -To pass arguments, use environment variables. - -**NOTE:** For Bash, an evaluation of the arguments -sets the environment variables correctly. - -The following format shows the generic call: - -```bash -autobuild/agl/autobuild [ARG1="value1" [ARG2="value2" ... ]] -``` - -The **autobuild** script can be invoked from any directory -with all paths considered to be relative to the -script's location. -For makefile scripts, this is the usual behavior. -For Bash scripts, a `cd $(dirname $0)` command must be run at -the beginning of the script. - -At build time, the following calls must be made in the following order: - -1. Initialize the build environment (e.g if the application uses - `cmake` the configure step runs CMake). - - ```bash - autobuild/agl/autobuild configure CONFIGURE_ARGS="..." - ``` - -2. Build the application (i.e. compile, link binaries, assembles javascript, - and so forth). - - ```bash - autobuild/agl/autobuild build BUILD_ARGS="...." - ``` - -3. Create the widget package(s) in the specified destination path - prepared by the caller. - - ```bash - autobuild/agl/autobuild package PACKAGE_ARGS="..." DEST= - ``` - -4. Create the test widget package(s) in the specified destination path - prepared by the caller. - - ```bash - autobuild/agl/autobuild package-test PACKAGE_ARGS="..." DEST= - ``` - -5. Clean the built files by removing the result of the **autobuild** build. - - ```bash - autobuild/agl/autobuild clean CLEAN_ARGS="..." - ``` - -6. Clean everything by removing the result of the **autobuild** build - and the **autobuild** configure. - - ```bash - autobuild/agl/autobuild distclean DISTCLEAN_ARGS="..." - ``` - -## Integrating **autobuild** into the Yocto Project Workflow - -If you want to integrate the **autobuild** script into the Yocto Project -workflow, you need to generate the script. -To generate the script, use the `autobuild` target. - -The following commands create the **autobuild** script in the -`autobuild/agl` directory: - -```bash -mkdir -p build -cd build -cmake .. && make autobuild -``` - -## Available Targets - -Following are the targets available from the **autobuild** script: - -- **clean**: Removes all the object files and target results generated by Makefile. -- **clean-{release,debug,coverage,test}**: Removes all the object files and target results generated by Makefile for the specified build type. -- **clean-all**: Deletes the build directories for all build types. -- **distclean**: Deletes the build directories for all build types. -- **configure**: Generates the project Makefile from the `CMakeLists.txt` files for the release build type. -- **configure-{release,debug,coverage,test}**: Generates the project Makefile from the `CMakeLists.txt` files for the specified build type. -- **build**: Compiles all project targets for the release build type. -- **build-{release,debug,coverage,test}**: Compiles all project targets for the specified build type. -- **build-all**: Compiles all project targets for all specified build types. -- **package**: Builds the widget (**wgt**) package for the release build type. -- **package-{release,debug,coverage}**: Builds the widget (**wgt**) package for the specified build type. -- **package-test**: Builds the test **wgt** package. -- **package-all**: Builds the widget (**wgt**) packages for all build types. -- **install**: Installs the project into your filesystem. - -Note that `aglwgt.bbclass` only will use the **package-{coverage,test}** targets (and thus the **build-{coverage,test}**, etc. targets) for service bindings by default, so **autobuild** scripts for applications may omit support for those. - -Specifying the following variables lets you modify compilation behavior: - -- **CLEAN_ARGS**: Variable used at **clean** time. -- **CONFIGURE_ARGS**: Variable used at **configure** time. -- **BUILD_ARGS**: Variable used at **build** time. -- **BUILD_DIR**: Build directory for release type build. - The default value is a "build" directory in the root of the project. -- **BUILD_DIR_DEBUG**: Build directory for debug type build. - The default value is a "build-debug" directory in the root of the project. -- **BUILD_DIR_TEST**: Build directory for test type build. - The default value is a "build-test" directory in the root of the project. -- **BUILD_DIR_COVERAGE**: Build directory for coverage type build. - The default value is a "build-coverage" directory in the root of the project. -- **DEST**: Directory in which to place the created ***wgt*** file(s). - The default directory is the build root directory. - -Note that the values of **BUILD_DIR_{DEBUG,TEST,COVERAGE}** are defined based on the value of **BUILD_DIR**, so this needs to be kept in mind if over-riding it and building those other widget types. - -When you provide a variable, use the CMake format (i.e. -BUILD_ARGS="-DC_FLAGS='-g -O2'"). -Following is an example: - -```bash -./autobuild/agl/autobuild package DEST=/tmp -``` diff --git a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/6_Using_CMake_Templates_from_Bitbake_Recipes.md b/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/6_Using_CMake_Templates_from_Bitbake_Recipes.md deleted file mode 100644 index 26bf869..0000000 --- a/docs/3_Developer_Guides/5_Using_CMAKE_Applications_Module/6_Using_CMake_Templates_from_Bitbake_Recipes.md +++ /dev/null @@ -1,56 +0,0 @@ ---- -title: Using CMake Templates from BitBake Recipes ---- - -If you have developed an application and you want to include it in an AGL image, -you must add a BitBake recipe in one of the following layers: - -* [meta-agl](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/AGL/meta-agl): - meta-agl layer (core AGL) -* [meta-agl-cluster-demo](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/AGL/meta-agl-cluster-demo): - cluster demo specific recipes and configuration -* [meta-agl-demo](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/AGL/meta-agl-demo): - meta-agl-demo layer (demo/staging/"one-shot") -* [meta-agl-devel](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/AGL/meta-agl-devel): - meta-agl-devel (Development and Community BSPs) -* [meta-agl-extra](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/AGL/meta-agl-extra): - meta-agl-extra (additional/optional components for AGL) - -Once you have the recipe in place, edit it to include the following -line to cause the `aglwgt` class to be inherited: - -```bb -inherit aglwgt -``` - -Following is an example that uses the HVAC application recipe (i.e. `hvac.bb`), which -builds the HVAC application: - -```bb -SUMMARY = "HVAC Service Binding" -DESCRIPTION = "AGL HVAC Service Binding" -HOMEPAGE = "https://gerrit.automotivelinux.org/gerrit/#/admin/projects/apps/agl-service-hvac" -SECTION = "apps" - -LICENSE = "Apache-2.0" -LIC_FILES_CHKSUM = "file://LICENSE;md5=ae6497158920d9524cf208c09cc4c984" - -SRC_URI = "gitsm://gerrit.automotivelinux.org/gerrit/apps/agl-service-hvac;protocol=https;branch=${AGL_BRANCH}" -SRCREV = "${AGL_APP_REVISION}" - -PV = "1.0+git${SRCPV}" -S = "${WORKDIR}/git" - -DEPENDS = "json-c" -RDEPENDS_${PN} += "agl-service-identity-agent" - -inherit cmake aglwgt pkgconfig -``` - -The following links provide more examples of recipes that use the -CMake templates: - -* [agl-service-helloworld](https://gerrit.automotivelinux.org/gerrit/admin/repos/apps/agl-service-helloworld) -* [agl-service-audio-4a](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/apps/agl-service-audio-4a) -* [agl-service-unicens](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/apps/agl-service-unicens) -* [4a-hal-unicens](https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/4a-hal-unicens) \ No newline at end of file diff --git a/docs/4_APIs_and_Services/0_API_Reference.md b/docs/4_APIs_and_Services/0_API_Reference.md deleted file mode 100644 index 4822bf0..0000000 --- a/docs/4_APIs_and_Services/0_API_Reference.md +++ /dev/null @@ -1,48 +0,0 @@ ---- -title: API Reference ---- - -# Available APIs - -Introduction of Available APIs with categorization. If multiple categories apply, they will all be listed in the third column (e.g. first row in the following). - - - -| API | Description | Profile | -| --- | --- | --- | -| [agl-service-audiomixer](https://git.automotivelinux.org/apps/agl-service-audiomixer/about/) | Audio Mixer API | | -| [agl-service-bluetooth](https://git.automotivelinux.org/apps/agl-service-bluetooth/about/) | bluetooth binding | Infotainment | -| [agl-service-bluetooth-avrcp](https://git.automotivelinux.org/apps/agl-service-bluetooth-avrcp/) | AGL service that allow multimedia control over Bluetooth AVRCP profile | Infotainment | -| [agl-service-bluetooth-pbap](https://git.automotivelinux.org/apps/agl-service-bluetooth-pbap/about/) | Bluetooth Phone Book Access Protocoll service | Infotainment | -| [agl-service-can-low-level](https://git.automotivelinux.org/apps/agl-service-can-low-level/about/) | Low level CAN service made to decode and write on CAN bus. | Instrument Cluster | -| [agl-service-data-persistence](https://git.automotivelinux.org/apps/agl-service-data-persistence/about/) | AGL binding for data persistence | Instrument Cluster | -| [agl-service-geoclue](https://git.automotivelinux.org/apps/agl-service-geoclue/about/) | AGL Geoclue service to backup GPS positioning with network-based
positioning | Infotainment | -| [agl-service-geofence](https://git.automotivelinux.org/apps/agl-service-geofence/about/) | AGL geofence binding to signal vehicle POI bounding box events | Infotainment | -| [agl-service-gps](https://git.automotivelinux.org/apps/agl-service-gps/about/) | GPS binding | Infotainment | -| [agl-service-gstreamer](https://git.automotivelinux.org/apps/agl-service-gstreamer/) | (deprecated) GStreamer binding for multimedia control and playback | Infotainment | -| [agl-service-harvester](https://git.automotivelinux.org/apps/agl-service-harvester/about/) | V2C interface that collect data to TimeSeries database | | -| [agl-service-homescreen](https://git.automotivelinux.org/apps/agl-service-homescreen/about/) | Applications need a new binding to communicate with homescreen | Infotainment | -| [agl-service-homescreen-2017](https://git.automotivelinux.org/apps/agl-service-homescreen-2017/about/) | Binding for applications to communicate with the homescreen-2017 | Infotainment | -| [agl-service-hvac](https://git.automotivelinux.org/apps/agl-service-hvac/) | Unnamed repository | | -| [agl-service-identity-agent](https://git.automotivelinux.org/apps/agl-service-identity-agent/about/) | Identity Agent | | -| [agl-service-iiodevices](https://git.automotivelinux.org/apps/agl-service-iiodevices/about/) | iiodevices support | Telematics/Connectivity | -| [agl-service-mediaplayer](https://git.automotivelinux.org/apps/agl-service-mediaplayer/about/) | AGL Media Player service that allows applications to control
playing media. | Infotainment | -| [agl-service-mediascanner](https://git.automotivelinux.org/apps/agl-service-mediascanner/about/) | AGL Media Scanning service that allows applications to detect
and index media at... | Telematics/Connectivity | -| [agl-service-navigation](https://git.automotivelinux.org/apps/agl-service-navigation/) | Navigation API with binding | Infotainment | -| [agl-service-network](https://git.automotivelinux.org/apps/agl-service-network/about/) | AGL Network service providing support for management of networking
interfaces in... | | -| [agl-service-nfc](https://git.automotivelinux.org/apps/agl-service-nfc/about/) | AGL service NFC binding | | -| [agl-service-radio](https://git.automotivelinux.org/apps/agl-service-radio/about/) | radio binding | | -| [agl-service-signal-composer](https://git.automotivelinux.org/apps/agl-service-signal-composer/about/) | AGL High Level Signaling service to handle CAN, LIN, and others
signaling source... | Instrument Cluster | -| [agl-service-soundmanager](https://git.automotivelinux.org/apps/agl-service-soundmanager/about/) | Binding for applications to communicate with the soundmanager | | -| [agl-service-soundmanager-2017](https://git.automotivelinux.org/apps/agl-service-soundmanager-2017/about/) | Binding for applications to communicate with the soundmanager-2017 | | -| [agl-service-speech](https://git.automotivelinux.org/apps/agl-service-speech/about/) | AGL App Framework Binding for Speech Services | Telematics/Connectivity | -| [agl-service-steering-wheel](https://git.automotivelinux.org/apps/agl-service-steering-wheel/about/) | And binding service for steering wheel demo | Instrument Cluster | -| [agl-service-taskmanager](https://git.automotivelinux.org/apps/agl-service-taskmanager/about/) | Simple taskmanager service to retrieve data from procps | | -| [agl-service-telephony](https://git.automotivelinux.org/apps/agl-service-telephony/about/) | Unnamed repository | | -| [agl-service-unicens](https://git.automotivelinux.org/apps/agl-service-unicens/about/) | Infotainment network setup and access (using Unified Centralized
Network Stack) | Infotainment | -| [agl-service-weather](https://git.automotivelinux.org/apps/agl-service-weather/about/) | AGL binding that uses OpenWeathermap data to display current
conditions on Homes... | Telematics/Connectivity | -| [agl-service-wifi](https://git.automotivelinux.org/apps/agl-service-wifi/) | wifi binding | Telematics/Connectivity | -| [agl-service-windowmanager](https://git.automotivelinux.org/apps/agl-service-windowmanager/about/) | Binding for applications to communicate with the windowmanager | | -| [agl-service-windowmanager-2017](https://git.automotivelinux.org/apps/agl-service-windowmanager-2017/about/) | Binding for applications to communicate with the windowmanager-2017 | | -| [agl-service-xds](https://git.automotivelinux.org/apps/agl-service-xds/) | AGL binding used to control collected data from AGL
supervision. (empty) | | -| [agl-service-xds-monitoring](https://git.automotivelinux.org/apps/agl-service-xds-monitoring/about/) | UNDER DEVELOPMENT | | diff --git a/docs/4_APIs_and_Services/FIXME.md b/docs/4_APIs_and_Services/FIXME.md new file mode 100644 index 0000000..e69de29 diff --git a/docs/5_Component_Documentation/5_appfw.md b/docs/5_Component_Documentation/5_application_framework.md similarity index 100% rename from docs/5_Component_Documentation/5_appfw.md rename to docs/5_Component_Documentation/5_application_framework.md diff --git a/docs/5_Component_Documentation/6_cynagora.md b/docs/5_Component_Documentation/6_cynagora.md deleted file mode 100644 index d2c74ce..0000000 --- a/docs/5_Component_Documentation/6_cynagora.md +++ /dev/null @@ -1,7 +0,0 @@ ---- -title: Cynagora ---- - -# cynagora - -FIXME. diff --git a/docs/5_Component_Documentation/8_pipewire_wireplumber.md b/docs/5_Component_Documentation/6_pipewire_wireplumber.md similarity index 100% rename from docs/5_Component_Documentation/8_pipewire_wireplumber.md rename to docs/5_Component_Documentation/6_pipewire_wireplumber.md diff --git a/docs/5_Component_Documentation/9_ic-sound-manager.md b/docs/5_Component_Documentation/7_ic-sound-manager.md similarity index 100% rename from docs/5_Component_Documentation/9_ic-sound-manager.md rename to docs/5_Component_Documentation/7_ic-sound-manager.md diff --git a/docs/5_Component_Documentation/7_pyagl.md b/docs/5_Component_Documentation/7_pyagl.md deleted file mode 100644 index 40f0a53..0000000 --- a/docs/5_Component_Documentation/7_pyagl.md +++ /dev/null @@ -1,250 +0,0 @@ ---- -title: PyAGL ---- - -# 0. Intro -## Main purpose -PyAGL was written to be used as a testing framework replacing the Lua afb-test one, -however the modules are written in a way that could be used as standalone utilities to query -and evaluate apis and verbs from the App Framework Binder services in AGL. - -## High level overview -Python compatibility: **Python 3.8 preferred**, **should** be compatible with **3.6** - -Initial development PyAGL was done with Python **3.6** in mind, heavily using f-strings and a few typings. As of writing this -documentation(June 3rd 2021), current stable AGL version is Koi 11.0.2 which has Python 3.8, and further development is -done using 3.8 and 3.9 runtimes although **no** version-specific features are used from later versions; -features **used** are kept within features offered by Python **3.8**. - -The test suite is written in a relatively standard way of extending **pytest** with a couple tweaks -tailored to Jenkins CI and LAVA for AGL with regards to output and timings/timeouts, and these tweaks -are enabled by running `pytest -L` in order to enable LAVA logging behavior. - -The way PyAGL works could be summarized in several bullets below: - -* `websockets` package is used to communicate to the services, `x-afb-ws-json1` is used as a subprotocol, -* base.py provides AGLBaseService to be extended for each service -* AGLBaseService has a `portfinder()` routine which will use `asyncssh` if used remotely, -to figure out the port of the service's websocket that is listening on. When this was implemented services had a hardcoded listening port, -and was often changed when a new service was introduced. If you specify port, pyagl will connect to it directly. If no port is specified and -portfinder() cannot find the process or listening port should throw an exception and exit. -* main() implementations in most PyAGL services' bindings are intended to be used as a convenient standalone utility to query verbs, although -not necessarily available. -* PyAGL bindings are organized in classes, method names and respective parameters mostly adhere to service verbs/apis described -per service in https://git.automotivelinux.org/apps/agl-service-*/about -For example, in https://git.automotivelinux.org/apps/agl-service-audiomixer/about/ the docs for the service describe 5 verbs - -subscribe, unsubscribe, list_controls, volume, mute - and their respective methods in audiomixer.py. -* as mentioned above `pytest` package is required for unit tests. -* `pytest-async` is needed by pytest to cooperate with asyncio -* `pytest-dependency` is used in cases where specific testing order is needed and used via decorators - -# 1. Using PyAGL -Command line execution is intended for debugging and quick evaluation. -There are few prerequisites to start using it. First, your AGL image **must** be bitbaked with **agl-devel** feature when sourcing __aglsetup.sh__; -if not - the running AGL instance won't have websocket services exposed to listening TCP ports and PyAGL will fail to connect. - -```bash -git clone "https://gerrit.automotivelinux.org/gerrit/src/pyagl" -``` -Preferably create a virtualenv and install the packages in the env -```bash -user@debian:~$ python3 -mvenv ~/.virtualenvs/aglenv -user@debian:~$ source ~/.virtualenvs/aglenv/bin/activate -(aglenv) user@debian:~$ pip install -r requirements.txt -``` -Hard requirements are asyncssh, websockets, pytest, pytest-dependency, pytest-async; the others in the file are dependencies of the mentioned packages. - -If you have installed PyAGL as python package or current working directory is in the project root: -``` -(aglenv) user@debian:~/pyagl$ python3 -m pyagl.services.audiomixer 192.168.234.34 --list_controls -``` -should produce the following or similar result depending on how many controls are exposed and which AGL version you are running: -``` -matching services: ['afm-service-agl-service-audiomixer--0.1--main@1001.service'] -Requesting list_controls with id 359450446 -[RESPONSE][Status: success][359450446][Info: None][Data: [{'control': 'Master Playback', 'volume': 1.0, 'mute': 0}, -{'control': 'Playback: Speech-Low', 'volume': 1.0, 'mute': 0}, {'control': 'Playback: Emergency', 'volume': 1.0, 'mute': 0}, -{'control': 'Playback: Speech-High', 'volume': 1.0, 'mute': 0}, {'control': 'Playback: Navigation', 'volume': 1.0, 'mute': 0}, -{'control': 'Playback: Multimedia', 'volume': 1.0, 'mute': 0}, {'control': 'Playback: Custom-Low', 'volume': 1.0, 'mute': 0}, -{'control': 'Playback: Communication', 'volume': 1.0, 'mute': 0}, {'control': 'Playback: Custom-High', 'volume': 1.0, 'mute': 0}]] -``` - -# 2. Running the tests - -## Markers -Before running the tests it must be noted that __Markers__ are metavariables applied to the tests which play important part -in the behavior of pyagl and add great flexibility when deciding which tests to run. -Each test suite usually have unambiguous marker and description in `pytest.ini` for the reason above. -The default markers are applied in the list variable `pytestmark` in the beginning of each test file. -Each test suite has at least 2 default markers. - -`pytest.mark.asyncio` is a special marker needed because we are running pytest in async mode, -and the other marker is the name of the testsuite - for example `pytest.mark.geoclue` is for `geoclue` tests. - -`pytest.mark.dependency` is another special marker used by the pytest-dependency library helping for -running tests in a particular order when a more complicated setup other than a fixture is needed for -a test or the setup itself is a test or sequence of tests. - -`pytest.mark.hwrequired` is a marker signifying that additional hardware is required for tests to be successful - e.g. bluetooth phonebook tests need a phone with a pbap profile connected - -`pytest.mark.internet` is a marker for tests which require internet connection - -As mentioned above, behavior of pytest is altered by the markers because pytest does expression matching by marker and test names for which suite to be run. -In the example below we select all internet requiring and subscription tests but skip those that require additional hardware. -If we have a match with `internet or subscribe` the test will be selected, but if the test has `hwrequired` will be skipped, otherwise deselected overall. -``` -h3ulcb:~# pyagl -vk "internet or subscribe and not hwrequired" -============================ test session starts ============================ -platform linux -- Python 3.8.2, pytest-5.3.5, py-1.8.1, pluggy-0.13.1 -- /usr/bin/python3 -cachedir: .pytest_cache -rootdir: /usr/lib/python3.8/site-packages/pyagl, inifile: pytest.ini -plugins: asyncio-0.10.0, dependency-0.5.1, reverse-1.0.1 -collected 218 items / 163 deselected / 55 selected - -test_bluetooth.py::test_subscribe_device_changes PASSED [ 1%] -... -test_radio.py::test_unsubscribe_all PASSED [ 90%] -test_signal_composer.py::test_subscribe SKIPPED [ 92%] -test_signal_composer.py::test_unsubscribe SKIPPED [ 94%] -test_weather.py::test_current_weather FAILED [ 96%] -test_weather.py::test_subscribe_weather PASSED [ 98%] -test_weather.py::test_unsubscribe_weather PASSED [100%] -==== 1 failed, 37 passed, 17 skipped, 163 deselected, 1 warning in 3.23s ==== - -``` - -## Locally - On the board itself -There is the /usr/bin/pyagl convenience wrapper script which invokes pytest -with the tests residing in `/usr/lib/python3.8/site-packages/pyagl/tests` which -also will pass all commandline arguments down to pytest - -```console -qemux86-64:~# pyagl -=================== test session starts ============================= -platform linux -- Python 3.8.2, pytest-5.3.5, py-1.8.1, pluggy-0.13.1 -rootdir: /usr/lib/python3.8/site-packages/pyagl, inifile: pytest.ini -plugins: dependency-0.5.1, asyncio-0.10.0, reverse-1.0.1 -collected 213 items - -test_audiomixer.py ....... [ 3%] -test_bluetooth.py ............xxxsxx [ 11%] -test_bluetooth_map.py .x.xs. [ 12%] -... -``` - -## Remotely -You must export `AGL_TGT_IP` environment variable first, containing a string with a reachable IP address -configured(either DHCP or static) on one of the interfeces on the AGL instance(board or vm) on your network. -`AGL_TGT_PORT` is not required, however can be exported to skip over connecting to the board via ssh first -in order to figure out the listening port of service. - -```console -user@debian:~$ source ~/.virtualenvs/aglenv/bin/activate -(pyagl) user@debian:~$ export AGL_TGT_IP=192.168.234.34 -(pyagl) user@debian:~$ cd pydev/pyagl/pyagl/tests -(pyagl) user@debian:~/pydev/pyagl/pyagl/tests$ pytest test_geoclue.py -========================= test session starts ========================= -platform linux -- Python 3.9.2, pytest-5.4.1, py-1.8.1, pluggy-0.13.1 -rootdir: /home/user/pydev/pyagl/pyagl, inifile: pytest.ini -plugins: dependency-0.5.1, asyncio-0.11.0 -collected 3 items - -test_geoclue.py ... [100%] -``` -# 3. Writing bindings and/or tests for new services -This assumes you have already went through ["3. Developer Guides > Creating a new service"](../3_Developer_Guides/2_Creating_a_New_Service.md). - -Templates directory contains barebone _cookiecutter_ templates to create your project. -If you do not intend to use cookiecutter, you need a simple service file in which you inherit AGLBaseService -from base.py. -You can take a look at pyagl/services/geoclue.py and pyagl/tests/test_geoclue.py which is probably the -simplest binding in PyAGL for a reference and example. All basic methods like -[send|receive|un/subscribe|portfinder] are implemented in the base class. -You would need to do minimal work to create new service binding from scratch and by example of the geoclue service you need to do the following: - -* do the basic imports -```python3 -from pyagl.services.base import AGLBaseService, AFBResponse -import asyncio -``` - -* inherit AGLBaseService and type in the service class member the service name presuming you are following the AGL naming convention: -(if your new service does not follow the convention, the portfider routine wont work and you'll have to specify service port manually) -```python3 -class GeoClueService(AGLBaseService): - service = 'agl-service-geoclue' -``` - -* if you intend to run the new service binding as a standalone utility, you might want to add your new options to the argparser -```python3 - parser = AGLBaseService.getparser() - parser.add_argument('--location', help='Get current location', action='store_true') -``` - -* override the __init__ method with the respective parameters as api(used in the binding) and systemd service slug -``` - def __init__(self, ip, port=None, api='geoclue'): - super().__init__(ip=ip, port=port, api=api, service='agl-service-geoclue') -``` - -* define your methods and send requests with .request() which prepares the data in a JSON format, request returns message id -``` - async def location(self): - return await self.request('location') -``` - -* get the raw response with data = await .response() or use .afbresponse() to get structured data - -PyAGL is written with asyncio so you'd need an event loop to get your code running. -Most modules have standalone CLI functionality, which is done via ArgumentParser and each module that -is CLI usable inherits static base parser and extends its arguments as shown in the example below: - -```python3 -async def main(loop): - args = GeoClueService.parser.parse_args() - gcs = await GeoClueService(args.ipaddr) - - if args.location: - msgid = await gcs.location() - print(f'Sent location request with messageid {msgid}') - print(await gcs.afbresponse()) - -if __name__ == '__main__': - loop = asyncio.get_event_loop() - loop.run_until_complete(main(loop)) -``` -`GeoClueService` will try to return an instance with connection to the service. It will throw an exception if it fails to do so. -`AGLBaseService.afbresponse()` method is a wrapper on top of .response() which will prepare, validate and format data for a convenient usage intended for CLI usage. -`AFBResponse.__str__` is also a convenience method to be able to print all relevant data in regarding state of the response. - -```console -(aglenv) user@debian:~$ python3 -m pyagl.services.geoclue 192.168.234.251 --location -matching services: ['afm-service-agl-service-geoclue--1.0--main.service'] -Sent location request with messageid 29188435 -[RESPONSE][Status: success][29188435][Info: GeoClue location data][Data: {'latitude': 42.6898421, 'longitude': 23.3099069, 'accuracy': 107.4702045}] -``` - - -# 4. Environment variables -The following environment variables are used in the PyAGL project: - -Variable | Description ---- | --- -**AGL_TGT_IP** | **required** -**AGL_TGT_PORT** | **optional**, when this is used portfinder() routine is skipped, attempts direct websocket connection to this port. -**AGL_TEST_TIMEOUT** | **optional**, over-ride the default 5 second timeout value for binding responses. This is useful in many cases where a long-standing request has taken place - e.g. importing few thousand entries from a phonebook -**AGL_AVAILABLE_INTERFACES** | **optional**, specify which of ethernet, wifi, and bluetooth interfaces are available. The value is a comma separated list, with a default value of "ethernet,wifi,bluetooth". -**AGL_BTMAP_RECIPIENT** | **optional**, when running Bluetooth MAP tests, this would be used as phone number to write text messages to. -**AGL_BTMAP_TEXT** | **optional**, when running Bluetooth MAP tests, messages will be composed with this text. -**AGL_CAN_INTERFACE** | **optional**, specify the CAN interface to use for CAN testing, default value is "can0". -**AGL_PBAP_PHONENUM** | **optional**, when running Bluetooth PBAP tests, this phone number will be used to .search(). -**AGL_PBAP_VCF** | **optional**, for the Bluetooh PBAP tests query a contact entry out of the phonebook. -**AGL_BT_TEST_ADDR** | **optional**, for the Bluetooth tests pair/connect/disconnect with an actual Bluetooth device(phone)'s address . The address should have the DBus address style as "dev_00_01_02_03_04_05" instead of a regular colon-separated MAC address. - -# 5. Debugging -PyAGL uses pythons logger library so you can rise the logging level and see the output from most of the modules, -but was disabled by default because of the massive amount of output produced. When the default logger is enabled -all other libraries will show their output with pyagl - e.g. websockets, asyncssh etc. - -README.md in the root directory of the project also contains useful information. - diff --git a/docs/index.md b/docs/index.md index 68e117b..dea00c8 100644 --- a/docs/index.md +++ b/docs/index.md @@ -38,6 +38,7 @@ You can find information on the AGL Unified Code Base on the "[Unified Code Base](https://www.automotivelinux.org/software/unified-code-base)" page. + What Can I Do Right Away Using AGL? ----------------------------------- -- 2.16.6

Ietf1-t?}E)We##@2rjGJ#!xd9 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