blob: d66fecd9e2a0bf7832fb60fd8191619d0206ab03 [file] [log] [blame]
Alexandre Savard14323be2012-10-24 10:02:13 -04001/*
alisionb1763882013-06-18 17:30:51 -04002 * Copyright (C) 2004-2013 Savoir-Faire Linux Inc.
Alexandre Savard14323be2012-10-24 10:02:13 -04003 *
4 * Author: Alexandre Savard <alexandre.savard@savoirfairelinux.com>
Adrien Béraud71b2f812013-04-26 18:51:02 +10005 * Author: Adrien Béraud <adrien.beraud@savoirfairelinux.com>
alisionfde875f2013-05-28 17:01:54 -04006 * Author: Alexandre Lision <alexandre.lision@savoirfairelinux.com>
Alexandre Savard14323be2012-10-24 10:02:13 -04007 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 *
22 * Additional permission under GNU GPL version 3 section 7:
23 *
24 * If you modify this program, or any covered work, by linking or
25 * combining it with the OpenSSL project's OpenSSL library (or a
26 * modified version of that library), containing parts covered by the
27 * terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
28 * grants you additional permission to convey the resulting work.
29 * Corresponding Source for a non-source form of such a combination
30 * shall include the source code for the parts of OpenSSL used as well
31 * as that of the covered work.
32 */
33
34package com.savoirfairelinux.sflphone.client;
35
Alexandre Lision3c6b7102013-09-16 16:56:46 -040036import java.util.ArrayList;
alision85704182013-05-29 15:23:03 -040037import java.util.HashMap;
Adrien Béraud33268882013-05-18 03:41:15 +100038
Alexandre Savard14323be2012-10-24 10:02:13 -040039import android.app.Activity;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040040import android.content.ComponentName;
alision17052d42013-04-22 10:39:38 -040041import android.content.Context;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040042import android.content.Intent;
alision84813a12013-05-27 17:40:39 -040043import android.content.IntentFilter;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040044import android.content.ServiceConnection;
alision55c36cb2013-06-14 14:57:38 -040045import android.net.Uri;
Alexandre Savard14323be2012-10-24 10:02:13 -040046import android.os.Bundle;
Alexandre Lision0c384512013-09-17 17:15:57 -040047import android.os.Handler;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040048import android.os.IBinder;
alision85992112013-05-29 12:18:08 -040049import android.os.RemoteException;
Alexandre Lision0c384512013-09-17 17:15:57 -040050import android.os.SystemClock;
alisionfde875f2013-05-28 17:01:54 -040051import android.support.v4.widget.SlidingPaneLayout;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040052import android.util.Log;
alisionfde875f2013-05-28 17:01:54 -040053import android.view.View;
Adrien Béraud33268882013-05-18 03:41:15 +100054import android.widget.Toast;
Alexandre Savard14323be2012-10-24 10:02:13 -040055
56import com.savoirfairelinux.sflphone.R;
alision84813a12013-05-27 17:40:39 -040057import com.savoirfairelinux.sflphone.fragments.CallFragment;
alisionfde875f2013-05-28 17:01:54 -040058import com.savoirfairelinux.sflphone.fragments.CallListFragment;
alision84813a12013-05-27 17:40:39 -040059import com.savoirfairelinux.sflphone.interfaces.CallInterface;
alision55c36cb2013-06-14 14:57:38 -040060import com.savoirfairelinux.sflphone.model.CallContact;
alisiondf1dac92013-06-27 17:35:53 -040061import com.savoirfairelinux.sflphone.model.Conference;
alisionf76de3b2013-04-16 15:35:22 -040062import com.savoirfairelinux.sflphone.model.SipCall;
alision85992112013-05-29 12:18:08 -040063import com.savoirfairelinux.sflphone.model.SipCall.state;
alisioncc7bb422013-06-06 15:31:39 -040064import com.savoirfairelinux.sflphone.receivers.CallReceiver;
alision84813a12013-05-27 17:40:39 -040065import com.savoirfairelinux.sflphone.service.CallManagerCallBack;
Alexandre Savard6d54bbc2012-10-24 11:04:23 -040066import com.savoirfairelinux.sflphone.service.ISipService;
67import com.savoirfairelinux.sflphone.service.SipService;
Adrien Béraudc9c424d2013-05-30 17:47:35 +100068import com.savoirfairelinux.sflphone.views.CallPaneLayout;
Alexandre Savard14323be2012-10-24 10:02:13 -040069
alisionfde875f2013-05-28 17:01:54 -040070public class CallActivity extends Activity implements CallInterface, CallFragment.Callbacks, CallListFragment.Callbacks {
alision55c36cb2013-06-14 14:57:38 -040071 static final String TAG = "CallActivity";
72 private ISipService service;
alision84813a12013-05-27 17:40:39 -040073
alision55c36cb2013-06-14 14:57:38 -040074 CallReceiver receiver;
alision85992112013-05-29 12:18:08 -040075
alision55c36cb2013-06-14 14:57:38 -040076 CallPaneLayout slidingPaneLayout;
Adrien Béraud33268882013-05-18 03:41:15 +100077
alision55c36cb2013-06-14 14:57:38 -040078 CallListFragment mCallsFragment;
79 CallFragment mCurrentCallFragment;
alisiondf1dac92013-06-27 17:35:53 -040080 private boolean fragIsChanging;
Alexandre Lision1a9e3b12013-09-16 11:06:07 -040081
82 /* result code sent in c&ase of call failure */
Alexandre Lisionc51ccb12013-09-11 16:00:30 -040083 public static int RESULT_FAILURE = -10;
Alexandre Savard4f42ade2012-10-24 18:03:31 -040084
alision55c36cb2013-06-14 14:57:38 -040085 @Override
86 protected void onCreate(Bundle savedInstanceState) {
87 super.onCreate(savedInstanceState);
88 setContentView(R.layout.activity_call_layout);
Alexandre Savard4f42ade2012-10-24 18:03:31 -040089
alision55c36cb2013-06-14 14:57:38 -040090 receiver = new CallReceiver(this);
Adrien Béraud33268882013-05-18 03:41:15 +100091
alision55c36cb2013-06-14 14:57:38 -040092 mCallsFragment = new CallListFragment();
Adrien Béraud33268882013-05-18 03:41:15 +100093
alision55c36cb2013-06-14 14:57:38 -040094 getFragmentManager().beginTransaction().replace(R.id.calllist_pane, mCallsFragment).commit();
alision85992112013-05-29 12:18:08 -040095
alision55c36cb2013-06-14 14:57:38 -040096 slidingPaneLayout = (CallPaneLayout) findViewById(R.id.slidingpanelayout);
alisiondf1dac92013-06-27 17:35:53 -040097
alision55c36cb2013-06-14 14:57:38 -040098 slidingPaneLayout.setPanelSlideListener(new SlidingPaneLayout.PanelSlideListener() {
alision84813a12013-05-27 17:40:39 -040099
alision55c36cb2013-06-14 14:57:38 -0400100 @Override
101 public void onPanelSlide(View view, float offSet) {
102 }
alisionfde875f2013-05-28 17:01:54 -0400103
alision55c36cb2013-06-14 14:57:38 -0400104 @Override
105 public void onPanelOpened(View view) {
alisionfde875f2013-05-28 17:01:54 -0400106
alision55c36cb2013-06-14 14:57:38 -0400107 switch (view.getId()) {
108 case R.id.calllist_pane:
109 // getFragmentManager().findFragmentById(R.id.calllist_pane).setHasOptionsMenu(true);
110 // getFragmentManager().findFragmentById(R.id.ongoingcall_pane).setHasOptionsMenu(false);
111 break;
112 default:
113 break;
114 }
115 }
alisionfde875f2013-05-28 17:01:54 -0400116
alision55c36cb2013-06-14 14:57:38 -0400117 @Override
118 public void onPanelClosed(View view) {
alisionfde875f2013-05-28 17:01:54 -0400119
alision55c36cb2013-06-14 14:57:38 -0400120 switch (view.getId()) {
121 case R.id.ongoingcall_pane:
alisiondf1dac92013-06-27 17:35:53 -0400122 if (fragIsChanging) {
123 getFragmentManager().beginTransaction().replace(R.id.ongoingcall_pane, mCurrentCallFragment).commit();
124
125 fragIsChanging = false;
Alexandre Lisiona764c682013-09-09 10:02:07 -0400126 } else if (mCurrentCallFragment != null && mCurrentCallFragment.getBubbleView() != null) {
alisiondf1dac92013-06-27 17:35:53 -0400127 mCurrentCallFragment.getBubbleView().restartDrawing();
128 }
129
alision55c36cb2013-06-14 14:57:38 -0400130 break;
131 default:
132 break;
133 }
134 }
135 });
alisionfde875f2013-05-28 17:01:54 -0400136
alision55c36cb2013-06-14 14:57:38 -0400137 Intent intent = new Intent(this, SipService.class);
138 bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
Alexandre Lisionc51ccb12013-09-11 16:00:30 -0400139 slidingPaneLayout.setCoveredFadeColor(0xFF0000);
alision55c36cb2013-06-14 14:57:38 -0400140 }
alisiond45da712013-05-30 09:18:49 -0400141
alision55c36cb2013-06-14 14:57:38 -0400142 /* activity gets back to the foreground and user input */
143 @Override
144 protected void onResume() {
145 Log.i(TAG, "onResume");
146 IntentFilter intentFilter = new IntentFilter();
147 intentFilter.addAction(CallManagerCallBack.INCOMING_CALL);
148 intentFilter.addAction(CallManagerCallBack.INCOMING_TEXT);
149 intentFilter.addAction(CallManagerCallBack.CALL_STATE_CHANGED);
alisiondf1dac92013-06-27 17:35:53 -0400150 intentFilter.addAction(CallManagerCallBack.CONF_CREATED);
151 intentFilter.addAction(CallManagerCallBack.CONF_REMOVED);
152 intentFilter.addAction(CallManagerCallBack.CONF_CHANGED);
153 intentFilter.addAction(CallManagerCallBack.RECORD_STATE_CHANGED);
alision55c36cb2013-06-14 14:57:38 -0400154 registerReceiver(receiver, intentFilter);
Alexandre Lision0c384512013-09-17 17:15:57 -0400155
alision55c36cb2013-06-14 14:57:38 -0400156 super.onResume();
157 }
alisiond45da712013-05-30 09:18:49 -0400158
Alexandre Lision0c384512013-09-17 17:15:57 -0400159 private Handler mHandler = new Handler();
160 private Runnable mUpdateTimeTask = new Runnable() {
Adrien Béraud9360f242013-09-19 11:07:42 +1000161 @Override
Alexandre Lision0c384512013-09-17 17:15:57 -0400162 public void run() {
Alexandre Lisionfd7a88f2013-09-18 10:03:17 -0400163 if(mCurrentCallFragment != null)
164 mCurrentCallFragment.updateTime();
Alexandre Lision0c384512013-09-17 17:15:57 -0400165 mCallsFragment.update();
166
Adrien Béraud9360f242013-09-19 11:07:42 +1000167 mHandler.postAtTime(this, SystemClock.uptimeMillis() + 1000);
Alexandre Lision0c384512013-09-17 17:15:57 -0400168 }
169 };
170
alision55c36cb2013-06-14 14:57:38 -0400171 /* activity no more in foreground */
172 @Override
173 protected void onPause() {
174 super.onPause();
Alexandre Lision0c384512013-09-17 17:15:57 -0400175 mHandler.removeCallbacks(mUpdateTimeTask);
alision55c36cb2013-06-14 14:57:38 -0400176 }
Alexandre Savard6d54bbc2012-10-24 11:04:23 -0400177
alision55c36cb2013-06-14 14:57:38 -0400178 @Override
179 protected void onDestroy() {
Alexandre Savard6d54bbc2012-10-24 11:04:23 -0400180
alision55c36cb2013-06-14 14:57:38 -0400181 unregisterReceiver(receiver);
182
183 try {
alision2cb99562013-05-30 17:02:20 -0400184 service.createNotification();
185 } catch (RemoteException e) {
186 Log.e(TAG, e.toString());
187 }
alision55c36cb2013-06-14 14:57:38 -0400188 // Log.i(TAG, "Destroying Call Activity for call " + mCall.getCallId());
189 // LocalBroadcastManager.getInstance(this).unregisterReceiver(mMessageReceiver);
190 try {
alision2cb99562013-05-30 17:02:20 -0400191 service.destroyNotification();
192 } catch (RemoteException e) {
193 Log.e(TAG, e.toString());
194 }
alision55c36cb2013-06-14 14:57:38 -0400195 unbindService(mConnection);
Adrien Béraud33268882013-05-18 03:41:15 +1000196
alision55c36cb2013-06-14 14:57:38 -0400197 super.onDestroy();
198 }
Adrien Béraud33268882013-05-18 03:41:15 +1000199
alision55c36cb2013-06-14 14:57:38 -0400200 /** Defines callbacks for service binding, passed to bindService() */
201 private ServiceConnection mConnection = new ServiceConnection() {
202 @Override
203 public void onServiceConnected(ComponentName className, IBinder binder) {
204 service = ISipService.Stub.asInterface(binder);
alisiondf1dac92013-06-27 17:35:53 -0400205
alision55c36cb2013-06-14 14:57:38 -0400206 mCurrentCallFragment = new CallFragment();
Adrien Béraud9360f242013-09-19 11:07:42 +1000207
alision55c36cb2013-06-14 14:57:38 -0400208 Uri u = getIntent().getData();
209 if (u != null) {
210 CallContact c = CallContact.ContactBuilder.buildUnknownContact(u.getSchemeSpecificPart());
211 try {
212 service.destroyNotification();
alision907bde72013-06-20 14:40:37 -0400213 SipCall call = SipCall.SipCallBuilder.getInstance().startCallCreation().setContact(c)
alision55c36cb2013-06-14 14:57:38 -0400214 .setAccountID(service.getAccountList().get(1).toString()).setCallType(SipCall.state.CALL_TYPE_OUTGOING).build();
alisiondf1dac92013-06-27 17:35:53 -0400215 Conference tmp = new Conference("-1");
216 tmp.getParticipants().add(call);
alision55c36cb2013-06-14 14:57:38 -0400217 Bundle b = new Bundle();
alisiondf1dac92013-06-27 17:35:53 -0400218 b.putParcelable("conference", tmp);
alision1005ba12013-06-19 13:52:44 -0400219 Log.i(TAG, "Arguments set");
alision55c36cb2013-06-14 14:57:38 -0400220 mCurrentCallFragment.setArguments(b);
221 } catch (RemoteException e) {
alision55c36cb2013-06-14 14:57:38 -0400222 e.printStackTrace();
223 } catch (Exception e) {
alision55c36cb2013-06-14 14:57:38 -0400224 e.printStackTrace();
225 }
alision55c36cb2013-06-14 14:57:38 -0400226 } else {
alisiondf1dac92013-06-27 17:35:53 -0400227 if (getIntent().getBooleanExtra("resuming", false)) {
228
229 Bundle b = new Bundle();
Adrien Béraud9360f242013-09-19 11:07:42 +1000230 b.putParcelable("conference", getIntent().getParcelableExtra("conference"));
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400231 mCurrentCallFragment.setArguments(b);
232
alisiondf1dac92013-06-27 17:35:53 -0400233 } else {
234 mCurrentCallFragment.setArguments(getIntent().getExtras());
235 }
236
alision55c36cb2013-06-14 14:57:38 -0400237 }
Alexandre Savard6d54bbc2012-10-24 11:04:23 -0400238
alision55c36cb2013-06-14 14:57:38 -0400239 slidingPaneLayout.setCurFragment(mCurrentCallFragment);
240 getIntent().getExtras();
241 mCallsFragment.update();
242 getFragmentManager().beginTransaction().replace(R.id.ongoingcall_pane, mCurrentCallFragment).commit();
alisiond8c83882013-05-17 17:00:42 -0400243
alision55c36cb2013-06-14 14:57:38 -0400244 }
Adrien Béraud6bbce912013-05-24 00:48:13 +1000245
alision55c36cb2013-06-14 14:57:38 -0400246 @Override
247 public void onServiceDisconnected(ComponentName arg0) {
248 }
249 };
Adrien Béraud6bbce912013-05-24 00:48:13 +1000250
alision55c36cb2013-06-14 14:57:38 -0400251 @Override
252 public void incomingCall(Intent call) {
253 Toast.makeText(this, "New Call incoming", Toast.LENGTH_LONG).show();
Alexandre Savarde41f5212012-10-26 14:23:50 -0400254
alision55c36cb2013-06-14 14:57:38 -0400255 mCallsFragment.update();
Alexandre Savarddf544262012-10-25 14:24:08 -0400256
alision55c36cb2013-06-14 14:57:38 -0400257 }
alision84813a12013-05-27 17:40:39 -0400258
alision55c36cb2013-06-14 14:57:38 -0400259 @Override
260 public void callStateChanged(Intent callState) {
alision84813a12013-05-27 17:40:39 -0400261
alision55c36cb2013-06-14 14:57:38 -0400262 Bundle b = callState.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate");
263 processCallStateChangedSignal(b.getString("CallID"), b.getString("State"));
alision84813a12013-05-27 17:40:39 -0400264
alision55c36cb2013-06-14 14:57:38 -0400265 }
alision84813a12013-05-27 17:40:39 -0400266
alision55c36cb2013-06-14 14:57:38 -0400267 public void processCallStateChangedSignal(String callID, String newState) {
268 /*
269 * Bundle bundle = intent.getBundleExtra("com.savoirfairelinux.sflphone.service.newstate"); String callID = bundle.getString("CallID"); String
270 * newState = bundle.getString("State");
271 */
272 // CallFragment fr = mCurrentCallFragment;
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400273
alision55c36cb2013-06-14 14:57:38 -0400274 mCallsFragment.update();
alision84813a12013-05-27 17:40:39 -0400275
Alexandre Lisiona764c682013-09-09 10:02:07 -0400276 if (mCurrentCallFragment != null)
277 mCurrentCallFragment.changeCallState(callID, newState);
Adrien Béraud29556042013-04-26 17:35:43 +1000278
alision55c36cb2013-06-14 14:57:38 -0400279 try {
alisiondf1dac92013-06-27 17:35:53 -0400280 HashMap<String, SipCall> callMap = (HashMap<String, SipCall>) service.getCallList();
281 HashMap<String, Conference> confMap = (HashMap<String, Conference>) service.getConferenceList();
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400282
alision34673e62013-06-25 14:40:07 -0400283 if (callMap.size() == 0 && confMap.size() == 0) {
alision34673e62013-06-25 14:40:07 -0400284 finish();
alision55c36cb2013-06-14 14:57:38 -0400285 }
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400286
287 if (callMap.size() > 0) {
288 ArrayList<SipCall> calls = new ArrayList<SipCall>(callMap.values());
289 HashMap<String, String> details = (HashMap<String, String>) service.getCallDetails(calls.get(0).getCallId());
Alexandre Lision0c384512013-09-17 17:15:57 -0400290
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400291 }
alision55c36cb2013-06-14 14:57:38 -0400292 } catch (RemoteException e) {
Alexandre Lision3c6b7102013-09-16 16:56:46 -0400293
alision55c36cb2013-06-14 14:57:38 -0400294 Log.e(TAG, e.toString());
295 }
Adrien Béraud29556042013-04-26 17:35:43 +1000296
alision55c36cb2013-06-14 14:57:38 -0400297 Log.w(TAG, "processCallStateChangedSignal " + newState);
Adrien Béraud71b2f812013-04-26 18:51:02 +1000298
alision55c36cb2013-06-14 14:57:38 -0400299 }
300
301 @Override
302 public void incomingText(Intent msg) {
303 Bundle b = msg.getBundleExtra("com.savoirfairelinux.sflphone.service.newtext");
304
alisiona2a2da12013-06-05 15:58:39 -0400305 Toast.makeText(this, b.getString("From") + " : " + b.getString("Msg"), Toast.LENGTH_LONG).show();
Adrien Béraud71b2f812013-04-26 18:51:02 +1000306
alision55c36cb2013-06-14 14:57:38 -0400307 }
alision7f18fc82013-05-01 09:37:33 -0400308
alision55c36cb2013-06-14 14:57:38 -0400309 @Override
310 public ISipService getService() {
311 return service;
312 }
alision04a00182013-05-10 17:05:29 -0400313
alision55c36cb2013-06-14 14:57:38 -0400314 @Override
alisiondf1dac92013-06-27 17:35:53 -0400315 public void onCallSelected(Conference conf) {
alision85992112013-05-29 12:18:08 -0400316
Alexandre Lisiona764c682013-09-09 10:02:07 -0400317 if (mCurrentCallFragment == null || mCurrentCallFragment.getBubbleView() == null) {
alisiondf1dac92013-06-27 17:35:53 -0400318 return;
319 }
320 mCurrentCallFragment.getBubbleView().stopThread();
alision55c36cb2013-06-14 14:57:38 -0400321 mCurrentCallFragment = new CallFragment();
322 Bundle b = new Bundle();
alision34673e62013-06-25 14:40:07 -0400323
alisiondf1dac92013-06-27 17:35:53 -0400324 b.putParcelable("conference", conf);
alision55c36cb2013-06-14 14:57:38 -0400325 mCurrentCallFragment.setArguments(b);
alision85992112013-05-29 12:18:08 -0400326
alisiondf1dac92013-06-27 17:35:53 -0400327 // if (calls.size() == 1) {
328 // onCallResumed(calls.get(0));
329 // }
330
alision55c36cb2013-06-14 14:57:38 -0400331 slidingPaneLayout.setCurFragment(mCurrentCallFragment);
332 slidingPaneLayout.closePane();
alisiondf1dac92013-06-27 17:35:53 -0400333 fragIsChanging = true;
alision85992112013-05-29 12:18:08 -0400334
alision55c36cb2013-06-14 14:57:38 -0400335 }
alision85992112013-05-29 12:18:08 -0400336
alision55c36cb2013-06-14 14:57:38 -0400337 @Override
338 public void callContact(SipCall call) {
339 try {
340 service.placeCall(call);
341 } catch (RemoteException e) {
342 Log.e(TAG, "Cannot call service method", e);
343 }
alision85992112013-05-29 12:18:08 -0400344
alision55c36cb2013-06-14 14:57:38 -0400345 }
alision85992112013-05-29 12:18:08 -0400346
alision55c36cb2013-06-14 14:57:38 -0400347 @Override
348 public void onCallAccepted(SipCall call) {
349 int callState = call.getCallStateInt();
350 if (callState != state.CALL_STATE_RINGING && callState != state.CALL_STATE_NONE) {
351 return;
352 }
alision85992112013-05-29 12:18:08 -0400353
alision55c36cb2013-06-14 14:57:38 -0400354 try {
355 service.accept(call.getCallId());
356 } catch (RemoteException e) {
357 Log.e(TAG, "Cannot call service method", e);
358 }
alision85992112013-05-29 12:18:08 -0400359
alision55c36cb2013-06-14 14:57:38 -0400360 }
alision85992112013-05-29 12:18:08 -0400361
alision55c36cb2013-06-14 14:57:38 -0400362 @Override
363 public void onCallRejected(SipCall call) {
364 try {
365 if (call.getCallStateInt() == state.CALL_STATE_RINGING) {
366 service.refuse(call.getCallId());
367 return;
368 }
369 } catch (RemoteException e) {
370 Log.e(TAG, "Cannot call service method", e);
371 }
372 }
alision85992112013-05-29 12:18:08 -0400373
alision55c36cb2013-06-14 14:57:38 -0400374 @Override
375 public void onCallEnded(SipCall call) {
376 try {
377 if (call.getCallStateInt() == state.CALL_STATE_NONE || call.getCallStateInt() == state.CALL_STATE_CURRENT
378 || call.getCallStateInt() == state.CALL_STATE_HOLD) {
379 service.hangUp(call.getCallId());
380 return;
alision85992112013-05-29 12:18:08 -0400381
alision55c36cb2013-06-14 14:57:38 -0400382 } else if (call.getCallStateInt() == state.CALL_STATE_RINGING) {
383 if (call.getCallType() == state.CALL_TYPE_INCOMING) {
384 service.refuse(call.getCallId());
385 return;
386 } else if (call.getCallType() == state.CALL_TYPE_OUTGOING) {
387 service.hangUp(call.getCallId());
388 return;
389 }
390 }
391 } catch (RemoteException e) {
392 Log.e(TAG, "Cannot call service method", e);
393 }
394 }
alision85992112013-05-29 12:18:08 -0400395
alision55c36cb2013-06-14 14:57:38 -0400396 @Override
397 public void onCallSuspended(SipCall call) {
398 try {
399 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
400 service.hold(call.getCallId());
401 return;
402 }
403 } catch (RemoteException e) {
404 Log.e(TAG, "Cannot call service method", e);
405 }
406 }
alision85992112013-05-29 12:18:08 -0400407
alision55c36cb2013-06-14 14:57:38 -0400408 @Override
409 public void onCallResumed(SipCall call) {
410 try {
411 if (call.getCallStateInt() == state.CALL_STATE_HOLD) {
412 service.unhold(call.getCallId());
413 return;
414 }
415 } catch (RemoteException e) {
416 Log.e(TAG, "Cannot call service method", e);
417 }
alision85992112013-05-29 12:18:08 -0400418
alision55c36cb2013-06-14 14:57:38 -0400419 }
alision85992112013-05-29 12:18:08 -0400420
alision55c36cb2013-06-14 14:57:38 -0400421 @Override
422 public void onCalltransfered(SipCall call, String to) {
423 try {
424 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
425 service.transfer(call.getCallId(), to);
426 }
427 } catch (RemoteException e) {
428 Log.e(TAG, "Cannot call service method", e);
429 }
alision85992112013-05-29 12:18:08 -0400430
alision55c36cb2013-06-14 14:57:38 -0400431 }
alision85992112013-05-29 12:18:08 -0400432
alision55c36cb2013-06-14 14:57:38 -0400433 @Override
434 public void onRecordCall(SipCall call) {
435 try {
alisiondf1dac92013-06-27 17:35:53 -0400436
Alexandre Lision1a9e3b12013-09-16 11:06:07 -0400437 // service.setRecordPath(Environment.getExternalStorageDirectory().getAbsolutePath() + File.separator);
Alexandre Lision2b237922013-09-09 16:23:02 -0400438 Log.w(TAG, "Recording path " + service.getRecordPath());
Alexandre Lisiona764c682013-09-09 10:02:07 -0400439 service.toggleRecordingCall(call.getCallId());
440
alision55c36cb2013-06-14 14:57:38 -0400441 } catch (RemoteException e) {
442 Log.e(TAG, "Cannot call service method", e);
443 }
alision85992112013-05-29 12:18:08 -0400444
alision55c36cb2013-06-14 14:57:38 -0400445 }
alision85992112013-05-29 12:18:08 -0400446
alision55c36cb2013-06-14 14:57:38 -0400447 @Override
448 public void onBackPressed() {
449 super.onBackPressed();
450 Intent launchHome = new Intent(this, SFLPhoneHomeActivity.class);
451 launchHome.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
452 startActivity(launchHome);
453 }
alision85992112013-05-29 12:18:08 -0400454
alision55c36cb2013-06-14 14:57:38 -0400455 @Override
456 public void onSendMessage(SipCall call, String msg) {
457 try {
458 if (call.getCallStateInt() == state.CALL_STATE_CURRENT) {
459 service.sendTextMessage(call.getCallId(), msg, "Me");
460 }
461 } catch (RemoteException e) {
462 Log.e(TAG, "Cannot call service method", e);
463 }
alisiond45da712013-05-30 09:18:49 -0400464
alision55c36cb2013-06-14 14:57:38 -0400465 }
alisiond45da712013-05-30 09:18:49 -0400466
alision806e18e2013-06-21 15:30:17 -0400467 @Override
468 public void confCreated(Intent intent) {
469 mCallsFragment.update();
alision34673e62013-06-25 14:40:07 -0400470
alision806e18e2013-06-21 15:30:17 -0400471 }
472
473 @Override
474 public void confRemoved(Intent intent) {
475 mCallsFragment.update();
476 }
477
478 @Override
479 public void confChanged(Intent intent) {
480 mCallsFragment.update();
481 }
482
483 @Override
484 public void onCallsTerminated() {
alisiondf1dac92013-06-27 17:35:53 -0400485
486 }
487
488 @Override
489 public void recordingChanged(Intent intent) {
490 mCallsFragment.update();
491 }
492
493 @Override
494 public void replaceCurrentCallDisplayed() {
495 mCurrentCallFragment.getBubbleView().stopThread();
496 getFragmentManager().beginTransaction().remove(mCurrentCallFragment).commit();
alision465ceba2013-07-04 09:24:30 -0400497 mCurrentCallFragment = null;
alision34673e62013-06-25 14:40:07 -0400498
alision806e18e2013-06-21 15:30:17 -0400499 }
500
Alexandre Lision0c384512013-09-17 17:15:57 -0400501 @Override
502 public void startTimer() {
503 mHandler.postDelayed(mUpdateTimeTask, 0);
504 }
505
Alexandre Savard14323be2012-10-24 10:02:13 -0400506}