2015-08-03 23:09:49 +02:00
|
|
|
package nodomain.freeyourgadget.gadgetbridge.service;
|
2015-01-12 00:35:15 +01:00
|
|
|
|
2015-02-06 13:55:44 +01:00
|
|
|
import android.app.NotificationManager;
|
2015-01-12 00:35:15 +01:00
|
|
|
import android.app.Service;
|
2015-04-19 14:34:18 +02:00
|
|
|
import android.content.BroadcastReceiver;
|
2015-01-23 11:32:58 +01:00
|
|
|
import android.content.ContentResolver;
|
2015-02-06 13:55:44 +01:00
|
|
|
import android.content.Context;
|
2015-01-12 00:35:15 +01:00
|
|
|
import android.content.Intent;
|
2015-04-19 14:34:18 +02:00
|
|
|
import android.content.IntentFilter;
|
2015-03-21 18:18:07 +01:00
|
|
|
import android.content.SharedPreferences;
|
2015-01-23 11:32:58 +01:00
|
|
|
import android.database.Cursor;
|
|
|
|
import android.net.Uri;
|
2015-01-12 00:35:15 +01:00
|
|
|
import android.os.IBinder;
|
2015-03-21 18:18:07 +01:00
|
|
|
import android.preference.PreferenceManager;
|
2015-01-23 11:32:58 +01:00
|
|
|
import android.provider.ContactsContract;
|
2015-08-23 00:54:28 +02:00
|
|
|
import android.support.annotation.Nullable;
|
2015-04-19 15:11:03 +02:00
|
|
|
import android.support.v4.content.LocalBroadcastManager;
|
2015-01-12 00:35:15 +01:00
|
|
|
import android.widget.Toast;
|
2015-04-19 15:27:16 +02:00
|
|
|
|
2015-05-12 06:28:11 +02:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
2015-06-25 14:34:21 +02:00
|
|
|
import java.util.ArrayList;
|
2015-12-14 23:31:31 +01:00
|
|
|
import java.util.Random;
|
2015-05-18 20:56:19 +02:00
|
|
|
import java.util.UUID;
|
|
|
|
|
2015-12-14 23:31:31 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
2015-08-04 01:01:14 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
2015-10-15 17:23:16 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.K9Receiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.MusicPlaybackReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.PebbleReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.PhoneCallReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.SMSReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.TimeChangeReceiver;
|
2015-08-03 23:09:49 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.model.Alarm;
|
2015-09-24 14:45:21 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.model.NotificationType;
|
2015-08-04 01:01:14 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.model.ServiceCommand;
|
2015-12-13 00:43:07 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.DeviceHelper;
|
2015-08-04 01:01:14 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
2015-08-23 00:54:28 +02:00
|
|
|
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_CALLSTATE;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_CONNECT;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DELETEAPP;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DISCONNECT;
|
2015-09-02 08:00:26 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_ENABLE_REALTIME_STEPS;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FETCH_ACTIVITY_DATA;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FIND_DEVICE;
|
2015-12-28 14:38:56 +01:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_HEARTRATE_TEST;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_INSTALL;
|
2015-09-24 14:45:21 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_NOTIFICATION;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REBOOT;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_APPINFO;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_DEVICEINFO;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_SCREENSHOT;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETMUSICINFO;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETTIME;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SET_ALARMS;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_START;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_STARTAPP;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_ALARMS;
|
2015-09-13 21:44:26 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_APP_START;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_APP_UUID;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_COMMAND;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_PHONENUMBER;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_DEVICE_ADDRESS;
|
2015-09-02 08:00:26 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_ENABLE_REALTIME_STEPS;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_FIND_START;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ALBUM;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ARTIST;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_TRACK;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_BODY;
|
2016-01-09 17:54:17 +01:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_FLAGS;
|
2015-09-24 14:45:21 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_ID;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_PHONENUMBER;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_SENDER;
|
2015-09-24 14:45:21 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_SOURCENAME;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_SUBJECT;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_TITLE;
|
2015-09-24 14:45:21 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_NOTIFICATION_TYPE;
|
2015-08-23 00:54:28 +02:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_PERFORM_PAIR;
|
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_URI;
|
2015-05-01 01:49:43 +02:00
|
|
|
|
2015-08-04 01:01:14 +02:00
|
|
|
public class DeviceCommunicationService extends Service {
|
|
|
|
private static final Logger LOG = LoggerFactory.getLogger(DeviceCommunicationService.class);
|
2015-02-06 13:55:44 +01:00
|
|
|
|
|
|
|
private boolean mStarted = false;
|
2015-03-22 23:38:51 +01:00
|
|
|
|
2015-08-23 00:54:28 +02:00
|
|
|
private DeviceSupportFactory mFactory;
|
2015-04-01 18:34:52 +02:00
|
|
|
private GBDevice mGBDevice = null;
|
2015-04-14 01:24:03 +02:00
|
|
|
private DeviceSupport mDeviceSupport;
|
2015-01-12 00:35:15 +01:00
|
|
|
|
2015-10-15 17:23:16 +02:00
|
|
|
private PhoneCallReceiver mPhoneCallReceiver = null;
|
|
|
|
private SMSReceiver mSMSReceiver = null;
|
|
|
|
private K9Receiver mK9Receiver = null;
|
|
|
|
private PebbleReceiver mPebbleReceiver = null;
|
|
|
|
private MusicPlaybackReceiver mMusicPlaybackReceiver = null;
|
|
|
|
private TimeChangeReceiver mTimeChangeReceiver = null;
|
|
|
|
|
2015-12-14 23:31:31 +01:00
|
|
|
private Random mRandom = new Random();
|
|
|
|
|
2015-11-23 23:04:46 +01:00
|
|
|
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
2015-04-19 14:34:18 +02:00
|
|
|
@Override
|
|
|
|
public void onReceive(Context context, Intent intent) {
|
|
|
|
String action = intent.getAction();
|
|
|
|
if (action.equals(GBDevice.ACTION_DEVICE_CHANGED)) {
|
2015-07-10 21:35:28 +02:00
|
|
|
GBDevice device = intent.getParcelableExtra(GBDevice.EXTRA_DEVICE);
|
2015-04-20 11:58:59 +02:00
|
|
|
if (mGBDevice.equals(device)) {
|
|
|
|
mGBDevice = device;
|
2015-08-07 13:24:54 +02:00
|
|
|
boolean enableReceivers = mDeviceSupport != null && (mDeviceSupport.useAutoConnect() || mGBDevice.isInitialized());
|
2015-10-15 17:23:16 +02:00
|
|
|
setReceiversEnableState(enableReceivers);
|
2015-04-27 21:18:51 +02:00
|
|
|
GB.updateNotification(mGBDevice.getName() + " " + mGBDevice.getStateString(), context);
|
2015-07-10 21:35:28 +02:00
|
|
|
} else {
|
|
|
|
LOG.error("Got ACTION_DEVICE_CHANGED from unexpected device: " + mGBDevice);
|
2015-04-19 14:34:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2015-04-19 15:27:16 +02:00
|
|
|
|
2015-01-12 00:35:15 +01:00
|
|
|
@Override
|
|
|
|
public void onCreate() {
|
2015-08-04 01:01:14 +02:00
|
|
|
LOG.debug("DeviceCommunicationService is being created");
|
2015-01-12 00:35:15 +01:00
|
|
|
super.onCreate();
|
2015-04-19 15:11:03 +02:00
|
|
|
LocalBroadcastManager.getInstance(this).registerReceiver(mReceiver, new IntentFilter(GBDevice.ACTION_DEVICE_CHANGED));
|
2015-08-23 00:54:28 +02:00
|
|
|
mFactory = new DeviceSupportFactory(this);
|
2015-01-12 00:35:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-10-22 00:52:45 +02:00
|
|
|
public synchronized int onStartCommand(Intent intent, int flags, int startId) {
|
2015-01-26 18:52:19 +01:00
|
|
|
|
2015-04-03 22:39:25 +02:00
|
|
|
if (intent == null) {
|
2015-05-12 06:28:11 +02:00
|
|
|
LOG.info("no intent");
|
2015-04-03 22:39:25 +02:00
|
|
|
return START_NOT_STICKY;
|
|
|
|
}
|
|
|
|
|
2015-02-06 13:55:44 +01:00
|
|
|
String action = intent.getAction();
|
2015-05-05 00:48:02 +02:00
|
|
|
boolean pair = intent.getBooleanExtra(EXTRA_PERFORM_PAIR, false);
|
2015-04-03 22:39:25 +02:00
|
|
|
|
2015-03-17 21:41:58 +01:00
|
|
|
if (action == null) {
|
2015-05-12 06:28:11 +02:00
|
|
|
LOG.info("no action");
|
2015-03-17 21:41:58 +01:00
|
|
|
return START_NOT_STICKY;
|
|
|
|
}
|
2015-01-12 00:35:15 +01:00
|
|
|
|
2015-05-12 06:28:11 +02:00
|
|
|
LOG.debug("Service startcommand: " + action);
|
2015-04-22 20:37:07 +02:00
|
|
|
|
2015-04-19 02:37:29 +02:00
|
|
|
if (!action.equals(ACTION_START) && !action.equals(ACTION_CONNECT)) {
|
2015-08-06 23:17:41 +02:00
|
|
|
if (!mStarted) {
|
|
|
|
// using the service before issuing ACTION_START
|
|
|
|
LOG.info("Must start service with " + ACTION_START + " or " + ACTION_CONNECT + " before using it: " + action);
|
|
|
|
return START_NOT_STICKY;
|
|
|
|
}
|
|
|
|
|
2015-08-07 22:07:48 +02:00
|
|
|
if (mDeviceSupport == null || (!isInitialized() && !mDeviceSupport.useAutoConnect())) {
|
2015-04-19 02:37:29 +02:00
|
|
|
// trying to send notification without valid Bluetooth connection
|
2015-04-24 23:08:47 +02:00
|
|
|
if (mGBDevice != null) {
|
|
|
|
// at least send back the current device state
|
|
|
|
mGBDevice.sendDeviceUpdateIntent(this);
|
|
|
|
}
|
2015-04-19 02:37:29 +02:00
|
|
|
return START_STICKY;
|
|
|
|
}
|
2015-02-06 13:55:44 +01:00
|
|
|
}
|
2015-01-12 00:35:15 +01:00
|
|
|
|
2015-08-14 00:23:01 +02:00
|
|
|
// when we get past this, we should have valid mDeviceSupport and mGBDevice instances
|
2015-08-06 23:17:41 +02:00
|
|
|
|
2015-05-08 11:18:06 +02:00
|
|
|
switch (action) {
|
2015-08-06 23:17:41 +02:00
|
|
|
case ACTION_START:
|
|
|
|
start();
|
|
|
|
break;
|
2015-05-08 11:18:06 +02:00
|
|
|
case ACTION_CONNECT:
|
2015-08-06 23:17:41 +02:00
|
|
|
start(); // ensure started
|
2015-12-13 00:43:07 +01:00
|
|
|
GBDevice gbDevice = intent.getParcelableExtra(GBDevice.EXTRA_DEVICE);
|
|
|
|
if (gbDevice == null) {
|
|
|
|
String btDeviceAddress = intent.getStringExtra(EXTRA_DEVICE_ADDRESS);
|
|
|
|
SharedPreferences sharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
|
|
|
|
if (sharedPrefs != null) { // may be null in test cases
|
|
|
|
if (btDeviceAddress == null) {
|
|
|
|
btDeviceAddress = sharedPrefs.getString("last_device_address", null);
|
|
|
|
} else {
|
|
|
|
sharedPrefs.edit().putString("last_device_address", btDeviceAddress).apply();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (btDeviceAddress != null) {
|
|
|
|
gbDevice = DeviceHelper.getInstance().findAvailableDevice(btDeviceAddress, this);
|
2015-08-22 01:08:46 +02:00
|
|
|
}
|
2015-08-06 02:17:38 +02:00
|
|
|
}
|
2015-05-08 11:18:06 +02:00
|
|
|
|
2015-12-13 00:43:07 +01:00
|
|
|
if (gbDevice != null && !isConnecting() && !isConnected()) {
|
2015-08-23 00:54:28 +02:00
|
|
|
setDeviceSupport(null);
|
2015-08-04 01:01:14 +02:00
|
|
|
try {
|
2015-12-13 00:43:07 +01:00
|
|
|
DeviceSupport deviceSupport = mFactory.createDeviceSupport(gbDevice);
|
2015-08-23 00:54:28 +02:00
|
|
|
if (deviceSupport != null) {
|
|
|
|
setDeviceSupport(deviceSupport);
|
2015-08-04 01:01:14 +02:00
|
|
|
if (pair) {
|
2015-08-23 00:54:28 +02:00
|
|
|
deviceSupport.pair();
|
2015-08-04 01:01:14 +02:00
|
|
|
} else {
|
2015-08-23 00:54:28 +02:00
|
|
|
deviceSupport.connect();
|
2015-04-14 01:24:03 +02:00
|
|
|
}
|
2015-10-18 08:34:51 +02:00
|
|
|
} else {
|
|
|
|
GB.toast(this, getString(R.string.cannot_connect, "Can't create device support"), Toast.LENGTH_SHORT, GB.ERROR);
|
2015-04-01 18:34:52 +02:00
|
|
|
}
|
2015-08-04 01:01:14 +02:00
|
|
|
} catch (Exception e) {
|
2015-10-18 23:43:27 +02:00
|
|
|
GB.toast(this, getString(R.string.cannot_connect, e.getMessage()), Toast.LENGTH_SHORT, GB.ERROR, e);
|
2015-08-23 00:54:28 +02:00
|
|
|
setDeviceSupport(null);
|
2015-01-12 00:35:15 +01:00
|
|
|
}
|
2015-08-14 23:37:47 +02:00
|
|
|
} else if (mGBDevice != null) {
|
|
|
|
// send an update at least
|
|
|
|
mGBDevice.sendDeviceUpdateIntent(this);
|
2015-01-12 00:35:15 +01:00
|
|
|
}
|
2015-05-08 11:18:06 +02:00
|
|
|
break;
|
2015-08-14 23:37:47 +02:00
|
|
|
case ACTION_REQUEST_DEVICEINFO:
|
2015-08-14 00:29:05 +02:00
|
|
|
mGBDevice.sendDeviceUpdateIntent(this);
|
2015-08-06 23:17:41 +02:00
|
|
|
break;
|
2015-09-24 14:45:21 +02:00
|
|
|
case ACTION_NOTIFICATION: {
|
|
|
|
NotificationSpec notificationSpec = new NotificationSpec();
|
|
|
|
notificationSpec.phoneNumber = intent.getStringExtra(EXTRA_NOTIFICATION_PHONENUMBER);
|
|
|
|
notificationSpec.sender = intent.getStringExtra(EXTRA_NOTIFICATION_SENDER);
|
|
|
|
notificationSpec.subject = intent.getStringExtra(EXTRA_NOTIFICATION_SUBJECT);
|
|
|
|
notificationSpec.title = intent.getStringExtra(EXTRA_NOTIFICATION_TITLE);
|
|
|
|
notificationSpec.body = intent.getStringExtra(EXTRA_NOTIFICATION_BODY);
|
|
|
|
notificationSpec.type = (NotificationType) intent.getSerializableExtra(EXTRA_NOTIFICATION_TYPE);
|
|
|
|
notificationSpec.id = intent.getIntExtra(EXTRA_NOTIFICATION_ID, -1);
|
2016-01-09 17:54:17 +01:00
|
|
|
notificationSpec.flags = intent.getIntExtra(EXTRA_NOTIFICATION_FLAGS, 0);
|
2015-09-24 14:45:21 +02:00
|
|
|
notificationSpec.sourceName = intent.getStringExtra(EXTRA_NOTIFICATION_SOURCENAME);
|
|
|
|
if (notificationSpec.type == NotificationType.SMS && notificationSpec.phoneNumber != null) {
|
|
|
|
notificationSpec.sender = getContactDisplayNameByNumber(notificationSpec.phoneNumber);
|
2015-12-13 12:03:57 +01:00
|
|
|
|
2015-12-14 23:31:31 +01:00
|
|
|
notificationSpec.id = mRandom.nextInt(); // FIXME: add this in external SMS Receiver?
|
|
|
|
GBApplication.getIDSenderLookup().add(notificationSpec.id, notificationSpec.phoneNumber);
|
2016-01-09 17:54:17 +01:00
|
|
|
}
|
|
|
|
if (((notificationSpec.flags & NotificationSpec.FLAG_WEARABLE_REPLY) > 0)
|
|
|
|
|| (notificationSpec.type == NotificationType.SMS && notificationSpec.phoneNumber != null)) {
|
2015-12-13 12:03:57 +01:00
|
|
|
// NOTE: maybe not where it belongs
|
|
|
|
SharedPreferences sharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
|
|
|
|
if (sharedPrefs.getBoolean("pebble_force_untested", false)) {
|
|
|
|
// I would rather like to save that as an array in ShadredPreferences
|
|
|
|
// this would work but I dont know how to do the same in the Settings Activity's xml
|
|
|
|
ArrayList<String> replies = new ArrayList<>();
|
2015-12-17 00:05:42 +01:00
|
|
|
for (int i = 1; i <= 16; i++) {
|
2015-12-13 12:03:57 +01:00
|
|
|
String reply = sharedPrefs.getString("canned_reply_" + i, null);
|
|
|
|
if (reply != null && !reply.equals("")) {
|
|
|
|
replies.add(reply);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
notificationSpec.cannedReplies = replies.toArray(new String[replies.size()]);
|
|
|
|
}
|
2015-09-24 14:45:21 +02:00
|
|
|
}
|
|
|
|
mDeviceSupport.onNotification(notificationSpec);
|
2015-05-08 11:18:06 +02:00
|
|
|
break;
|
2015-04-06 20:58:35 +02:00
|
|
|
}
|
2015-05-17 21:58:08 +02:00
|
|
|
case ACTION_REBOOT: {
|
|
|
|
mDeviceSupport.onReboot();
|
|
|
|
break;
|
|
|
|
}
|
2015-12-28 14:38:56 +01:00
|
|
|
case ACTION_HEARTRATE_TEST: {
|
|
|
|
mDeviceSupport.onHearRateTest();
|
|
|
|
break;
|
|
|
|
}
|
2015-06-06 19:39:04 +02:00
|
|
|
case ACTION_FETCH_ACTIVITY_DATA: {
|
|
|
|
mDeviceSupport.onFetchActivityData();
|
|
|
|
break;
|
|
|
|
}
|
2015-06-07 15:31:42 +02:00
|
|
|
case ACTION_DISCONNECT: {
|
|
|
|
mDeviceSupport.dispose();
|
|
|
|
mDeviceSupport = null;
|
|
|
|
break;
|
|
|
|
}
|
2015-06-21 00:34:05 +02:00
|
|
|
case ACTION_FIND_DEVICE: {
|
2015-08-21 00:58:18 +02:00
|
|
|
boolean start = intent.getBooleanExtra(EXTRA_FIND_START, false);
|
2015-06-21 00:34:05 +02:00
|
|
|
mDeviceSupport.onFindDevice(start);
|
|
|
|
break;
|
|
|
|
}
|
2015-05-08 11:18:06 +02:00
|
|
|
case ACTION_CALLSTATE:
|
2015-08-21 00:58:18 +02:00
|
|
|
ServiceCommand command = (ServiceCommand) intent.getSerializableExtra(EXTRA_CALL_COMMAND);
|
2015-05-08 11:18:06 +02:00
|
|
|
|
2015-08-21 00:58:18 +02:00
|
|
|
String phoneNumber = intent.getStringExtra(EXTRA_CALL_PHONENUMBER);
|
2015-05-08 11:18:06 +02:00
|
|
|
String callerName = null;
|
|
|
|
if (phoneNumber != null) {
|
|
|
|
callerName = getContactDisplayNameByNumber(phoneNumber);
|
|
|
|
}
|
|
|
|
mDeviceSupport.onSetCallState(phoneNumber, callerName, command);
|
|
|
|
break;
|
|
|
|
case ACTION_SETTIME:
|
2015-08-21 00:58:18 +02:00
|
|
|
mDeviceSupport.onSetTime();
|
2015-05-08 11:18:06 +02:00
|
|
|
break;
|
|
|
|
case ACTION_SETMUSICINFO:
|
2015-08-21 00:58:18 +02:00
|
|
|
String artist = intent.getStringExtra(EXTRA_MUSIC_ARTIST);
|
|
|
|
String album = intent.getStringExtra(EXTRA_MUSIC_ALBUM);
|
|
|
|
String track = intent.getStringExtra(EXTRA_MUSIC_TRACK);
|
2015-05-08 11:18:06 +02:00
|
|
|
mDeviceSupport.onSetMusicInfo(artist, album, track);
|
|
|
|
break;
|
|
|
|
case ACTION_REQUEST_APPINFO:
|
|
|
|
mDeviceSupport.onAppInfoReq();
|
|
|
|
break;
|
2015-06-24 00:23:38 +02:00
|
|
|
case ACTION_REQUEST_SCREENSHOT:
|
|
|
|
mDeviceSupport.onScreenshotReq();
|
|
|
|
break;
|
2015-08-21 00:58:18 +02:00
|
|
|
case ACTION_STARTAPP: {
|
|
|
|
UUID uuid = (UUID) intent.getSerializableExtra(EXTRA_APP_UUID);
|
2015-09-13 21:44:26 +02:00
|
|
|
boolean start = intent.getBooleanExtra(EXTRA_APP_START, true);
|
|
|
|
mDeviceSupport.onAppStart(uuid, start);
|
2015-05-18 22:20:01 +02:00
|
|
|
break;
|
2015-08-21 00:58:18 +02:00
|
|
|
}
|
|
|
|
case ACTION_DELETEAPP: {
|
|
|
|
UUID uuid = (UUID) intent.getSerializableExtra(EXTRA_APP_UUID);
|
2015-05-18 20:56:19 +02:00
|
|
|
mDeviceSupport.onAppDelete(uuid);
|
2015-05-08 11:18:06 +02:00
|
|
|
break;
|
2015-08-21 00:58:18 +02:00
|
|
|
}
|
2015-07-23 12:09:01 +02:00
|
|
|
case ACTION_INSTALL:
|
2015-08-21 00:58:18 +02:00
|
|
|
Uri uri = intent.getParcelableExtra(EXTRA_URI);
|
2015-08-06 02:17:38 +02:00
|
|
|
if (uri != null) {
|
2015-07-23 12:09:01 +02:00
|
|
|
LOG.info("will try to install app/fw");
|
2015-08-06 02:17:38 +02:00
|
|
|
mDeviceSupport.onInstallApp(uri);
|
2015-05-08 11:18:06 +02:00
|
|
|
}
|
|
|
|
break;
|
2015-06-24 20:14:08 +02:00
|
|
|
case ACTION_SET_ALARMS:
|
2015-08-21 00:58:18 +02:00
|
|
|
ArrayList<Alarm> alarms = intent.getParcelableArrayListExtra(EXTRA_ALARMS);
|
2015-06-25 14:34:21 +02:00
|
|
|
mDeviceSupport.onSetAlarms(alarms);
|
2015-06-25 12:42:47 +02:00
|
|
|
break;
|
2015-09-02 08:00:26 +02:00
|
|
|
case ACTION_ENABLE_REALTIME_STEPS:
|
|
|
|
boolean enable = intent.getBooleanExtra(EXTRA_ENABLE_REALTIME_STEPS, false);
|
|
|
|
mDeviceSupport.onEnableRealtimeSteps(enable);
|
|
|
|
break;
|
2015-01-12 00:35:15 +01:00
|
|
|
}
|
2015-02-06 13:55:44 +01:00
|
|
|
|
2015-01-12 00:35:15 +01:00
|
|
|
return START_STICKY;
|
|
|
|
}
|
|
|
|
|
2015-08-23 00:54:28 +02:00
|
|
|
/**
|
|
|
|
* For testing!
|
2015-09-13 21:44:26 +02:00
|
|
|
*
|
2015-08-23 00:54:28 +02:00
|
|
|
* @param factory
|
|
|
|
*/
|
|
|
|
public void setDeviceSupportFactory(DeviceSupportFactory factory) {
|
|
|
|
mFactory = factory;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disposes the current DeviceSupport instance (if any) and sets a new device support instance
|
|
|
|
* (if not null).
|
2015-09-13 21:44:26 +02:00
|
|
|
*
|
2015-08-23 00:54:28 +02:00
|
|
|
* @param deviceSupport
|
|
|
|
*/
|
|
|
|
private void setDeviceSupport(@Nullable DeviceSupport deviceSupport) {
|
|
|
|
if (deviceSupport != mDeviceSupport && mDeviceSupport != null) {
|
|
|
|
mDeviceSupport.dispose();
|
|
|
|
mDeviceSupport = null;
|
|
|
|
mGBDevice = null;
|
|
|
|
}
|
|
|
|
mDeviceSupport = deviceSupport;
|
|
|
|
mGBDevice = mDeviceSupport != null ? mDeviceSupport.getDevice() : null;
|
|
|
|
}
|
|
|
|
|
2015-08-06 23:17:41 +02:00
|
|
|
private void start() {
|
|
|
|
if (!mStarted) {
|
|
|
|
startForeground(GB.NOTIFICATION_ID, GB.createNotification(getString(R.string.gadgetbridge_running), this));
|
|
|
|
mStarted = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-23 00:54:28 +02:00
|
|
|
public boolean isStarted() {
|
|
|
|
return mStarted;
|
|
|
|
}
|
|
|
|
|
2015-04-13 01:01:52 +02:00
|
|
|
private boolean isConnected() {
|
2015-08-07 13:24:54 +02:00
|
|
|
return mGBDevice != null && mGBDevice.isConnected();
|
2015-04-13 11:22:03 +02:00
|
|
|
}
|
2015-04-13 01:01:52 +02:00
|
|
|
|
2015-04-13 13:26:22 +02:00
|
|
|
private boolean isConnecting() {
|
2015-08-07 13:24:54 +02:00
|
|
|
return mGBDevice != null && mGBDevice.isConnecting();
|
|
|
|
}
|
|
|
|
|
|
|
|
private boolean isInitialized() {
|
|
|
|
return mGBDevice != null && mGBDevice.isInitialized();
|
2015-04-13 13:26:22 +02:00
|
|
|
}
|
|
|
|
|
2015-10-15 17:23:16 +02:00
|
|
|
|
|
|
|
private void setReceiversEnableState(boolean enable) {
|
|
|
|
LOG.info("Setting broadcast receivers to: " + enable);
|
|
|
|
|
|
|
|
if (enable) {
|
|
|
|
if (mPhoneCallReceiver == null) {
|
|
|
|
mPhoneCallReceiver = new PhoneCallReceiver();
|
|
|
|
IntentFilter filter = new IntentFilter();
|
|
|
|
filter.addAction("android.intent.action.PHONE_STATE");
|
|
|
|
filter.addAction("android.intent.action.NEW_OUTGOING_CALL");
|
|
|
|
registerReceiver(mPhoneCallReceiver, filter);
|
|
|
|
}
|
|
|
|
if (mSMSReceiver == null) {
|
|
|
|
mSMSReceiver = new SMSReceiver();
|
|
|
|
registerReceiver(mSMSReceiver, new IntentFilter("android.provider.Telephony.SMS_RECEIVED"));
|
|
|
|
}
|
|
|
|
if (mK9Receiver == null) {
|
|
|
|
mK9Receiver = new K9Receiver();
|
|
|
|
IntentFilter filter = new IntentFilter();
|
|
|
|
filter.addDataScheme("email");
|
|
|
|
filter.addAction("com.fsck.k9.intent.action.EMAIL_RECEIVED");
|
|
|
|
registerReceiver(mK9Receiver, filter);
|
|
|
|
}
|
|
|
|
if (mPebbleReceiver == null) {
|
|
|
|
mPebbleReceiver = new PebbleReceiver();
|
|
|
|
registerReceiver(mPebbleReceiver, new IntentFilter("com.getpebble.action.SEND_NOTIFICATION"));
|
|
|
|
}
|
|
|
|
if (mMusicPlaybackReceiver == null) {
|
|
|
|
mMusicPlaybackReceiver = new MusicPlaybackReceiver();
|
|
|
|
registerReceiver(mMusicPlaybackReceiver, new IntentFilter("com.android.music.metachanged"));
|
|
|
|
}
|
|
|
|
if (mTimeChangeReceiver == null) {
|
|
|
|
mTimeChangeReceiver = new TimeChangeReceiver();
|
|
|
|
IntentFilter filter = new IntentFilter();
|
|
|
|
filter.addAction("android.intent.action.TIME_SET");
|
|
|
|
filter.addAction("android.intent.action.TIMEZONE_CHANGED");
|
|
|
|
registerReceiver(mTimeChangeReceiver, filter);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (mPhoneCallReceiver != null) {
|
|
|
|
unregisterReceiver(mPhoneCallReceiver);
|
|
|
|
mPhoneCallReceiver = null;
|
|
|
|
}
|
|
|
|
if (mSMSReceiver != null) {
|
|
|
|
unregisterReceiver(mSMSReceiver);
|
|
|
|
mSMSReceiver = null;
|
|
|
|
}
|
|
|
|
if (mK9Receiver != null) {
|
|
|
|
unregisterReceiver(mK9Receiver);
|
|
|
|
mK9Receiver = null;
|
|
|
|
}
|
|
|
|
if (mPebbleReceiver != null) {
|
|
|
|
unregisterReceiver(mPebbleReceiver);
|
|
|
|
mPebbleReceiver = null;
|
|
|
|
}
|
|
|
|
if (mMusicPlaybackReceiver != null) {
|
|
|
|
unregisterReceiver(mMusicPlaybackReceiver);
|
|
|
|
mMusicPlaybackReceiver = null;
|
|
|
|
}
|
|
|
|
if (mTimeChangeReceiver != null) {
|
|
|
|
unregisterReceiver(mTimeChangeReceiver);
|
|
|
|
mTimeChangeReceiver = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-13 11:22:03 +02:00
|
|
|
@Override
|
2015-01-12 00:35:15 +01:00
|
|
|
public void onDestroy() {
|
2015-08-04 01:01:14 +02:00
|
|
|
LOG.debug("DeviceCommunicationService is being destroyed");
|
2015-01-12 00:35:15 +01:00
|
|
|
super.onDestroy();
|
2015-02-02 21:16:42 +01:00
|
|
|
|
2015-04-19 15:11:03 +02:00
|
|
|
LocalBroadcastManager.getInstance(this).unregisterReceiver(mReceiver);
|
2015-10-15 17:23:16 +02:00
|
|
|
setReceiversEnableState(false); // disable BroadcastReceivers
|
2015-02-02 21:16:42 +01:00
|
|
|
|
2015-08-23 00:54:28 +02:00
|
|
|
setDeviceSupport(null);
|
2015-02-06 13:55:44 +01:00
|
|
|
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
|
2015-04-13 01:01:52 +02:00
|
|
|
nm.cancel(GB.NOTIFICATION_ID); // need to do this because the updated notification wont be cancelled when service stops
|
2015-01-12 00:35:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public IBinder onBind(Intent intent) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2015-01-23 11:32:58 +01:00
|
|
|
|
|
|
|
private String getContactDisplayNameByNumber(String number) {
|
|
|
|
Uri uri = Uri.withAppendedPath(ContactsContract.PhoneLookup.CONTENT_FILTER_URI, Uri.encode(number));
|
2015-01-31 11:49:46 +01:00
|
|
|
String name = number;
|
2015-01-23 11:32:58 +01:00
|
|
|
|
|
|
|
if (number == null || number.equals("")) {
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
|
|
|
ContentResolver contentResolver = getContentResolver();
|
2015-12-06 15:29:57 +01:00
|
|
|
|
|
|
|
Cursor contactLookup = null;
|
|
|
|
try {
|
2015-12-06 15:39:34 +01:00
|
|
|
contactLookup = contentResolver.query(uri, null, null, null, null);
|
2015-12-06 15:29:57 +01:00
|
|
|
} catch (SecurityException e) {
|
|
|
|
return name;
|
|
|
|
}
|
2015-01-23 11:32:58 +01:00
|
|
|
|
|
|
|
try {
|
|
|
|
if (contactLookup != null && contactLookup.getCount() > 0) {
|
|
|
|
contactLookup.moveToNext();
|
|
|
|
name = contactLookup.getString(contactLookup.getColumnIndex(ContactsContract.Data.DISPLAY_NAME));
|
|
|
|
}
|
|
|
|
} finally {
|
|
|
|
if (contactLookup != null) {
|
|
|
|
contactLookup.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return name;
|
|
|
|
}
|
2015-01-30 11:59:36 +01:00
|
|
|
}
|