diff --git a/Sensor-API.md b/Sensor-API.md new file mode 100644 index 00000000..e5e56030 --- /dev/null +++ b/Sensor-API.md @@ -0,0 +1,61 @@ +# Sensor API + +This wiki page is an attempt to document the sensor API for sensor driver development. + +## File structure +Sensor libraries are located in the `lib/` directory. Sensor drivers are located in the `sonoff/` directory. The filename of the sensor driver is `xsns__.ino`, e.g. `xsns_05_ds18b20.ino` where `` is a _unique_ number between 01 and 90 and `` is a human-readable name of the driver. + +## API structure +### Pre-processor directives +Conditional compiling of a sensor driver is achieved by commenting/uncommenting a pre-processor directive of the scheme `USE_` in `user_config.h`. Accordingly the driver code has to be wrapped in `#ifdef USE_ ... #endif // USE_`. Any Sensor driver must contain a pre-processor directive defining the driver ID by the scheme `#define XSNS_`. + +### Callback function +Any sensor driver needs a callback function following the scheme +``` +/** + * The function Xsns() interfaces Tasmota with the driver. + * + * It provides the function IDs + * FUNC_INIT to initialize a driver, + * FUNC_EVERY_50_MSECOND for near real-time operation, + * FUNC_JSON_APPEND for telemetry data and + * FUNC_WEB_APPEND for displaying data in the Tasmota web-interface + * ` + * @param byte function Tasmota function ID. + * @return boolean ??? + * @pre None. + * @post None. + * + */ +boolean Xsns(byte function) +{ + // ??? + boolean result = false; + + // Check which function is called by Tasmota + switch (function) { + case : + + break; + } + + // Return boolean result + return result; +} +``` + + +### Function IDs + +#### FUNC_INIT +FUNC_INIT initializes a sensor driver + +#### FUNC_EVERY_50_MSECOND +FUNC_EVERY_50_MSECOND is called every 50 milliseconds, e.g. for near real-time operation + +#### FUNC_JSON_APPEND +FUNC_JSON_APPEND is called to append telemetry data to the MQTT JSON string when `TELEPERIOD` is due. + +#### FUNC_WEB_APPEND +FUNC_WEB_APPEND is called to add HTML code to the Tasmota web-interface main page. +It should be wrapped in `#ifdef USE_WEBSERVER ... #endif // USE_WEBSERVER` \ No newline at end of file