/* * Copyright (C) 2016 "IoT.bzh" * Author Fulup Ar Foll * * 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, something express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Reference: * Json load using json_unpack https://jansson.readthedocs.io/en/2.9/apiref.html#parsing-and-validating-values */ #ifndef _CTL_CONFIG_INCLUDE_ #define _CTL_CONFIG_INCLUDE_ #ifdef __cplusplus extern "C" { #endif #ifndef _GNU_SOURCE #define _GNU_SOURCE #endif #include "ctl-plugin.h" #include #include #ifdef CONTROL_SUPPORT_LUA #include "ctl-lua.h" #endif #ifndef CONTROL_MAXPATH_LEN #define CONTROL_MAXPATH_LEN 255 #endif #ifndef CONTROL_CONFIG_PRE #define CONTROL_CONFIG_PRE "onload" #endif #ifndef CTL_PLUGIN_EXT #define CTL_PLUGIN_EXT ".ctlso" #define CTL_SCRIPT_EXT ".lua" #endif #define LUA_ACTION_PREFIX "lua://" #define API_ACTION_PREFIX "api://" #define PLUGIN_ACTION_PREFIX "plugin://" typedef struct ConfigSectionS { const char *key; const char *uid; const char *info; const char *prefix; int (*loadCB)(afb_api_t apihandle, struct ConfigSectionS *section, json_object *sectionJ); void *handle; CtlActionT *actions; } CtlSectionT; typedef struct { const char *api; const char *uid; const char *info; const char *version; const char *author; const char *date; const char *prefix; json_object *configJ; json_object *requireJ; CtlSectionT *sections; CtlPluginT *ctlPlugins; void *external; } CtlConfigT; // This should not be global as application may want to define their own sections typedef enum { CTL_SECTION_PLUGIN, CTL_SECTION_ONLOAD, CTL_SECTION_CONTROL, CTL_SECTION_EVENT, CTL_SECTION_HAL, CTL_SECTION_ENDTAG, } SectionEnumT; /******************************************************************************* * ctl-action.h * ******************************************************************************/ extern int AddActionsToSection(afb_api_t apiHandle, CtlSectionT *section, json_object *actionsJ, int exportApi); extern CtlActionT *ActionConfig(afb_api_t apiHandle, json_object *actionsJ, int exportApi); extern void ActionExecUID(afb_req_t request, CtlConfigT *ctlConfig, const char *uid, json_object *queryJ); extern int ActionExecOne( CtlSourceT *source, CtlActionT* action, json_object *queryJ); extern int ActionLoadOne(afb_api_t apiHandle, CtlActionT *action, json_object *, int exportApi); extern int ActionLabelToIndex(CtlActionT* actions, const char* actionLabel); /******************************************************************************* * ctl-config.h * ******************************************************************************/ extern int CtlConfigMagicNew(); extern void* getExternalData(CtlConfigT *ctlConfig); extern void setExternalData(CtlConfigT *ctlConfig, void *data); extern json_object* CtlConfigScan(const char *dirList, const char *prefix) ; /** * @brief Return a string representing the path + filename for a given response * object from a CtlConfigScan calls. This will only take the first result, this is * made to avoid loading several time the same file found at differents places. * * The returned string has to be freed. * * @param apiHandle AppFW Api handle * @param responseJ Response from a CtlConfigScan function call. * @return char* absolute path to a file */ extern char* ConfigSearch(afb_api_t apiHandle, json_object *responseJ); extern char* CtlConfigSearch(afb_api_t apiHandle, const char *dirList, const char *prefix) ; /** * @brief Best effort to initialise everything before starting * Call afb_require_api at the first call or if there was an error because * the CtlConfigExec could be called anywhere and not in binding init. * So you could call this function at init time. * * @param apiHandle : an afb_daemon api handle, see AFB_ApiT in afb_definitions.h * @param requireJ : json_object array of api name required. */ extern void DispatchRequireApi(afb_api_t apiHandle, json_object * requireJ); extern int CtlConfigExec(afb_api_t apiHandle, CtlConfigT *ctlConfig) ; extern CtlConfigT *CtlLoadMetaDataJson(afb_api_t apiHandle,json_object *ctlConfigJ, const char *prefix) ; extern CtlConfigT *CtlLoadMetaDataUsingPrefix(afb_api_t apiHandle,const char* filepath, const char *prefix) ; extern int CtlLoadSections(afb_api_t apiHandle, CtlConfigT *ctlHandle, CtlSectionT *sections); #define CtlLoadMetaData(api, filepath) CtlLoadMetaDataUsingPrefix(api, filepath, NULL) /******************************************************************************* * ctl-event.h * ******************************************************************************/ extern int EventConfig(afb_api_t apihandle, CtlSectionT *section, json_object *actionsJ); extern void CtrlDispatchApiEvent (afb_api_t apiHandle, const char *evtLabel, struct json_object *eventJ); extern void CtrlDispatchV2Event(const char *evtLabel, json_object *eventJ); /******************************************************************************* * ctl-control.h * ******************************************************************************/ extern int ControlConfig(afb_api_t apiHandle, CtlSectionT *section, json_object *actionsJ); /******************************************************************************* * ctl-onload.h * ******************************************************************************/ extern int OnloadConfig(afb_api_t apiHandle, CtlSectionT *section, json_object *actionsJ); /******************************************************************************* * ctl-plugin.h * ******************************************************************************/ /** * @brief Plugins definition loads. You have to call it at least twice, one for * the configuration at binding preinit and the last one at init step to * initilize a API interface for binding with version 2. The last call should * not include any plugin definition to add. * * @param apiHandle an afb_daemon api handle, see AFB_ApiT in afb_definitions.h * @param section The plugin section to process * @param pluginsJ Json_object holding the plugins definitions to load. * @return int 0 if success, other on failure */ extern int PluginConfig(afb_api_t UNUSED_ARG(apiHandle), CtlSectionT *section, json_object *pluginsJ); /** * @brief Permit to find a C callback stored in a plugin to attach it to an * action as well as the plugin. * * @param apiHandle an afb_daemon api handle, see AFB_ApiT in afb_definitions.h * @param action Action structure to use to store the callback if found * @param callbackJ the callback definition to search * @return int 0 if success, other on failure */ extern int PluginGetCB (afb_api_t apiHandle, CtlActionT *action , json_object *callbackJ); extern void* getPluginContext(CtlPluginT *plugin); extern void setPluginContext(CtlPluginT *plugin, void *context); #ifdef __cplusplus } #endif #endif /* _CTL_CONFIG_INCLUDE_ */