diff options
author | Matt Porter <mporter@konsulko.com> | 2017-05-20 09:43:18 -0400 |
---|---|---|
committer | Matt Porter <mporter@konsulko.com> | 2017-05-20 09:49:39 -0400 |
commit | 1f5cd7758161271e7e7c38e5a7dc78396f5c56b8 (patch) | |
tree | eb46ced90b3dfa48b428381df94969fb94badedb /telephony-binding/telephony-binding.c | |
parent | 3a208ed9a418f02b4938f447af04666593cda410 (diff) |
Add support for UI display of phone call duration
Adds support to the telephony binding for generating events when
a call's state changes to active or disconnected states (when a
remote/local party answers or disconnects the call). These events
are used to drive a call duration display in the phone app UI.
AGL-Bug: SPEC-599
Change-Id: Ib4b0b115ca1d0573a7ae046082627f561f0d8d8a
Signed-off-by: Matt Porter <mporter@konsulko.com>
Diffstat (limited to 'telephony-binding/telephony-binding.c')
-rw-r--r-- | telephony-binding/telephony-binding.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/telephony-binding/telephony-binding.c b/telephony-binding/telephony-binding.c index 00115d2..41164f0 100644 --- a/telephony-binding/telephony-binding.c +++ b/telephony-binding/telephony-binding.c @@ -81,6 +81,14 @@ static void answer(struct afb_req request) } } +static void call_state_changed_cb(OrgOfonoVoiceCall *vc, gchar *state) +{ + struct json_object *call_state; + call_state = json_object_new_object(); + json_object_object_add(call_state, "state", json_object_new_string(state)); + afb_daemon_broadcast_event(interface->daemon, "callStateChanged", call_state); +} + static void incoming_call_cb(OrgOfonoVoiceCallManager *manager, gchar *op, gchar *clip) { struct json_object *call_info; @@ -88,7 +96,7 @@ static void incoming_call_cb(OrgOfonoVoiceCallManager *manager, gchar *op, gchar call_info = json_object_new_object(); json_object_object_add(call_info, "clip", json_object_new_string(clip)); afb_daemon_broadcast_event(interface->daemon, "incomingCall", call_info); - incoming_call = ofono_voicecall_new(op); + incoming_call = ofono_voicecall_new(interface, op, call_state_changed_cb); } static void dialing_call_cb(OrgOfonoVoiceCallManager *manager, gchar *op, gchar *colp) @@ -98,7 +106,7 @@ static void dialing_call_cb(OrgOfonoVoiceCallManager *manager, gchar *op, gchar call_info = json_object_new_object(); json_object_object_add(call_info, "colp", json_object_new_string(colp)); afb_daemon_broadcast_event(interface->daemon, "dialingCall", call_info); - voice_call = ofono_voicecall_new(op); + voice_call = ofono_voicecall_new(interface, op, call_state_changed_cb); } static void terminated_call_cb(OrgOfonoVoiceCallManager *manager, gchar *op) |