#include <zblib.h>
#include <zblib_driver.h>
+#include <zblib_request.h>
#include "zblib_driver_door_lock.h"
ZblibDriverDoorLockOps_t *ops; /**< Operations */
} ZblibDriverDoorLockPrivData_t;
-static gboolean __zblib_driver_door_lock_dispatcher(ZigBeeDriver *driver)
+static gboolean __zblib_driver_door_lock_dispatcher(ZigBeeDriver *driver, guint request_id)
{
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return FALSE;
+ ZigBeeService *service = NULL;
+ ZblibDriverDoorLockPrivData_t *priv_data = NULL;
+ ZblibDriverDoorLockOps_t *ops = NULL;
+ guint request_type;
+ guint ops_id;
+ gboolean ret = FALSE;
+
+ zblib_check_null_ret_error("driver", driver, FALSE);
+
+ service = zblib_driver_ref_service(driver);
+ zblib_check_null_ret_error("service", service, FALSE);
+
+ /* Fetch private data */
+ priv_data = zblib_driver_ref_object(driver);
+ zblib_check_null_ret_error("priv_data", priv_data, FALSE);
+
+ ops = priv_data->ops;
+ zblib_check_null_ret_error("ops", ops, FALSE);
+
+ /* Fetch request_type using request_id */
+ request_type = zblib_request_ref_request_type_by_request_id(service, request_id);
+
+ /* Fetch ops ID */
+ ops_id = zblib_request_get_ops_id(request_type);
+ switch (ops_id) {
+ case ZBLIB_DOOR_LOCK_OPS_SUBSCRIBE_LOCK_EVENT: {
+ zblib_check_null_ret_error("ops->subscribe_lock_event",
+ ops->subscribe_lock_event, FALSE);
+
+ ret = ops->subscribe_lock_event(driver, request_id);
}
+ break;
- return TRUE;
+ case ZBLIB_DOOR_LOCK_OPS_SET_DOOR_LOCK_PIN: {
+ zblib_check_null_ret_error("ops->set_door_lock_pin",
+ ops->set_door_lock_pin, FALSE);
+
+ ret = ops->set_door_lock_pin(driver, request_id);
+ }
+ break;
+
+ case ZBLIB_DOOR_LOCK_OPS_SET_DOOR_LOCK: {
+ zblib_check_null_ret_error("ops->set_door_lock",
+ ops->set_door_lock, FALSE);
+
+ ret = ops->set_door_lock(driver, request_id);
+ }
+ break;
+
+ case ZBLIB_DOOR_LOCK_OPS_GET_LOCK_STATE: {
+ zblib_check_null_ret_error("ops->get_lock_state", ops->get_lock_state, FALSE);
+
+ ret = ops->get_lock_state(driver, request_id);
+ }
+ break;
+
+ default:
+ break;
+ }
+
+ Z_LOGD("ret: [%d]", ret);
+
+ return ret;
}
static void __zblib_driver_door_lock_free_hook(ZigBeeDriver *driver)
{
ZblibDriverDoorLockPrivData_t *priv_data = NULL;
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return;
- }
+ zblib_check_null_ret("driver", driver);
/* Fetch private data */
priv_data = zblib_driver_ref_object(driver);
- if (NULL == priv_data) {
- Z_LOGE("priv_data is NULL");
- return;
- }
+ zblib_check_null_ret("priv_data", priv_data);
/* Free resources */
g_free(priv_data);
ZblibDriverDoorLockPrivData_t *priv_data = NULL;
gboolean ret;
- if (NULL == plugin) {
- Z_LOGE("plugin is NULL");
- return NULL;
- }
+ zblib_check_null_ret_error("plugin", plugin, NULL);
/* Create new driver */
driver = zblib_driver_new(plugin, driver_name, ZBLIB_DRIVER_TYPE_DOOR_LOCK);
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return NULL;
- }
+ zblib_check_null_ret_error("driver", driver, NULL);
/* Allocate memory for private data */
priv_data = g_malloc0(sizeof(ZblibDriverDoorLockPrivData_t));
void zblib_driver_door_lock_free(ZigBeeDriver *driver)
{
- if (NULL == driver) {
- Z_LOGE("driver is NULL");
- return;
- }
+ zblib_check_null_ret("driver", driver);
/* Free driver */
zblib_driver_free(driver);