From 518a51ad1d20f0430ab1a06d3920921f076c6184 Mon Sep 17 00:00:00 2001 From: Christian Fetzer Date: Tue, 9 Apr 2013 13:51:37 +0200 Subject: [PATCH] obexd: Automatically setup notification connection for MAP client This automatically establishes the MNS connection when the MAS client session is started and terminates the MNS connection when the MAS client session is closed. The MAP client controls the notification channel using the SetNotificationRegistration function. The MSE will connect/disconnect the MNS connection accordingly. --- obexd/client/map.c | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/obexd/client/map.c b/obexd/client/map.c index 2b665ec0d..3188a0873 100644 --- a/obexd/client/map.c +++ b/obexd/client/map.c @@ -27,6 +27,7 @@ #include #include #include +#include #include #include #include @@ -1690,10 +1691,39 @@ static void map_msg_remove(void *data) g_free(path); } +static bool set_notification_registration(struct map_data *map, bool status) +{ + struct obc_transfer *transfer; + GError *err = NULL; + GObexApparam *apparam; + char contents[2]; + + contents[0] = FILLER_BYTE; + contents[1] = '\0'; + + transfer = obc_transfer_put("x-bt/MAP-NotificationRegistration", NULL, + NULL, contents, sizeof(contents), &err); + + if (transfer == NULL) + return false; + + apparam = g_obex_apparam_set_uint8(NULL, MAP_AP_NOTIFICATIONSTATUS, + status); + + obc_transfer_set_apparam(transfer, apparam); + + if (obc_session_queue(map->session, transfer, NULL, map, &err)) + return true; + + return false; +} + static void map_free(void *data) { struct map_data *map = data; + set_notification_registration(map, false); + obc_session_unref(map->session); g_hash_table_unref(map->messages); g_free(map); @@ -1716,6 +1746,8 @@ static int map_probe(struct obc_session *session) map->messages = g_hash_table_new_full(g_str_hash, g_str_equal, NULL, map_msg_remove); + set_notification_registration(map, true); + if (!g_dbus_register_interface(conn, path, MAP_INTERFACE, map_methods, NULL, NULL, map, map_free)) { map_free(map); -- 2.47.3