0a8f1ef17ff9d848e9c14f489989e191ae7e6156
[platform/core/connectivity/bluetooth-frwk.git] / bt-service / bt-service-event-sender.c
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *              http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 #include <glib.h>
19 #include <dlog.h>
20 #include <gio/gio.h>
21 #include "bluetooth-api.h"
22 #include "bt-internal-types.h"
23
24 #include "bt-service-common.h"
25 #include "bt-service-event.h"
26
27 static GDBusConnection *event_conn;
28 static GDBusConnection *hf_local_term_event_conn;
29
30 #ifdef HPS_FEATURE
31 int _bt_send_to_hps(void)
32 {
33         gboolean ret = FALSE;
34         GError *error = NULL;
35
36         BT_DBG(" ");
37
38         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
39
40         ret = g_dbus_connection_emit_signal(event_conn, NULL,
41                                         "/org/projectx/httpproxy",
42                                         "org.projectx.httpproxy_service",
43                                         BT_LE_ENABLED,
44                                         NULL, &error);
45         if (!ret) {
46                 if (error != NULL) {
47                         BT_ERR("D-Bus API failure: errCode[%x], \
48                                         message[%s]",
49                                         error->code, error->message);
50                         g_clear_error(&error);
51                 }
52                 return BLUETOOTH_ERROR_INTERNAL;
53         }
54
55         return BLUETOOTH_ERROR_NONE;
56 }
57 #endif
58
59 int _bt_send_event(int event_type, int event, GVariant *param)
60 {
61         char *path;
62         char *signal;
63         GDBusMessage *msg1 = NULL;
64
65         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
66
67         BT_DBG("event_type [%d], event [%d]", event_type, event);
68
69         switch (event_type) {
70         case BT_ADAPTER_EVENT:
71                 path = BT_ADAPTER_PATH;
72                 break;
73         case BT_LE_ADAPTER_EVENT:
74                 path = BT_LE_ADAPTER_PATH;
75                 break;
76         case BT_DEVICE_EVENT:
77                 path = BT_DEVICE_PATH;
78                 break;
79         case BT_HID_EVENT:
80                 path = BT_HID_PATH;
81                 break;
82         case BT_HID_DEVICE_EVENT:
83                 path = BT_HID_DEVICE_PATH;
84                 break;
85         case BT_HEADSET_EVENT:
86                 path = BT_HEADSET_PATH;
87                 break;
88         case BT_AVRCP_EVENT:
89                 path = BT_AVRCP_PATH;
90                 break;
91         case BT_AVRCP_CONTROL_EVENT:
92                 path = BT_AVRCP_CONTROL_PATH;
93                 break;
94         case BT_NETWORK_EVENT:
95                 path = BT_NETWORK_PATH;
96                 break;
97         case BT_OPP_CLIENT_EVENT:
98                 path = BT_OPP_CLIENT_PATH;
99                 break;
100         case BT_OPP_SERVER_EVENT:
101                 path = BT_OPP_SERVER_PATH;
102                 break;
103         case BT_PBAP_CLIENT_EVENT:
104                 path = BT_PBAP_CLIENT_PATH;
105                 break;
106         case BT_RFCOMM_CLIENT_EVENT:
107                 path = BT_RFCOMM_CLIENT_PATH;
108                 break;
109         case BT_RFCOMM_SERVER_EVENT:
110                 path = BT_RFCOMM_SERVER_PATH;
111                 break;
112         case BT_A2DP_SOURCE_EVENT:
113                 path = BT_A2DP_SOURCE_PATH;
114                 break;
115         default:
116                 BT_ERR("Unknown event");
117                 return BLUETOOTH_ERROR_INTERNAL;
118         }
119
120         switch (event) {
121         case BLUETOOTH_EVENT_ENABLED:
122                 signal = BT_ENABLED;
123                 BT_INFO_C("### BT Enabled");
124                 break;
125         case BLUETOOTH_EVENT_DISABLED:
126                 signal = BT_DISABLED;
127                 BT_INFO_C("### BT Disabled");
128                 break;
129         case BLUETOOTH_EVENT_LE_ENABLED:
130                 signal = BT_LE_ENABLED;
131                 break;
132         case BLUETOOTH_EVENT_LE_DISABLED:
133                 signal = BT_LE_DISABLED;
134                 break;
135         case BLUETOOTH_EVENT_LOCAL_NAME_CHANGED:
136                 signal = BT_ADAPTER_NAME_CHANGED;
137                 break;
138         case BLUETOOTH_EVENT_DISCOVERABLE_MODE_CHANGED:
139                 signal = BT_DISCOVERABLE_MODE_CHANGED;
140                 break;
141         case BLUETOOTH_EVENT_DISCOVERABLE_TIMEOUT_CHANGED:
142                 signal = BT_DISCOVERABLE_TIMEOUT_CHANGED;
143                 break;
144         case BLUETOOTH_EVENT_CONNECTABLE_CHANGED:
145                 signal = BT_CONNECTABLE_CHANGED;
146                 break;
147         case BLUETOOTH_EVENT_DISCOVERY_STARTED:
148                 signal = BT_DISCOVERY_STARTED;
149                 break;
150         case BLUETOOTH_EVENT_REMOTE_DEVICE_FOUND:
151                 signal = BT_DEVICE_FOUND;
152                 break;
153         case BLUETOOTH_EVENT_DISCOVERY_FINISHED:
154                 signal = BT_DISCOVERY_FINISHED;
155                 break;
156         case BLUETOOTH_EVENT_LE_DISCOVERY_STARTED:
157                 signal = BT_LE_DISCOVERY_STARTED;
158                 break;
159         case BLUETOOTH_EVENT_REMOTE_LE_DEVICE_FOUND:
160                 signal = BT_LE_DEVICE_FOUND;
161                 break;
162         case BLUETOOTH_EVENT_LE_DISCOVERY_FINISHED:
163                 signal = BT_LE_DISCOVERY_FINISHED;
164                 break;
165         case BLUETOOTH_EVENT_ADVERTISING_STARTED:
166                 signal = BT_ADVERTISING_STARTED;
167                 break;
168         case BLUETOOTH_EVENT_ADVERTISING_STOPPED:
169                 signal = BT_ADVERTISING_STOPPED;
170                 break;
171         case BLUETOOTH_EVENT_ADVERTISING_MANUFACTURER_DATA_CHANGED:
172                 signal = BT_ADVERTISING_MANUFACTURER_DATA_CHANGED;
173                 break;
174         case BLUETOOTH_EVENT_SCAN_RESPONSE_MANUFACTURER_DATA_CHANGED:
175                 signal = BT_SCAN_RESPONSE_MANUFACTURER_DATA_CHANGED;
176                 break;
177         case BLUETOOTH_EVENT_MANUFACTURER_DATA_CHANGED:
178                 signal = BT_MANUFACTURER_DATA_CHANGED;
179                 break;
180         case BLUETOOTH_EVENT_BONDING_FINISHED:
181                 signal = BT_BOND_CREATED;
182                 break;
183         case BLUETOOTH_EVENT_BONDED_DEVICE_REMOVED:
184                 signal = BT_BOND_DESTROYED;
185                 break;
186         case BLUETOOTH_EVENT_DEVICE_AUTHORIZED:
187                 signal = BT_DEVICE_AUTHORIZED;
188                 break;
189         case BLUETOOTH_EVENT_DEVICE_UNAUTHORIZED:
190                 signal = BT_DEVICE_UNAUTHORIZED;
191                 break;
192         case BLUETOOTH_EVENT_RSSI_ENABLED:
193                 signal = BT_RSSI_MONITORING_ENABLED;
194                 break;
195         case BLUETOOTH_EVENT_RSSI_ALERT:
196                 signal = BT_RSSI_ALERT;
197                 break;
198         case BLUETOOTH_EVENT_RAW_RSSI:
199                 signal = BT_RAW_RSSI_EVENT;
200                 break;
201         case BLUETOOTH_EVENT_SUPPORTED_PROFILE_TRUSTED:
202                 signal = BT_SUPPORTED_PROFILE_TRUSTED;
203                 break;
204         case BLUETOOTH_EVENT_KEYBOARD_PASSKEY_DISPLAY:
205                 signal = BT_KBD_PASSKEY_DISPLAY_REQ_RECEIVED;
206                 break;
207         case BLUETOOTH_EVENT_PIN_REQUEST:
208                 signal = BT_PIN_REQ_RECEIVED;
209                 break;
210         case BLUETOOTH_EVENT_PASSKEY_REQUEST:
211                 signal = BT_PASSKEY_REQ_RECEIVED;
212                 break;
213         case BLUETOOTH_EVENT_PASSKEY_CONFIRM_REQUEST:
214                 signal = BT_PASSKEY_CFM_REQ_RECEIVED;
215                 break;
216         case BLUETOOTH_EVENT_SERVICE_SEARCHED:
217                 signal = BT_SERVICE_SEARCHED;
218                 break;
219         case BLUETOOTH_HID_CONNECTED:
220                 signal = BT_INPUT_CONNECTED;
221                 BT_INFO_C("Connected [HID]");
222                 break;
223         case BLUETOOTH_HID_DISCONNECTED:
224                 signal = BT_INPUT_DISCONNECTED;
225                 BT_INFO_C("Disconnected [HID]");
226                 break;
227         case BLUETOOTH_HID_DEVICE_CONNECTED:
228                 signal = BT_INPUT_HID_DEVICE_CONNECTED;
229                 BT_INFO_C("Connected [HIDDevice]");
230                 break;
231         case BLUETOOTH_HID_DEVICE_DISCONNECTED:
232                 signal = BT_INPUT_HID_DEVICE_DISCONNECTED;
233                 BT_INFO_C("Disconnected [HIDDevice]");
234                 break;
235         case BLUETOOTH_PBAP_CONNECTED:
236                 signal = BT_PBAP_CONNECTED;
237                 BT_INFO_C("Connected [PBAP Client]");
238                 break;
239         case BLUETOOTH_PBAP_DISCONNECTED:
240                 signal = BT_PBAP_DISCONNECTED;
241                 BT_INFO_C("Disconnected [PBAP Client]");
242                 break;
243         case BLUETOOTH_PBAP_PHONEBOOK_SIZE:
244                 signal = BT_PBAP_PHONEBOOK_SIZE;
245                 break;
246         case BLUETOOTH_PBAP_PHONEBOOK_PULL:
247                 signal = BT_PBAP_PHONEBOOK_PULL;
248                 break;
249         case BLUETOOTH_PBAP_VCARD_LIST:
250                 signal = BT_PBAP_VCARD_LIST;
251                 break;
252         case BLUETOOTH_PBAP_VCARD_PULL:
253                 signal = BT_PBAP_VCARD_PULL;
254                 break;
255         case BLUETOOTH_PBAP_PHONEBOOK_SEARCH:
256                 signal = BT_PBAP_SEARCH_PHONEBOOK;
257                 break;
258         case BLUETOOTH_EVENT_AG_CONNECTED:
259                 signal = BT_HEADSET_CONNECTED;
260                 BT_INFO_C("Connected [HSP/HFP]");
261                 break;
262         case BLUETOOTH_EVENT_AG_DISCONNECTED:
263                 signal = BT_HEADSET_DISCONNECTED;
264                 BT_INFO_C("Disconnected [HSP/HFP]");
265                 break;
266         case BLUETOOTH_EVENT_AV_CONNECTED:
267                 signal = BT_STEREO_HEADSET_CONNECTED;
268                 BT_INFO_C("Connected [A2DP]");
269                 break;
270         case BLUETOOTH_EVENT_AV_DISCONNECTED:
271                 signal = BT_STEREO_HEADSET_DISCONNECTED;
272                 BT_INFO_C("Disconnected [A2DP]");
273                 break;
274         case BLUETOOTH_EVENT_AV_SOURCE_CONNECTED:
275                 signal = BT_A2DP_SOURCE_CONNECTED;
276                 BT_INFO_C("Connected [A2DP Source]");
277                 break;
278         case BLUETOOTH_EVENT_AV_SOURCE_DISCONNECTED:
279                 signal = BT_A2DP_SOURCE_DISCONNECTED;
280                 BT_INFO_C("Disconnected [A2DP Source]");
281                 break;
282         case BLUETOOTH_EVENT_AG_AUDIO_CONNECTED:
283                 signal = BT_SCO_CONNECTED;
284                 BT_INFO_C("Connected [SCO]");
285                 break;
286         case BLUETOOTH_EVENT_AG_AUDIO_DISCONNECTED:
287                 signal = BT_SCO_DISCONNECTED;
288                 BT_INFO_C("Disonnected [SCO]");
289                 break;
290         case BLUETOOTH_EVENT_AG_SPEAKER_GAIN:
291                 signal = BT_SPEAKER_GAIN;
292                 break;
293         case BLUETOOTH_EVENT_AG_MIC_GAIN:
294                 signal = BT_MICROPHONE_GAIN;
295                 break;
296         case BLUETOOTH_EVENT_NETWORK_CONNECTED:
297                 signal = BT_NETWORK_CONNECTED;
298                 BT_INFO_C("Connected [Newwork]");
299                 break;
300         case BLUETOOTH_EVENT_NETWORK_DISCONNECTED:
301                 signal = BT_NETWORK_DISCONNECTED;
302                 BT_INFO_C("Disconnected [Newwork]");
303                 break;
304         case BLUETOOTH_EVENT_NETWORK_SERVER_CONNECTED:
305                 signal = BT_NETWORK_SERVER_CONNECTED;
306                 BT_INFO_C("Connected [Network Server]");
307                 break;
308         case BLUETOOTH_EVENT_NETWORK_SERVER_DISCONNECTED:
309                 signal = BT_NETWORK_SERVER_DISCONNECTED;
310                 BT_INFO_C("Disconnected [Network Server]");
311                 break;
312         case BLUETOOTH_EVENT_OPC_CONNECTED:
313                 signal = BT_OPP_CONNECTED;
314                 BT_INFO_C("Connected [OPP]");
315                 break;
316         case BLUETOOTH_EVENT_OPC_DISCONNECTED:
317                 signal = BT_OPP_DISCONNECTED;
318                 BT_INFO_C("Disconnected [OPP]");
319                 break;
320         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_CONNECTED:
321                 signal = BT_TRANSFER_CONNECTED;
322                 break;
323         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_DISCONNECTED:
324                 signal = BT_TRANSFER_DISCONNECTED;
325                 break;
326         case BLUETOOTH_EVENT_OPC_TRANSFER_STARTED:
327         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_STARTED:
328                 signal = BT_TRANSFER_STARTED;
329                 break;
330         case BLUETOOTH_EVENT_OPC_TRANSFER_PROGRESS:
331         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_PROGRESS:
332                 signal = BT_TRANSFER_PROGRESS;
333                 break;
334         case BLUETOOTH_EVENT_OPC_TRANSFER_COMPLETE:
335         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_COMPLETED:
336                 signal = BT_TRANSFER_COMPLETED;
337                 break;
338         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_AUTHORIZE:
339                 signal = BT_TRANSFER_AUTHORIZED;
340                 break;
341         case BLUETOOTH_EVENT_OBEX_SERVER_CONNECTION_AUTHORIZE:
342         case BLUETOOTH_EVENT_RFCOMM_AUTHORIZE:
343                 signal = BT_CONNECTION_AUTHORIZED;
344                 break;
345         case BLUETOOTH_EVENT_RFCOMM_CONNECTED:
346                 signal = BT_RFCOMM_CONNECTED;
347                 break;
348         case BLUETOOTH_EVENT_RFCOMM_DISCONNECTED:
349                 signal = BT_RFCOMM_DISCONNECTED;
350                 break;
351         case BLUETOOTH_EVENT_RFCOMM_DATA_RECEIVED:
352                 signal = BT_RFCOMM_DATA_RECEIVED;
353                 break;
354         case BLUETOOTH_EVENT_RFCOMM_SERVER_REMOVED:
355                 signal = BT_RFCOMM_SERVER_REMOVED;
356                 break;
357         case BLUETOOTH_EVENT_DEVICE_CONNECTED:
358                 signal = BT_DEVICE_CONNECTED;
359                 break;
360         case BLUETOOTH_EVENT_DEVICE_DISCONNECTED:
361                 signal = BT_DEVICE_DISCONNECTED;
362                 break;
363         case BLUETOOTH_EVENT_AVRCP_CONNECTED:
364         case BLUETOOTH_EVENT_AVRCP_CONTROL_CONNECTED:
365                 signal = BT_AVRCP_CONNECTED;
366                 BT_INFO_C("Connected [AVRCP]");
367                 break;
368         case BLUETOOTH_EVENT_AVRCP_DISCONNECTED:
369         case BLUETOOTH_EVENT_AVRCP_CONTROL_DISCONNECTED:
370                 signal = BT_AVRCP_DISCONNECTED;
371                 BT_INFO_C("Disconnected [AVRCP]");
372                 break;
373         case BLUETOOTH_EVENT_AVRCP_SETTING_SHUFFLE_STATUS:
374         case BLUETOOTH_EVENT_AVRCP_CONTROL_SHUFFLE_STATUS:
375                 signal = BT_MEDIA_SHUFFLE_STATUS;
376                 break;
377         case BLUETOOTH_EVENT_AVRCP_SETTING_EQUALIZER_STATUS:
378         case BLUETOOTH_EVENT_AVRCP_CONTROL_EQUALIZER_STATUS:
379                 signal = BT_MEDIA_EQUALIZER_STATUS;
380                 break;
381         case BLUETOOTH_EVENT_AVRCP_SETTING_REPEAT_STATUS:
382         case BLUETOOTH_EVENT_AVRCP_CONTROL_REPEAT_STATUS:
383                 signal = BT_MEDIA_REPEAT_STATUS;
384                 break;
385         case BLUETOOTH_EVENT_AVRCP_SETTING_SCAN_STATUS:
386         case BLUETOOTH_EVENT_AVRCP_CONTROL_SCAN_STATUS:
387                 signal = BT_MEDIA_SCAN_STATUS;
388                 break;
389         case BLUETOOTH_EVENT_AVRCP_SONG_POSITION_STATUS:
390                 signal = BT_MEDIA_POSITION_STATUS;
391                 break;
392         case BLUETOOTH_EVENT_AVRCP_PLAY_STATUS_CHANGED:
393                 signal = BT_MEDIA_PLAY_STATUS;
394                 break;
395         case BLUETOOTH_EVENT_AVRCP_TRACK_CHANGED:
396                 signal = BT_MEDIA_TRACK_CHANGE;
397                 break;
398         case BLUETOOTH_EVENT_GATT_CONNECTED:
399                 signal = BT_GATT_CONNECTED;
400                 BT_INFO_C("### Connected [GATT]");
401                 break;
402         case BLUETOOTH_EVENT_GATT_DISCONNECTED:
403                 signal = BT_GATT_DISCONNECTED;
404                 BT_INFO_C("### Disconnected [GATT]");
405                 break;
406         case BLUETOOTH_EVENT_GATT_ATT_MTU_CHANGED:
407                 signal = BT_GATT_REQ_ATT_MTU_CHANGED;
408                 break;
409         case BLUETOOTH_EVENT_IPSP_INIT_STATE_CHANGED:
410                 signal = BT_IPSP_INITIALIZED;
411                 break;
412         case BLUETOOTH_EVENT_IPSP_CONNECTED:
413                 signal = BT_IPSP_CONNECTED;
414                 break;
415         case BLUETOOTH_EVENT_IPSP_DISCONNECTED:
416                 signal = BT_IPSP_DISCONNECTED;
417                 break;
418         case BLUETOOTH_EVENT_GATT_CHAR_VAL_CHANGED:
419                 signal = BT_GATT_CHAR_VAL_CHANGED;
420                 break;
421         case BLUETOOTH_EVENT_LE_DATA_LENGTH_CHANGED:
422                 signal = BT_LE_DATA_LENGTH_CHANGED;
423                 break;
424         case BLUETOOTH_EVENT_REMOTE_IBEACON_DEVICE_FOUND:
425                 signal = BT_IBEACON_DEVICE_FOUND;
426                 break;
427         default:
428                 BT_ERR("Unknown event");
429                 return BLUETOOTH_ERROR_INTERNAL;
430         }
431
432         BT_DBG("Path : %s", path);
433         BT_INFO_C("Signal : %s", signal);
434
435         msg1 = g_dbus_message_new_signal(path, BT_EVENT_SERVICE, signal);
436         g_dbus_message_set_body(msg1, param);
437         if (!g_dbus_connection_send_message(event_conn, msg1, G_DBUS_SEND_MESSAGE_FLAGS_NONE, 0, NULL)) {
438                 BT_ERR("Error while sending");
439         }
440
441         g_object_unref(msg1);
442
443 #ifdef HPS_FEATURE
444         if (g_strcmp0(signal, BT_LE_ENABLED) == 0)
445                 _bt_send_to_hps();
446 #endif
447
448         return BLUETOOTH_ERROR_NONE;
449 }
450
451 int _bt_send_event_to_dest(const char* dest, int event_type,
452                 int event, GVariant *param)
453 {
454         char *path;
455         char *signal;
456         GError *error = NULL;
457
458         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
459
460         BT_DBG("event_type [%d], event [%d]", event_type, event);
461
462         switch (event_type) {
463         case BT_ADAPTER_EVENT:
464                 path = BT_ADAPTER_PATH;
465                 break;
466         case BT_LE_ADAPTER_EVENT:
467                 path = BT_LE_ADAPTER_PATH;
468                 break;
469         case BT_DEVICE_EVENT:
470                 path = BT_DEVICE_PATH;
471                 break;
472         default:
473                 BT_ERR("Unknown event");
474                 return BLUETOOTH_ERROR_INTERNAL;
475         }
476
477         switch (event) {
478         case BLUETOOTH_EVENT_ADVERTISING_STARTED:
479                 signal = BT_ADVERTISING_STARTED;
480                 break;
481         case BLUETOOTH_EVENT_ADVERTISING_STOPPED:
482                 signal = BT_ADVERTISING_STOPPED;
483                 break;
484         case BLUETOOTH_EVENT_PASSKEY_NOTIFICATION:
485                 signal = BT_PASSKEY_NOTIFICATION;
486                 break;
487         case BLUETOOTH_EVENT_LE_DISCOVERY_STARTED:
488                 signal = BT_LE_DISCOVERY_STARTED;
489                 break;
490         case BLUETOOTH_EVENT_REMOTE_LE_DEVICE_FOUND:
491                 signal = BT_LE_DEVICE_FOUND;
492                 break;
493         case BLUETOOTH_EVENT_LE_DISCOVERY_FINISHED:
494                 signal = BT_LE_DISCOVERY_FINISHED;
495                 break;
496         case BLUETOOTH_EVENT_GATT_CHAR_VAL_CHANGED:
497                 signal = BT_GATT_CHAR_VAL_CHANGED;
498                 break;
499         default:
500                 BT_ERR("Unknown event");
501                 return BLUETOOTH_ERROR_INTERNAL;
502         }
503
504         BT_INFO_C("Signal : %s", signal);
505
506         if (!g_dbus_connection_emit_signal(event_conn, dest, path, BT_EVENT_SERVICE,
507                         signal, param, &error)) {
508                 BT_ERR("Error while sending Signal: %s", signal);
509                 if (error) {
510                         BT_ERR("Error Code [%d], Error Message [%s]",
511                                         error->code, error->message);
512                         g_clear_error(&error);
513                 }
514         }
515
516         return BLUETOOTH_ERROR_NONE;
517 }
518
519 int _bt_send_hf_local_term_event(char *address)
520 {
521         GError *error = NULL;
522
523         retv_if(hf_local_term_event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
524
525         if (!g_dbus_connection_emit_signal(hf_local_term_event_conn, NULL,
526                         BT_HF_LOCAL_TERM_EVENT_PATH,
527                         BT_HF_LOCAL_TERM_EVENT_INTERFACE,
528                         BT_HF_LOCAL_TERM, g_variant_new("s", address),
529                         &error)) {
530                 BT_ERR("Error while sending Signal: %s", signal);
531                 if (error) {
532                         BT_ERR("Error Code [%d], Error Message [%s]",
533                                         error->code, error->message);
534                         g_clear_error(&error);
535                 }
536         }
537
538         return BLUETOOTH_ERROR_NONE;
539 }
540
541 /* To send the event from service daemon to application*/
542 int _bt_init_service_event_sender(void)
543 {
544         GDBusConnection *conn;
545         GError *err = NULL;
546
547         if (event_conn) {
548                 BT_ERR("Event handler is already exist");
549                 return BLUETOOTH_ERROR_INTERNAL;
550         }
551
552         conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
553         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
554         if (conn == NULL) {
555                 BT_ERR("conn == NULL");
556                 if (err) {
557                         BT_ERR("Code[%d], Message[%s]",
558                                         err->code, err->message);
559                         g_clear_error(&err);
560                 }
561
562                 return BLUETOOTH_ERROR_INTERNAL;
563         }
564
565         event_conn = conn;
566         return BLUETOOTH_ERROR_NONE;
567 }
568
569 void _bt_deinit_service_event_sender(void)
570 {
571         if (event_conn) {
572                 g_object_unref(event_conn);
573                 event_conn = NULL;
574         }
575 }
576
577 int _bt_init_hf_local_term_event_sender(void)
578 {
579         GDBusConnection *conn;
580         GError *err = NULL;
581
582         if (hf_local_term_event_conn) {
583                 BT_ERR("Event handler is already exist");
584                 return BLUETOOTH_ERROR_INTERNAL;
585         }
586
587         conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
588         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
589         if (conn == NULL) {
590                 BT_ERR("conn == NULL");
591                 if (err) {
592                         BT_ERR("Code[%d], Message[%s]",
593                                         err->code, err->message);
594                         g_clear_error(&err);
595                 }
596
597                 return BLUETOOTH_ERROR_INTERNAL;
598         }
599
600         hf_local_term_event_conn = conn;
601
602         return BLUETOOTH_ERROR_NONE;
603 }
604
605 void _bt_deinit_hf_local_term_event_sender(void)
606 {
607         if (hf_local_term_event_conn) {
608                 g_object_unref(hf_local_term_event_conn);
609                 hf_local_term_event_conn = NULL;
610         }
611 }
612
613 int _bt_send_dump_signal(char *signal)
614 {
615         GError *error = NULL;
616         int32_t pid = getpid();
617
618         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
619
620         if (!g_dbus_connection_emit_signal(event_conn, NULL,
621                         BT_DUMP_SERVICE_PATH,
622                         BT_DUMP_SERVICE_INTERFACE,
623                         signal, g_variant_new("(i)", pid),
624                         &error)) {
625                 BT_ERR("Error while sending Signal: %s", signal);
626                 if (error) {
627                         BT_ERR("Error Code [%d], Error Message [%s]",
628                                         error->code, error->message);
629                         g_clear_error(&error);
630                 }
631         }
632
633         return BLUETOOTH_ERROR_NONE;
634 }
635