6789771846f74645f4ebdf623c0d7a1a23e494f5
[platform/core/connectivity/bluetooth-frwk.git] / bt-service-adaptation / services / 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 TIZEN_FEATURE_BT_HPS
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         switch (event_type) {
68         case BT_ADAPTER_EVENT:
69                 path = BT_ADAPTER_PATH;
70                 break;
71         case BT_LE_ADAPTER_EVENT:
72                 path = BT_LE_ADAPTER_PATH;
73                 break;
74         case BT_DEVICE_EVENT:
75                 path = BT_DEVICE_PATH;
76                 break;
77         case BT_HID_EVENT:
78                 path = BT_HID_PATH;
79                 break;
80         case BT_HID_DEVICE_EVENT:
81                 path = BT_HID_DEVICE_PATH;
82                 break;
83         case BT_HEADSET_EVENT:
84                 path = BT_HEADSET_PATH;
85                 break;
86         case BT_AVRCP_EVENT:
87                 path = BT_AVRCP_PATH;
88                 break;
89         case BT_AVRCP_CONTROL_EVENT:
90                 path = BT_AVRCP_CONTROL_PATH;
91                 break;
92         case BT_NETWORK_EVENT:
93                 path = BT_NETWORK_PATH;
94                 break;
95         case BT_OPP_CLIENT_EVENT:
96                 path = BT_OPP_CLIENT_PATH;
97                 break;
98         case BT_OPP_SERVER_EVENT:
99                 path = BT_OPP_SERVER_PATH;
100                 break;
101         case BT_MAP_CLIENT_EVENT:
102                 path = BT_MAP_CLIENT_PATH;
103                 break;
104         case BT_PBAP_CLIENT_EVENT:
105                 path = BT_PBAP_CLIENT_PATH;
106                 break;
107         case BT_RFCOMM_CLIENT_EVENT:
108                 path = BT_RFCOMM_CLIENT_PATH;
109                 break;
110         case BT_RFCOMM_SERVER_EVENT:
111                 path = BT_RFCOMM_SERVER_PATH;
112                 break;
113         case BT_A2DP_SOURCE_EVENT:
114                 path = BT_A2DP_SOURCE_PATH;
115                 break;
116         case BT_OTP_EVENT:
117                 path = BT_OTP_PATH;
118                 break;
119 #ifndef GATT_DIRECT
120         case BT_GATT_SERVER_EVENT:
121                 path = BT_GATT_SERVER_PATH;
122                 break;
123 #endif
124 #ifdef TIZEN_GATT_CLIENT
125         case BT_GATT_CLIENT_EVENT:
126                 path = BT_GATT_CLIENT_PATH;
127                 break;
128 #endif
129
130 #ifdef TIZEN_FEATURE_BT_AVC_TARGET
131         case BT_AUDIO_AVC_EVENT:
132                 path = BT_AUDIO_AVC_PATH;
133                 break;
134 #endif
135         default:
136                 BT_ERR("Unknown event");
137                 return BLUETOOTH_ERROR_INTERNAL;
138         }
139
140         switch (event) {
141         case BLUETOOTH_EVENT_ENABLED:
142                 signal = BT_ENABLED;
143                 BT_INFO_C("### BT Enabled");
144                 break;
145         case BLUETOOTH_EVENT_DISABLED:
146                 signal = BT_DISABLED;
147                 BT_INFO_C("### BT Disabled");
148                 break;
149         case BLUETOOTH_EVENT_DISABLED_BATTERY_DATA:
150                 signal = BT_DISABLED_BATTERY_DATA;
151                 BT_INFO_C("### Sending battery data for last session");
152                 break;
153         case BLUETOOTH_EVENT_LE_ENABLED:
154                 signal = BT_LE_ENABLED;
155                 break;
156         case BLUETOOTH_EVENT_LE_DISABLED:
157                 signal = BT_LE_DISABLED;
158                 break;
159         case BLUETOOTH_EVENT_LOCAL_NAME_CHANGED:
160                 signal = BT_ADAPTER_NAME_CHANGED;
161                 break;
162         case BLUETOOTH_EVENT_DISCOVERABLE_MODE_CHANGED:
163                 signal = BT_DISCOVERABLE_MODE_CHANGED;
164                 break;
165         case BLUETOOTH_EVENT_DISCOVERABLE_TIMEOUT_CHANGED:
166                 signal = BT_DISCOVERABLE_TIMEOUT_CHANGED;
167                 break;
168         case BLUETOOTH_EVENT_CONNECTABLE_CHANGED:
169                 signal = BT_CONNECTABLE_CHANGED;
170                 break;
171         case BLUETOOTH_EVENT_DISCOVERY_STARTED:
172                 signal = BT_DISCOVERY_STARTED;
173                 break;
174         case BLUETOOTH_EVENT_REMOTE_DEVICE_FOUND:
175                 signal = BT_DEVICE_FOUND;
176                 break;
177         case BLUETOOTH_EVENT_DISCOVERY_FINISHED:
178                 signal = BT_DISCOVERY_FINISHED;
179                 break;
180         case BLUETOOTH_EVENT_LE_DISCOVERY_STARTED:
181                 signal = BT_LE_DISCOVERY_STARTED;
182                 break;
183         case BLUETOOTH_EVENT_REMOTE_LE_DEVICE_FOUND:
184                 signal = BT_LE_DEVICE_FOUND;
185                 break;
186         case BLUETOOTH_EVENT_LE_DISCOVERY_FINISHED:
187                 signal = BT_LE_DISCOVERY_FINISHED;
188                 break;
189         case BLUETOOTH_EVENT_ADVERTISING_STARTED:
190                 signal = BT_ADVERTISING_STARTED;
191                 break;
192         case BLUETOOTH_EVENT_ADVERTISING_STOPPED:
193                 signal = BT_ADVERTISING_STOPPED;
194                 break;
195         case BLUETOOTH_EVENT_ADVERTISING_MANUFACTURER_DATA_CHANGED:
196                 signal = BT_ADVERTISING_MANUFACTURER_DATA_CHANGED;
197                 break;
198         case BLUETOOTH_EVENT_SCAN_RESPONSE_MANUFACTURER_DATA_CHANGED:
199                 signal = BT_SCAN_RESPONSE_MANUFACTURER_DATA_CHANGED;
200                 break;
201         case BLUETOOTH_EVENT_MANUFACTURER_DATA_CHANGED:
202                 signal = BT_MANUFACTURER_DATA_CHANGED;
203                 break;
204         case BLUETOOTH_EVENT_BONDING_FINISHED:
205                 signal = BT_BOND_CREATED;
206                 break;
207         case BLUETOOTH_EVENT_BONDED_DEVICE_REMOVED:
208                 signal = BT_BOND_DESTROYED;
209                 break;
210         case BLUETOOTH_EVENT_DEVICE_AUTHORIZED:
211                 signal = BT_DEVICE_AUTHORIZED;
212                 break;
213         case BLUETOOTH_EVENT_DEVICE_UNAUTHORIZED:
214                 signal = BT_DEVICE_UNAUTHORIZED;
215                 break;
216         case BLUETOOTH_EVENT_RSSI_ENABLED:
217                 signal = BT_RSSI_MONITORING_ENABLED;
218                 break;
219         case BLUETOOTH_EVENT_RSSI_ALERT:
220                 signal = BT_RSSI_ALERT;
221                 break;
222         case BLUETOOTH_EVENT_RAW_RSSI:
223                 signal = BT_RAW_RSSI_EVENT;
224                 break;
225         case BLUETOOTH_EVENT_SUPPORTED_PROFILE_TRUSTED:
226                 signal = BT_SUPPORTED_PROFILE_TRUSTED;
227                 break;
228         case BLUETOOTH_EVENT_KEYBOARD_PASSKEY_DISPLAY:
229                 signal = BT_KBD_PASSKEY_DISPLAY_REQ_RECEIVED;
230                 break;
231         case BLUETOOTH_EVENT_PIN_REQUEST:
232                 signal = BT_PIN_REQ_RECEIVED;
233                 break;
234         case BLUETOOTH_EVENT_PASSKEY_REQUEST:
235                 signal = BT_PASSKEY_REQ_RECEIVED;
236                 break;
237         case BLUETOOTH_EVENT_PASSKEY_CONFIRM_REQUEST:
238                 signal = BT_PASSKEY_CFM_REQ_RECEIVED;
239                 break;
240         case BLUETOOTH_EVENT_SERVICE_SEARCHED:
241                 signal = BT_SERVICE_SEARCHED;
242                 break;
243         case BLUETOOTH_HID_CONNECTED:
244                 signal = BT_INPUT_CONNECTED;
245                 BT_INFO_C("### Connected [HID]");
246                 break;
247         case BLUETOOTH_HID_DISCONNECTED:
248                 signal = BT_INPUT_DISCONNECTED;
249                 BT_INFO_C("### Disconnected [HID]");
250                 break;
251         case BLUETOOTH_HID_DEVICE_CONNECTED:
252                 signal = BT_INPUT_HID_DEVICE_CONNECTED;
253                 BT_INFO_C("### Connected [HIDDevice]");
254                 break;
255         case BLUETOOTH_HID_DEVICE_DISCONNECTED:
256                 signal = BT_INPUT_HID_DEVICE_DISCONNECTED;
257                 BT_INFO_C("### Disconnected [HIDDevice]");
258                 break;
259         case BLUETOOTH_PBAP_CONNECTED:
260                 signal = BT_PBAP_CONNECTED;
261                 BT_INFO_C("### Connected [PBAP Client]");
262                 break;
263         case BLUETOOTH_PBAP_DISCONNECTED:
264                 signal = BT_PBAP_DISCONNECTED;
265                 BT_INFO_C("### Disconnected [PBAP Client]");
266                 break;
267         case BLUETOOTH_PBAP_PHONEBOOK_SIZE:
268                 signal = BT_PBAP_PHONEBOOK_SIZE;
269                 break;
270         case BLUETOOTH_PBAP_PHONEBOOK_PULL:
271                 signal = BT_PBAP_PHONEBOOK_PULL;
272                 break;
273         case BLUETOOTH_PBAP_VCARD_LIST:
274                 signal = BT_PBAP_VCARD_LIST;
275                 break;
276         case BLUETOOTH_PBAP_VCARD_PULL:
277                 signal = BT_PBAP_VCARD_PULL;
278                 break;
279         case BLUETOOTH_PBAP_PHONEBOOK_SEARCH:
280                 signal = BT_PBAP_SEARCH_PHONEBOOK;
281                 break;
282         case BLUETOOTH_EVENT_AG_CONNECTED:
283                 signal = BT_HEADSET_CONNECTED;
284                 BT_INFO_C("### Connected [HSP/HFP]");
285                 break;
286         case BLUETOOTH_EVENT_AG_DISCONNECTED:
287                 signal = BT_HEADSET_DISCONNECTED;
288                 BT_INFO_C("### Disconnected [HSP/HFP]");
289                 break;
290         case BLUETOOTH_EVENT_AV_CONNECTED:
291                 signal = BT_STEREO_HEADSET_CONNECTED;
292                 BT_INFO_C("### Connected [A2DP]");
293                 break;
294         case BLUETOOTH_EVENT_AV_DISCONNECTED:
295                 signal = BT_STEREO_HEADSET_DISCONNECTED;
296                 BT_INFO_C("### Disconnected [A2DP]");
297                 break;
298         case BLUETOOTH_EVENT_AV_SOURCE_CONNECTED:
299                 signal = BT_A2DP_SOURCE_CONNECTED;
300                 BT_INFO_C("### Connected [A2DP Source]");
301                 break;
302         case BLUETOOTH_EVENT_AV_SOURCE_DISCONNECTED:
303                 signal = BT_A2DP_SOURCE_DISCONNECTED;
304                 BT_INFO_C("### Disconnected [A2DP Source]");
305                 break;
306         case BLUETOOTH_EVENT_AG_AUDIO_CONNECTED:
307                 signal = BT_SCO_CONNECTED;
308                 BT_INFO_C("### Connected [SCO]");
309                 break;
310         case BLUETOOTH_EVENT_AG_AUDIO_DISCONNECTED:
311                 signal = BT_SCO_DISCONNECTED;
312                 BT_INFO_C("### Disonnected [SCO]");
313                 break;
314         case BLUETOOTH_EVENT_AG_SPEAKER_GAIN:
315                 signal = BT_SPEAKER_GAIN;
316                 break;
317         case BLUETOOTH_EVENT_AG_MIC_GAIN:
318                 signal = BT_MICROPHONE_GAIN;
319                 break;
320         case BLUETOOTH_EVENT_NETWORK_CONNECTED:
321                 signal = BT_NETWORK_CONNECTED;
322                 BT_INFO_C("Connected [Newwork]");
323                 break;
324         case BLUETOOTH_EVENT_NETWORK_DISCONNECTED:
325                 signal = BT_NETWORK_DISCONNECTED;
326                 BT_INFO_C("Disconnected [Newwork]");
327                 break;
328         case BLUETOOTH_EVENT_NETWORK_SERVER_CONNECTED:
329                 signal = BT_NETWORK_SERVER_CONNECTED;
330                 BT_INFO_C("Connected [Network Server]");
331                 break;
332         case BLUETOOTH_EVENT_NETWORK_SERVER_DISCONNECTED:
333                 signal = BT_NETWORK_SERVER_DISCONNECTED;
334                 BT_INFO_C("Disconnected [Network Server]");
335                 break;
336         case BLUETOOTH_EVENT_OPC_CONNECTED:
337                 signal = BT_OPP_CONNECTED;
338                 BT_INFO_C("Connected [OPP]");
339                 break;
340         case BLUETOOTH_EVENT_OPC_DISCONNECTED:
341                 signal = BT_OPP_DISCONNECTED;
342                 BT_INFO_C("Disconnected [OPP]");
343                 break;
344         case BLUETOOTH_EVENT_MAP_CONNECTED:
345                 signal = BT_MAP_CONNECTED;
346                 BT_INFO_C("Connected [MAP]");
347                 break;
348         case BLUETOOTH_EVENT_MAP_DISCONNECTED:
349                 signal = BT_MAP_DISCONNECTED;
350                 BT_INFO_C("Disconnected [MAP]");
351                 break;
352         case BLUETOOTH_EVENT_MAP_LIST_FOLDERS_COMPLETE:
353                 signal = BT_MAP_LIST_FOLDERS_COMPLETE;
354                 BT_INFO_C("Completed list folders operation[MAP]");
355                 break;
356         case BLUETOOTH_EVENT_MAP_LIST_FILTER_FIELD_COMPLETE:
357                 signal = BT_MAP_FILTER_FIELDS_COMPLETE;
358                 BT_INFO_C("Completed list filters field operation[MAP]");
359                 break;
360         case BLUETOOTH_EVENT_MAP_LIST_MESSAGES_COMPLETE:
361                 signal = BT_MAP_LIST_MESSAGES_COMPLETE;
362                 BT_INFO_C("Completed list messages operation [MAP]");
363                 break;
364         case BLUETOOTH_EVENT_MAP_GET_MESSAGE_COMPLETE:
365                 signal = BT_MAP_GET_MESSAGE_COMPLETE;
366                 BT_INFO_C("Completed get message operation [MAP]");
367                 break;
368         case BLUETOOTH_EVENT_MAP_PUSH_MESSAGE_COMPLETE:
369                 signal = BT_MAP_PUSH_MESSAGE_COMPLETE;
370                 BT_INFO_C("Completed push message operation [MAP]");
371                 break;
372         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_CONNECTED:
373                 signal = BT_TRANSFER_CONNECTED;
374                 break;
375         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_DISCONNECTED:
376                 signal = BT_TRANSFER_DISCONNECTED;
377                 break;
378         case BLUETOOTH_EVENT_OPC_TRANSFER_STARTED:
379         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_STARTED:
380                 signal = BT_TRANSFER_STARTED;
381                 break;
382         case BLUETOOTH_EVENT_OPC_TRANSFER_PROGRESS:
383         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_PROGRESS:
384                 signal = BT_TRANSFER_PROGRESS;
385                 break;
386         case BLUETOOTH_EVENT_OPC_TRANSFER_COMPLETE:
387         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_COMPLETED:
388                 signal = BT_TRANSFER_COMPLETED;
389                 break;
390         case BLUETOOTH_EVENT_OBEX_SERVER_TRANSFER_AUTHORIZE:
391                 signal = BT_TRANSFER_AUTHORIZED;
392                 break;
393         case BLUETOOTH_EVENT_OBEX_SERVER_CONNECTION_AUTHORIZE:
394         case BLUETOOTH_EVENT_RFCOMM_AUTHORIZE:
395                 signal = BT_CONNECTION_AUTHORIZED;
396                 break;
397         case BLUETOOTH_EVENT_RFCOMM_CONNECTED:
398                 signal = BT_RFCOMM_CONNECTED;
399                 break;
400         case BLUETOOTH_EVENT_RFCOMM_DISCONNECTED:
401                 signal = BT_RFCOMM_DISCONNECTED;
402                 break;
403         case BLUETOOTH_EVENT_RFCOMM_DATA_RECEIVED:
404                 signal = BT_RFCOMM_DATA_RECEIVED;
405                 break;
406         case BLUETOOTH_EVENT_RFCOMM_SERVER_REMOVED:
407                 signal = BT_RFCOMM_SERVER_REMOVED;
408                 break;
409         case BLUETOOTH_EVENT_DEVICE_CONNECTED:
410                 signal = BT_DEVICE_CONNECTED;
411                 break;
412         case BLUETOOTH_EVENT_DEVICE_DISCONNECTED:
413                 signal = BT_DEVICE_DISCONNECTED;
414                 break;
415         case BLUETOOTH_EVENT_AVRCP_CONNECTED:
416         case BLUETOOTH_EVENT_AVRCP_CONTROL_CONNECTED:
417                 signal = BT_AVRCP_CONNECTED;
418                 BT_INFO_C("Connected [AVRCP]");
419                 break;
420         case BLUETOOTH_EVENT_AVRCP_DISCONNECTED:
421         case BLUETOOTH_EVENT_AVRCP_CONTROL_DISCONNECTED:
422                 signal = BT_AVRCP_DISCONNECTED;
423                 BT_INFO_C("Disconnected [AVRCP]");
424                 break;
425         case BLUETOOTH_EVENT_AVRCP_SETTING_SHUFFLE_STATUS:
426         case BLUETOOTH_EVENT_AVRCP_CONTROL_SHUFFLE_STATUS:
427                 signal = BT_MEDIA_SHUFFLE_STATUS;
428                 break;
429         case BLUETOOTH_EVENT_AVRCP_SETTING_EQUALIZER_STATUS:
430         case BLUETOOTH_EVENT_AVRCP_CONTROL_EQUALIZER_STATUS:
431                 signal = BT_MEDIA_EQUALIZER_STATUS;
432                 break;
433         case BLUETOOTH_EVENT_AVRCP_SETTING_REPEAT_STATUS:
434         case BLUETOOTH_EVENT_AVRCP_CONTROL_REPEAT_STATUS:
435                 signal = BT_MEDIA_REPEAT_STATUS;
436                 break;
437         case BLUETOOTH_EVENT_AVRCP_SETTING_SCAN_STATUS:
438         case BLUETOOTH_EVENT_AVRCP_CONTROL_SCAN_STATUS:
439                 signal = BT_MEDIA_SCAN_STATUS;
440                 break;
441         case BLUETOOTH_EVENT_AVRCP_SONG_POSITION_STATUS:
442                 signal = BT_MEDIA_POSITION_STATUS;
443                 break;
444         case BLUETOOTH_EVENT_AVRCP_PLAY_STATUS_CHANGED:
445                 signal = BT_MEDIA_PLAY_STATUS;
446                 break;
447         case BLUETOOTH_EVENT_AVRCP_TRACK_CHANGED:
448                 signal = BT_MEDIA_TRACK_CHANGE;
449                 break;
450         case BLUETOOTH_EVENT_AVRCP_DELAY_CHANGED:
451                 signal = BT_MEDIA_DELAY_CHANGE;
452                 break;
453         case BLUETOOTH_EVENT_AVRCP_VOLUME_CHANGED:
454                 signal = BT_MEDIA_VOLUME_CHANGE;
455                 break;
456 #ifdef TIZEN_GATT_CLIENT
457         case BLUETOOTH_EVENT_GATT_SERVER_CONNECTED: /* GATT Server and Client */
458                 signal = BT_GATT_SERVER_CONNECTED;
459                 BT_INFO_C("### Connected [GATT server]");
460                 break;
461         case BLUETOOTH_EVENT_GATT_SERVER_DISCONNECTED: /* GATT Client and Server */
462                 signal = BT_GATT_SERVER_DISCONNECTED;
463                 BT_INFO_C("### Disconnected [GATT server]");
464                 break;
465         case BLUETOOTH_EVENT_GATT_CLIENT_CONNECTED: /* GATT Server and Client */
466                 signal = BT_GATT_CLIENT_CONNECTED;
467                 BT_INFO_C("### Connected [GATT client]");
468                 break;
469         case BLUETOOTH_EVENT_GATT_CLIENT_DISCONNECTED: /* GATT Client and Server */
470                 signal = BT_GATT_CLIENT_DISCONNECTED;
471                 BT_INFO_C("### Disconnected [GATT client]");
472                 break;
473 #else
474         case BLUETOOTH_EVENT_GATT_CONNECTED:
475                 signal = BT_GATT_CONNECTED;
476                 BT_INFO_C("### Connected [GATT]");
477                 break;
478         case BLUETOOTH_EVENT_GATT_DISCONNECTED:
479                 signal = BT_GATT_DISCONNECTED;
480                 BT_INFO_C("### Disconnected [GATT]");
481                 break;
482 #endif
483         case BLUETOOTH_EVENT_GATT_ATT_MTU_CHANGED:
484                 signal = BT_GATT_REQ_ATT_MTU_CHANGED;
485                 break;
486         case BLUETOOTH_EVENT_GATT_SERVER_ATT_MTU_CHANGED:
487                 signal = BT_GATT_SERVER_ATT_MTU_CHANGED;
488                 break;
489 #ifndef GATT_DIRECT
490         case BLUETOOTH_EVENT_GATT_SERVER_VALUE_CHANGED:
491                 signal = BT_GATT_VALUE_CHANGED;
492                 break;
493         case BLUETOOTH_EVENT_GATT_SERVER_READ_REQUESTED:
494                 signal = BT_GATT_SERVER_READ_REQ;
495                 break;
496         case BLUETOOTH_EVENT_GATT_SERVER_NOTIFICATION_COMPLETED:
497                 signal = BT_GATT_SERVER_NOTIFICATION_COMPLETED;
498                 break;
499         case BLUETOOTH_EVENT_GATT_SERVER_NOTIFICATION_STATE_CHANGED:
500                 signal = BT_GATT_SERVER_NOTIFICATION_CHANGED;
501                 break;
502         case BLUETOOTH_EVENT_GATT_SERVER_ACQUIRE_WRITE:
503                 signal = BT_GATT_SERVER_ACQUIRE_WRITE;
504                 break;
505         case BLUETOOTH_EVENT_GATT_SERVER_ACQUIRE_NOTIFY:
506                 signal = BT_GATT_SERVER_ACQUIRE_NOTIFICATION;
507                 break;
508 #endif
509 #ifdef TIZEN_GATT_CLIENT
510         case BLUETOOTH_EVENT_GATT_READ_CHAR:       /* GATT Client */
511                 signal = BT_GATT_CLIENT_READ_CHAR;
512                 break;
513         case BLUETOOTH_EVENT_GATT_WRITE_CHAR:      /* GATT Client */
514                 signal = BT_GATT_CLIENT_WRITE_CHAR;
515                 break;
516         case BLUETOOTH_EVENT_GATT_READ_DESC:       /* GATT Client */
517                 signal = BT_GATT_CLIENT_READ_DESC;
518                 break;
519         case BLUETOOTH_EVENT_GATT_WRITE_DESC:      /* GATT Client */
520                 signal = BT_GATT_CLIENT_WRITE_DESC;
521                 break;
522         case BLUETOOTH_EVENT_GATT_CLIENT_SERVICE_CHANGED: /* GATT Client */
523                 signal = BT_GATT_CLIENT_SERVICE_CHANGED;
524                 break;
525 #endif
526
527         case BLUETOOTH_EVENT_IPSP_INIT_STATE_CHANGED:
528                 signal = BT_IPSP_INITIALIZED;
529                 break;
530         case BLUETOOTH_EVENT_IPSP_CONNECTED:
531                 signal = BT_IPSP_CONNECTED;
532                 break;
533         case BLUETOOTH_EVENT_IPSP_DISCONNECTED:
534                 signal = BT_IPSP_DISCONNECTED;
535                 break;
536         case BLUETOOTH_EVENT_GATT_CHAR_VAL_CHANGED:
537                 signal = BT_GATT_CHAR_VAL_CHANGED;
538                 break;
539         case BLUETOOTH_EVENT_LE_DATA_LENGTH_CHANGED:
540                 signal = BT_LE_DATA_LENGTH_CHANGED;
541                 break;
542         case BLUETOOTH_EVENT_PXP_PROPERTY_CHANGED:
543                 signal = BT_PXP_PROPERTY_CHANGED;
544                 break;
545         case BLUETOOTH_EVENT_OTP_SERVER_STATE_CHANGED:
546                 signal = BT_OTP_SERVER_STATE_CHANGED;
547                 break;
548         case BLUETOOTH_EVENT_OTC_STATE_CHANGED:
549                 signal = BT_OTC_STATE_CHANGED;
550                 break;
551 #ifdef TIZEN_FEATURE_BT_AVC_TARGET
552         case BLUETOOTH_EVENT_AUDIO_AVC_MODE_CHANGED:
553                 signal = BT_AUDIO_AVC_MODE_CHANGED;
554                 break;
555 #endif
556         default:
557                 BT_ERR("Unknown event");
558                 return BLUETOOTH_ERROR_INTERNAL;
559         }
560
561         BT_DBG("event_type [%d], event [%d] path [%s]", event_type, event, path);
562
563         if (event != BLUETOOTH_EVENT_DISCOVERABLE_TIMEOUT_CHANGED)
564                 BT_INFO_C("Signal : %s", signal);
565
566         msg1 = g_dbus_message_new_signal(path, BT_EVENT_SERVICE, signal);
567         g_dbus_message_set_body(msg1, param);
568         if (!g_dbus_connection_send_message(event_conn, msg1, G_DBUS_SEND_MESSAGE_FLAGS_NONE, 0, NULL))
569                 BT_ERR("Error while sending");
570
571         g_object_unref(msg1);
572
573 #ifdef TIZEN_FEATURE_BT_HPS
574         if (g_strcmp0(signal, BT_LE_ENABLED) == 0)
575                 _bt_send_to_hps();
576 #endif
577
578         return BLUETOOTH_ERROR_NONE;
579 }
580
581 int _bt_send_event_to_dest(const char* dest, int event_type,
582                 int event, GVariant *param)
583 {
584         char *path;
585         char *signal;
586         GError *error = NULL;
587
588         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
589
590         BT_DBG("event_type [%d], event [%d]", event_type, event);
591
592         switch (event_type) {
593         case BT_ADAPTER_EVENT:
594                 path = BT_ADAPTER_PATH;
595                 break;
596         case BT_LE_ADAPTER_EVENT:
597                 path = BT_LE_ADAPTER_PATH;
598                 break;
599         case BT_DEVICE_EVENT:
600                 path = BT_DEVICE_PATH;
601                 break;
602         case BT_TDS_EVENT:
603                 path = BT_TDS_PATH;
604                 break;
605         case BT_OTP_EVENT:
606                 path = BT_OTP_PATH;
607                 break;
608         case BT_HDP_EVENT:
609                 path = BT_HDP_DEVICE_PATH;
610                 break;
611         default:
612                 BT_ERR("Unknown event");
613                 return BLUETOOTH_ERROR_INTERNAL;
614         }
615
616         switch (event) {
617         case BLUETOOTH_EVENT_ADVERTISING_STARTED:
618                 signal = BT_ADVERTISING_STARTED;
619                 break;
620         case BLUETOOTH_EVENT_ADVERTISING_STOPPED:
621                 signal = BT_ADVERTISING_STOPPED;
622                 break;
623         case BLUETOOTH_EVENT_PASSKEY_NOTIFICATION:
624                 signal = BT_PASSKEY_NOTIFICATION;
625                 break;
626         case BLUETOOTH_EVENT_LE_DISCOVERY_STARTED:
627                 signal = BT_LE_DISCOVERY_STARTED;
628                 break;
629         case BLUETOOTH_EVENT_REMOTE_LE_DEVICE_FOUND:
630                 signal = BT_LE_DEVICE_FOUND;
631                 break;
632         case BLUETOOTH_EVENT_LE_DISCOVERY_FINISHED:
633                 signal = BT_LE_DISCOVERY_FINISHED;
634                 break;
635         case BLUETOOTH_EVENT_GATT_CHAR_VAL_CHANGED:
636                 signal = BT_GATT_CHAR_VAL_CHANGED;
637                 break;
638         case BLUETOOTH_EVENT_TDS_ACTIVATION_REQUESTED:
639                 signal = BT_TDS_ACTIVATION_REQUESTED;
640                 break;
641         case BLUETOOTH_EVENT_TDS_TRANSPORT_DATA_RECEIVED:
642                 signal = BT_TDS_TRANSPORT_DATA_RECEIVED;
643                 break;
644         case BLUETOOTH_EVENT_TDS_ACTIVATION_INDICATION:
645                 signal = BT_TDS_ACTIVATION_INDICATION;
646                 break;
647         case BLUETOOTH_EVENT_TDS_CONTROL_POINT_ENABLED:
648                 signal = BT_TDS_CONTROL_POINT_ENABLED;
649                 break;
650         case BLUETOOTH_EVENT_TDS_ACTIVATION_RESULT:
651                 signal = BT_TDS_ACTIVATION_RESULT;
652                 break;
653         case BLUETOOTH_EVENT_OTP_READ_CHAR_VAL:
654                 signal = BT_OTP_READ_CHAR_VAL;
655                 break;
656         case BLUETOOTH_EVENT_OTP_NOTIFICATION_ENABLED:
657                 signal = BT_OTP_NOTIFICATION_ENABLED;
658                 break;
659         case BLUETOOTH_EVENT_OTP_WRITE_CHAR_VAL:
660                 signal = BT_OTP_WRITE_CHAR_VAL;
661                 break;
662         case BLUETOOTH_EVENT_OTP_INDICATION:
663                 signal = BT_OTP_INDICATION;
664                 break;
665         case BLUETOOTH_EVENT_HDP_CONNECTED:
666                 signal = BT_HDP_CONNECTED;
667                 break;
668         case BLUETOOTH_EVENT_HDP_DISCONNECTED:
669                 signal = BT_HDP_DISCONNECTED;
670                 break;
671         default:
672                 BT_ERR("Unknown event");
673                 return BLUETOOTH_ERROR_INTERNAL;
674         }
675
676         if (event != BLUETOOTH_EVENT_REMOTE_LE_DEVICE_FOUND)
677                 BT_INFO_C("Signal : %s", signal);
678         else
679                 BT_DBG("Signal : %s", signal);
680
681         if (!g_dbus_connection_emit_signal(event_conn, dest, path, BT_EVENT_SERVICE,
682                         signal, param, &error)) {
683                 BT_ERR("Error while sending Signal: %s", signal);
684                 if (error) {
685                         BT_ERR("Error Code [%d], Error Message [%s]",
686                                         error->code, error->message);
687                         g_clear_error(&error);
688                 }
689         }
690
691         return BLUETOOTH_ERROR_NONE;
692 }
693
694 int _bt_send_hf_local_term_event(char *address)
695 {
696         GError *error = NULL;
697
698         retv_if(hf_local_term_event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
699
700         if (!g_dbus_connection_emit_signal(hf_local_term_event_conn, NULL,
701                         BT_HF_LOCAL_TERM_EVENT_PATH,
702                         BT_HF_LOCAL_TERM_EVENT_INTERFACE,
703                         BT_HF_LOCAL_TERM, g_variant_new("s", address),
704                         &error)) {
705                 BT_ERR("Error while sending Signal: %s", address);
706                 if (error) {
707                         BT_ERR("Error Code [%d], Error Message [%s]",
708                                         error->code, error->message);
709                         g_clear_error(&error);
710                 }
711         }
712
713         return BLUETOOTH_ERROR_NONE;
714 }
715
716 /* To send the event from service daemon to application*/
717 int _bt_init_service_event_sender(void)
718 {
719         GDBusConnection *conn;
720         GError *err = NULL;
721
722         if (event_conn) {
723                 BT_ERR("Event handler is already exist");
724                 return BLUETOOTH_ERROR_INTERNAL;
725         }
726
727         conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
728
729         if (conn == NULL) {
730                 BT_ERR("conn == NULL");
731                 if (err) {
732                         BT_ERR("Code[%d], Message[%s]",
733                                         err->code, err->message);
734                         g_clear_error(&err);
735                 }
736
737                 return BLUETOOTH_ERROR_INTERNAL;
738         }
739
740         event_conn = conn;
741         return BLUETOOTH_ERROR_NONE;
742 }
743
744 void _bt_deinit_service_event_sender(void)
745 {
746         if (event_conn) {
747                 g_object_unref(event_conn);
748                 event_conn = NULL;
749         }
750 }
751
752 int _bt_init_hf_local_term_event_sender(void)
753 {
754         GDBusConnection *conn;
755         GError *err = NULL;
756
757         if (hf_local_term_event_conn) {
758                 BT_ERR("Event handler is already exist");
759                 return BLUETOOTH_ERROR_INTERNAL;
760         }
761
762         conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
763
764         if (conn == NULL) {
765                 BT_ERR("conn == NULL");
766                 if (err) {
767                         BT_ERR("Code[%d], Message[%s]",
768                                         err->code, err->message);
769                         g_clear_error(&err);
770                 }
771
772                 return BLUETOOTH_ERROR_INTERNAL;
773         }
774
775         hf_local_term_event_conn = conn;
776
777         return BLUETOOTH_ERROR_NONE;
778 }
779
780 void _bt_deinit_hf_local_term_event_sender(void)
781 {
782         if (hf_local_term_event_conn) {
783                 g_object_unref(hf_local_term_event_conn);
784                 hf_local_term_event_conn = NULL;
785         }
786 }
787
788 int _bt_send_dump_signal(char *signal)
789 {
790         GError *error = NULL;
791         int32_t pid = getpid();
792
793         retv_if(event_conn == NULL, BLUETOOTH_ERROR_INTERNAL);
794
795         if (!g_dbus_connection_emit_signal(event_conn, NULL,
796                         BT_DUMP_SERVICE_PATH,
797                         BT_DUMP_SERVICE_INTERFACE,
798                         signal, g_variant_new("(i)", pid),
799                         &error)) {
800                 BT_ERR("Error while sending Signal: %s", signal);
801                 if (error) {
802                         BT_ERR("Error Code [%d], Error Message [%s]",
803                                         error->code, error->message);
804                         g_clear_error(&error);
805                 }
806         }
807
808         return BLUETOOTH_ERROR_NONE;
809 }
810