2020-01-09 10:44:32 +01:00
|
|
|
/* Copyright (C) 2015-2020 Andreas Böhler, Andreas Shimokawa, Carsten
|
2019-11-23 21:52:46 +01:00
|
|
|
Pfeiffer, Daniele Gobbetti, José Rebelo, Sebastian Kranz, Taavi Eomäe
|
2017-03-10 14:53:19 +01:00
|
|
|
|
|
|
|
This file is part of Gadgetbridge.
|
|
|
|
|
|
|
|
Gadgetbridge is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Gadgetbridge is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
2015-08-03 23:09:49 +02:00
|
|
|
package nodomain.freeyourgadget.gadgetbridge.service;
|
2015-04-14 01:24:03 +02:00
|
|
|
|
2015-06-26 23:17:31 +02:00
|
|
|
import android.app.Notification;
|
|
|
|
import android.app.NotificationManager;
|
2015-06-27 00:21:30 +02:00
|
|
|
import android.app.PendingIntent;
|
2015-04-14 01:24:03 +02:00
|
|
|
import android.bluetooth.BluetoothAdapter;
|
|
|
|
import android.content.Context;
|
2015-05-23 00:54:14 +02:00
|
|
|
import android.content.Intent;
|
2015-06-26 23:17:31 +02:00
|
|
|
import android.graphics.Bitmap;
|
|
|
|
import android.graphics.BitmapFactory;
|
2015-06-27 00:21:30 +02:00
|
|
|
import android.net.Uri;
|
2015-12-15 00:26:06 +01:00
|
|
|
import android.telephony.SmsManager;
|
2015-05-23 00:54:14 +02:00
|
|
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
2015-06-27 00:21:30 +02:00
|
|
|
import java.io.File;
|
2015-10-28 23:54:08 +01:00
|
|
|
import java.io.IOException;
|
2015-08-18 17:37:51 +02:00
|
|
|
import java.text.DateFormat;
|
2015-06-25 23:34:50 +02:00
|
|
|
import java.text.SimpleDateFormat;
|
|
|
|
import java.util.Date;
|
2017-03-10 23:10:40 +01:00
|
|
|
import java.util.Locale;
|
2016-01-11 15:29:12 +01:00
|
|
|
import java.util.Objects;
|
2015-06-25 23:34:50 +02:00
|
|
|
|
2019-01-26 15:52:40 +01:00
|
|
|
import androidx.core.app.NotificationCompat;
|
|
|
|
import androidx.core.content.FileProvider;
|
|
|
|
import androidx.localbroadcastmanager.content.LocalBroadcastManager;
|
2015-12-14 23:31:31 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
2015-08-31 17:25:58 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
2018-01-19 23:10:08 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.activities.FindPhoneActivity;
|
2016-06-14 15:56:38 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.activities.appmanager.AbstractAppManagerFragment;
|
2015-08-17 02:22:16 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.activities.charts.ChartsHost;
|
2015-06-23 11:54:33 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEvent;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventAppInfo;
|
2015-08-31 17:25:58 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventBatteryInfo;
|
2015-06-23 11:54:33 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventCallControl;
|
2016-04-03 00:50:45 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventDisplayMessage;
|
2018-01-19 23:10:08 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventFindPhone;
|
2018-10-31 21:47:12 +01:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventFmFrequency;
|
2018-07-28 17:23:58 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventLEDColor;
|
2015-06-23 11:54:33 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventMusicControl;
|
2015-08-31 22:27:25 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventNotificationControl;
|
2015-06-24 23:55:51 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventScreenshot;
|
2015-06-23 11:54:33 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventVersionInfo;
|
2015-07-21 01:25:22 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.externalevents.NotificationListener;
|
2015-08-31 17:25:58 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.model.BatteryState;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.service.receivers.GBCallControlReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.service.receivers.GBMusicControlReceiver;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
2016-04-25 23:39:03 +02:00
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
|
2015-04-14 01:24:03 +02:00
|
|
|
|
2018-02-14 21:27:24 +01:00
|
|
|
import static nodomain.freeyourgadget.gadgetbridge.util.GB.NOTIFICATION_CHANNEL_ID;
|
|
|
|
|
2015-04-19 02:37:29 +02:00
|
|
|
// TODO: support option for a single reminder notification when notifications could not be delivered?
|
|
|
|
// conditions: app was running and received notifications, but device was not connected.
|
|
|
|
// maybe need to check for "unread notifications" on device for that.
|
2015-08-02 00:12:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Abstract implementation of DeviceSupport with some implementations for
|
|
|
|
* common functionality. Still transport independent.
|
|
|
|
*/
|
2015-04-14 01:24:03 +02:00
|
|
|
public abstract class AbstractDeviceSupport implements DeviceSupport {
|
2015-05-23 00:54:14 +02:00
|
|
|
private static final Logger LOG = LoggerFactory.getLogger(AbstractDeviceSupport.class);
|
2015-06-26 23:17:31 +02:00
|
|
|
private static final int NOTIFICATION_ID_SCREENSHOT = 8000;
|
2015-05-23 00:54:14 +02:00
|
|
|
|
2015-05-22 20:20:33 +02:00
|
|
|
protected GBDevice gbDevice;
|
2015-04-14 01:24:03 +02:00
|
|
|
private BluetoothAdapter btAdapter;
|
|
|
|
private Context context;
|
2016-04-28 23:17:13 +02:00
|
|
|
private boolean autoReconnect;
|
2015-04-14 01:24:03 +02:00
|
|
|
|
2016-09-10 10:52:02 +02:00
|
|
|
@Override
|
2015-08-02 00:12:21 +02:00
|
|
|
public void setContext(GBDevice gbDevice, BluetoothAdapter btAdapter, Context context) {
|
2015-04-14 01:24:03 +02:00
|
|
|
this.gbDevice = gbDevice;
|
|
|
|
this.btAdapter = btAdapter;
|
|
|
|
this.context = context;
|
|
|
|
}
|
2015-04-14 10:29:09 +02:00
|
|
|
|
2017-04-12 21:33:19 +02:00
|
|
|
/**
|
|
|
|
* Default implementation just calls #connect()
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public boolean connectFirstTime() {
|
|
|
|
return connect();
|
|
|
|
}
|
|
|
|
|
2015-04-19 02:37:29 +02:00
|
|
|
@Override
|
|
|
|
public boolean isConnected() {
|
|
|
|
return gbDevice.isConnected();
|
|
|
|
}
|
2015-04-19 11:28:03 +02:00
|
|
|
|
2015-08-02 00:12:21 +02:00
|
|
|
/**
|
|
|
|
* Returns true if the device is not only connected, but also
|
|
|
|
* initialized.
|
2015-08-31 17:25:58 +02:00
|
|
|
*
|
2015-08-02 00:12:21 +02:00
|
|
|
* @see GBDevice#isInitialized()
|
|
|
|
*/
|
2015-04-19 02:37:29 +02:00
|
|
|
protected boolean isInitialized() {
|
|
|
|
return gbDevice.isInitialized();
|
|
|
|
}
|
2015-04-19 11:28:03 +02:00
|
|
|
|
2016-04-28 23:17:13 +02:00
|
|
|
@Override
|
|
|
|
public void setAutoReconnect(boolean enable) {
|
|
|
|
autoReconnect = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean getAutoReconnect() {
|
|
|
|
return autoReconnect;
|
|
|
|
}
|
|
|
|
|
2015-04-14 01:24:03 +02:00
|
|
|
@Override
|
|
|
|
public GBDevice getDevice() {
|
|
|
|
return gbDevice;
|
|
|
|
}
|
2015-04-14 10:29:09 +02:00
|
|
|
|
2015-04-14 01:24:03 +02:00
|
|
|
@Override
|
|
|
|
public BluetoothAdapter getBluetoothAdapter() {
|
|
|
|
return btAdapter;
|
|
|
|
}
|
2015-04-14 10:29:09 +02:00
|
|
|
|
2015-04-14 01:24:03 +02:00
|
|
|
@Override
|
|
|
|
public Context getContext() {
|
|
|
|
return context;
|
|
|
|
}
|
2015-05-23 00:54:14 +02:00
|
|
|
|
2015-06-23 11:54:33 +02:00
|
|
|
public void evaluateGBDeviceEvent(GBDeviceEvent deviceEvent) {
|
2015-08-31 17:25:58 +02:00
|
|
|
if (deviceEvent instanceof GBDeviceEventMusicControl) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventMusicControl) deviceEvent);
|
|
|
|
} else if (deviceEvent instanceof GBDeviceEventCallControl) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventCallControl) deviceEvent);
|
|
|
|
} else if (deviceEvent instanceof GBDeviceEventVersionInfo) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventVersionInfo) deviceEvent);
|
|
|
|
} else if (deviceEvent instanceof GBDeviceEventAppInfo) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventAppInfo) deviceEvent);
|
|
|
|
} else if (deviceEvent instanceof GBDeviceEventScreenshot) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventScreenshot) deviceEvent);
|
2015-08-31 22:27:25 +02:00
|
|
|
} else if (deviceEvent instanceof GBDeviceEventNotificationControl) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventNotificationControl) deviceEvent);
|
2015-08-31 17:25:58 +02:00
|
|
|
} else if (deviceEvent instanceof GBDeviceEventBatteryInfo) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventBatteryInfo) deviceEvent);
|
2018-01-19 23:10:08 +01:00
|
|
|
} else if (deviceEvent instanceof GBDeviceEventFindPhone) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventFindPhone) deviceEvent);
|
2018-07-28 17:23:58 +02:00
|
|
|
} else if (deviceEvent instanceof GBDeviceEventLEDColor) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventLEDColor) deviceEvent);
|
|
|
|
} else if (deviceEvent instanceof GBDeviceEventFmFrequency) {
|
|
|
|
handleGBDeviceEvent((GBDeviceEventFmFrequency) deviceEvent);
|
2018-01-19 23:10:08 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void handleGBDeviceEvent(GBDeviceEventFindPhone deviceEvent) {
|
|
|
|
Context context = getContext();
|
|
|
|
LOG.info("Got GBDeviceEventFindPhone");
|
|
|
|
switch (deviceEvent.event) {
|
|
|
|
case START:
|
|
|
|
Intent startIntent = new Intent(getContext(), FindPhoneActivity.class);
|
2018-10-22 13:28:54 +02:00
|
|
|
startIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
2018-01-19 23:10:08 +01:00
|
|
|
context.startActivity(startIntent);
|
|
|
|
break;
|
|
|
|
case STOP:
|
|
|
|
Intent intent = new Intent(FindPhoneActivity.ACTION_FOUND);
|
|
|
|
LocalBroadcastManager.getInstance(context).sendBroadcast(intent);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
LOG.warn("unknown GBDeviceEventFindPhone");
|
2015-05-23 00:54:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
private void handleGBDeviceEvent(GBDeviceEventMusicControl musicEvent) {
|
2015-05-23 00:54:14 +02:00
|
|
|
Context context = getContext();
|
2015-06-23 11:54:33 +02:00
|
|
|
LOG.info("Got event for MUSIC_CONTROL");
|
2015-05-23 00:54:14 +02:00
|
|
|
Intent musicIntent = new Intent(GBMusicControlReceiver.ACTION_MUSICCONTROL);
|
2015-06-23 11:54:33 +02:00
|
|
|
musicIntent.putExtra("event", musicEvent.event.ordinal());
|
2015-05-23 00:54:14 +02:00
|
|
|
musicIntent.setPackage(context.getPackageName());
|
|
|
|
context.sendBroadcast(musicIntent);
|
|
|
|
}
|
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
private void handleGBDeviceEvent(GBDeviceEventCallControl callEvent) {
|
2015-05-23 00:54:14 +02:00
|
|
|
Context context = getContext();
|
2015-06-23 11:54:33 +02:00
|
|
|
LOG.info("Got event for CALL_CONTROL");
|
2019-05-25 15:56:21 +02:00
|
|
|
if(callEvent.event == GBDeviceEventCallControl.Event.IGNORE) {
|
|
|
|
LOG.info("Sending intent for mute");
|
|
|
|
Intent broadcastIntent = new Intent("nodomain.freeyourgadget.gadgetbridge.MUTE_CALL");
|
|
|
|
broadcastIntent.setPackage(context.getPackageName());
|
|
|
|
context.sendBroadcast(broadcastIntent);
|
|
|
|
return;
|
|
|
|
}
|
2015-05-23 00:54:14 +02:00
|
|
|
Intent callIntent = new Intent(GBCallControlReceiver.ACTION_CALLCONTROL);
|
2015-06-23 11:54:33 +02:00
|
|
|
callIntent.putExtra("event", callEvent.event.ordinal());
|
2015-05-23 00:54:14 +02:00
|
|
|
callIntent.setPackage(context.getPackageName());
|
|
|
|
context.sendBroadcast(callIntent);
|
|
|
|
}
|
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
protected void handleGBDeviceEvent(GBDeviceEventVersionInfo infoEvent) {
|
2015-05-23 00:54:14 +02:00
|
|
|
Context context = getContext();
|
2018-08-06 20:20:54 +02:00
|
|
|
LOG.info("Got event for VERSION_INFO: " + infoEvent);
|
2015-05-23 00:54:14 +02:00
|
|
|
if (gbDevice == null) {
|
|
|
|
return;
|
|
|
|
}
|
2015-06-23 11:54:33 +02:00
|
|
|
gbDevice.setFirmwareVersion(infoEvent.fwVersion);
|
2016-08-26 20:57:59 +02:00
|
|
|
gbDevice.setModel(infoEvent.hwVersion);
|
2015-05-23 00:54:14 +02:00
|
|
|
gbDevice.sendDeviceUpdateIntent(context);
|
|
|
|
}
|
|
|
|
|
2018-07-28 17:23:58 +02:00
|
|
|
protected void handleGBDeviceEvent(GBDeviceEventLEDColor colorEvent) {
|
|
|
|
Context context = getContext();
|
2018-09-28 16:50:11 +02:00
|
|
|
LOG.info("Got event for LED Color: #" + Integer.toHexString(colorEvent.color).toUpperCase());
|
2018-07-28 17:23:58 +02:00
|
|
|
if (gbDevice == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
gbDevice.setExtraInfo("led_color", colorEvent.color);
|
|
|
|
gbDevice.sendDeviceUpdateIntent(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void handleGBDeviceEvent(GBDeviceEventFmFrequency frequencyEvent) {
|
|
|
|
Context context = getContext();
|
|
|
|
LOG.info("Got event for FM Frequency");
|
|
|
|
if (gbDevice == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
gbDevice.setExtraInfo("fm_frequency", frequencyEvent.frequency);
|
|
|
|
gbDevice.sendDeviceUpdateIntent(context);
|
|
|
|
}
|
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
private void handleGBDeviceEvent(GBDeviceEventAppInfo appInfoEvent) {
|
2015-05-23 00:54:14 +02:00
|
|
|
Context context = getContext();
|
2015-06-23 11:54:33 +02:00
|
|
|
LOG.info("Got event for APP_INFO");
|
2015-05-23 00:54:14 +02:00
|
|
|
|
2016-06-14 15:56:38 +02:00
|
|
|
Intent appInfoIntent = new Intent(AbstractAppManagerFragment.ACTION_REFRESH_APPLIST);
|
2015-06-23 11:54:33 +02:00
|
|
|
int appCount = appInfoEvent.apps.length;
|
2015-05-23 00:54:14 +02:00
|
|
|
appInfoIntent.putExtra("app_count", appCount);
|
2018-09-15 23:56:44 +02:00
|
|
|
for (int i = 0; i < appCount; i++) {
|
|
|
|
appInfoIntent.putExtra("app_name" + i, appInfoEvent.apps[i].getName());
|
|
|
|
appInfoIntent.putExtra("app_creator" + i, appInfoEvent.apps[i].getCreator());
|
|
|
|
appInfoIntent.putExtra("app_uuid" + i, appInfoEvent.apps[i].getUUID().toString());
|
|
|
|
appInfoIntent.putExtra("app_type" + i, appInfoEvent.apps[i].getType().ordinal());
|
2015-05-23 00:54:14 +02:00
|
|
|
}
|
|
|
|
LocalBroadcastManager.getInstance(context).sendBroadcast(appInfoIntent);
|
|
|
|
}
|
|
|
|
|
2015-06-24 23:55:51 +02:00
|
|
|
private void handleGBDeviceEvent(GBDeviceEventScreenshot screenshot) {
|
2017-03-10 23:10:40 +01:00
|
|
|
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd-hhmmss", Locale.US);
|
2015-06-26 23:17:31 +02:00
|
|
|
String filename = "screenshot_" + dateFormat.format(new Date()) + ".bmp";
|
|
|
|
|
2015-10-28 23:54:08 +01:00
|
|
|
try {
|
|
|
|
String fullpath = GB.writeScreenshot(screenshot, filename);
|
2015-06-27 00:21:30 +02:00
|
|
|
Bitmap bmp = BitmapFactory.decodeFile(fullpath);
|
|
|
|
Intent intent = new Intent();
|
|
|
|
intent.setAction(android.content.Intent.ACTION_VIEW);
|
2017-03-10 23:10:40 +01:00
|
|
|
Uri screenshotURI = FileProvider.getUriForFile(context, context.getApplicationContext().getPackageName() + ".screenshot_provider", new File(fullpath));
|
|
|
|
intent.setDataAndType(screenshotURI, "image/*");
|
2015-06-27 00:21:30 +02:00
|
|
|
|
|
|
|
PendingIntent pIntent = PendingIntent.getActivity(context, 0, intent, 0);
|
2015-06-26 23:17:31 +02:00
|
|
|
|
2015-06-27 18:09:49 +02:00
|
|
|
Intent shareIntent = new Intent(Intent.ACTION_SEND);
|
|
|
|
shareIntent.setType("image/*");
|
2017-09-03 14:11:51 +02:00
|
|
|
shareIntent.putExtra(Intent.EXTRA_STREAM, screenshotURI);
|
2015-06-27 18:09:49 +02:00
|
|
|
|
|
|
|
PendingIntent pendingShareIntent = PendingIntent.getActivity(context, 0, Intent.createChooser(shareIntent, "share screenshot"),
|
|
|
|
PendingIntent.FLAG_UPDATE_CURRENT);
|
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
NotificationCompat.Action action = new NotificationCompat.Action.Builder(android.R.drawable.ic_menu_share, "share", pendingShareIntent).build();
|
|
|
|
|
2018-02-14 21:27:24 +01:00
|
|
|
Notification notif = new NotificationCompat.Builder(context, NOTIFICATION_CHANNEL_ID)
|
2015-06-26 23:17:31 +02:00
|
|
|
.setContentTitle("Screenshot taken")
|
|
|
|
.setTicker("Screenshot taken")
|
|
|
|
.setContentText(filename)
|
|
|
|
.setSmallIcon(R.drawable.ic_notification)
|
2017-03-10 23:10:40 +01:00
|
|
|
.setStyle(new NotificationCompat.BigPictureStyle()
|
2015-06-26 23:17:31 +02:00
|
|
|
.bigPicture(bmp))
|
2015-06-27 00:21:30 +02:00
|
|
|
.setContentIntent(pIntent)
|
2017-03-10 23:10:40 +01:00
|
|
|
.addAction(action)
|
|
|
|
.setAutoCancel(true)
|
2015-06-26 23:17:31 +02:00
|
|
|
.build();
|
2015-06-27 18:09:49 +02:00
|
|
|
|
2015-06-26 23:17:31 +02:00
|
|
|
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
|
|
|
|
nm.notify(NOTIFICATION_ID_SCREENSHOT, notif);
|
2015-10-28 23:54:08 +01:00
|
|
|
} catch (IOException ex) {
|
|
|
|
LOG.error("Error writing screenshot", ex);
|
2015-06-26 23:17:31 +02:00
|
|
|
}
|
2015-06-24 23:55:51 +02:00
|
|
|
}
|
2015-07-21 01:25:22 +02:00
|
|
|
|
2015-08-31 22:27:25 +02:00
|
|
|
private void handleGBDeviceEvent(GBDeviceEventNotificationControl deviceEvent) {
|
2015-07-21 01:25:22 +02:00
|
|
|
Context context = getContext();
|
2015-08-31 22:27:25 +02:00
|
|
|
LOG.info("Got NOTIFICATION CONTROL device event");
|
|
|
|
String action = null;
|
|
|
|
switch (deviceEvent.event) {
|
|
|
|
case DISMISS:
|
|
|
|
action = NotificationListener.ACTION_DISMISS;
|
|
|
|
break;
|
2015-09-01 21:58:36 +02:00
|
|
|
case DISMISS_ALL:
|
|
|
|
action = NotificationListener.ACTION_DISMISS_ALL;
|
|
|
|
break;
|
2015-08-31 22:27:25 +02:00
|
|
|
case OPEN:
|
|
|
|
action = NotificationListener.ACTION_OPEN;
|
|
|
|
break;
|
2015-09-25 00:53:40 +02:00
|
|
|
case MUTE:
|
|
|
|
action = NotificationListener.ACTION_MUTE;
|
|
|
|
break;
|
2015-12-13 22:43:53 +01:00
|
|
|
case REPLY:
|
2016-06-21 00:31:53 +02:00
|
|
|
if (deviceEvent.phoneNumber == null) {
|
2018-11-01 19:12:43 +01:00
|
|
|
deviceEvent.phoneNumber = (String) GBApplication.getIDSenderLookup().lookup((int) (deviceEvent.handle >> 4));
|
2016-06-21 00:31:53 +02:00
|
|
|
}
|
|
|
|
if (deviceEvent.phoneNumber != null) {
|
2018-03-22 22:47:40 +01:00
|
|
|
LOG.info("Got notification reply for SMS from " + deviceEvent.phoneNumber + " : " + deviceEvent.reply);
|
2016-06-21 00:31:53 +02:00
|
|
|
SmsManager.getDefault().sendTextMessage(deviceEvent.phoneNumber, null, deviceEvent.reply, null, null);
|
2016-01-09 17:54:17 +01:00
|
|
|
} else {
|
2018-03-22 22:47:40 +01:00
|
|
|
LOG.info("Got notification reply for notification id " + deviceEvent.handle + " : " + deviceEvent.reply);
|
2016-01-09 17:54:17 +01:00
|
|
|
action = NotificationListener.ACTION_REPLY;
|
2015-12-14 23:31:31 +01:00
|
|
|
}
|
2015-12-13 22:43:53 +01:00
|
|
|
break;
|
2015-08-31 22:27:25 +02:00
|
|
|
}
|
|
|
|
if (action != null) {
|
|
|
|
Intent notificationListenerIntent = new Intent(action);
|
|
|
|
notificationListenerIntent.putExtra("handle", deviceEvent.handle);
|
2018-10-31 21:47:12 +01:00
|
|
|
notificationListenerIntent.putExtra("title", deviceEvent.title);
|
2016-01-09 17:54:17 +01:00
|
|
|
if (deviceEvent.reply != null) {
|
2016-04-25 23:39:03 +02:00
|
|
|
Prefs prefs = GBApplication.getPrefs();
|
|
|
|
String suffix = prefs.getString("canned_reply_suffix", null);
|
2016-01-11 15:29:12 +01:00
|
|
|
if (suffix != null && !Objects.equals(suffix, "")) {
|
|
|
|
deviceEvent.reply += suffix;
|
|
|
|
}
|
2016-01-09 17:54:17 +01:00
|
|
|
notificationListenerIntent.putExtra("reply", deviceEvent.reply);
|
|
|
|
}
|
2015-08-31 22:27:25 +02:00
|
|
|
LocalBroadcastManager.getInstance(context).sendBroadcast(notificationListenerIntent);
|
|
|
|
}
|
2015-07-21 01:25:22 +02:00
|
|
|
}
|
2015-08-18 17:37:51 +02:00
|
|
|
|
2017-03-10 23:10:40 +01:00
|
|
|
protected void handleGBDeviceEvent(GBDeviceEventBatteryInfo deviceEvent) {
|
2015-08-18 17:37:51 +02:00
|
|
|
Context context = getContext();
|
|
|
|
LOG.info("Got BATTERY_INFO device event");
|
|
|
|
gbDevice.setBatteryLevel(deviceEvent.level);
|
2015-08-21 08:41:57 +02:00
|
|
|
gbDevice.setBatteryState(deviceEvent.state);
|
2018-07-28 17:23:58 +02:00
|
|
|
gbDevice.setBatteryVoltage(deviceEvent.voltage);
|
2015-08-18 17:37:51 +02:00
|
|
|
|
2018-09-04 22:28:45 +02:00
|
|
|
if (deviceEvent.level == GBDevice.BATTERY_UNKNOWN) {
|
|
|
|
// no level available, just "high" or "low"
|
|
|
|
if (BatteryState.BATTERY_LOW.equals(deviceEvent.state)) {
|
|
|
|
GB.updateBatteryNotification(context.getString(R.string.notif_battery_low, gbDevice.getName()),
|
|
|
|
deviceEvent.extendedInfoAvailable() ?
|
|
|
|
context.getString(R.string.notif_battery_low_extended, gbDevice.getName(),
|
|
|
|
context.getString(R.string.notif_battery_low_bigtext_last_charge_time, DateFormat.getDateTimeInstance().format(deviceEvent.lastChargeTime.getTime())) +
|
|
|
|
context.getString(R.string.notif_battery_low_bigtext_number_of_charges, String.valueOf(deviceEvent.numCharges)))
|
|
|
|
: ""
|
|
|
|
, context);
|
|
|
|
} else {
|
|
|
|
GB.removeBatteryNotification(context);
|
|
|
|
}
|
2017-04-24 09:53:48 +02:00
|
|
|
} else {
|
2018-09-04 22:28:45 +02:00
|
|
|
//show the notification if the battery level is below threshold and only if not connected to charger
|
|
|
|
if (deviceEvent.level <= gbDevice.getBatteryThresholdPercent() &&
|
|
|
|
(BatteryState.BATTERY_LOW.equals(deviceEvent.state) ||
|
|
|
|
BatteryState.BATTERY_NORMAL.equals(deviceEvent.state))
|
|
|
|
) {
|
|
|
|
GB.updateBatteryNotification(context.getString(R.string.notif_battery_low_percent, gbDevice.getName(), String.valueOf(deviceEvent.level)),
|
|
|
|
deviceEvent.extendedInfoAvailable() ?
|
|
|
|
context.getString(R.string.notif_battery_low_percent, gbDevice.getName(), String.valueOf(deviceEvent.level)) + "\n" +
|
|
|
|
context.getString(R.string.notif_battery_low_bigtext_last_charge_time, DateFormat.getDateTimeInstance().format(deviceEvent.lastChargeTime.getTime())) +
|
|
|
|
context.getString(R.string.notif_battery_low_bigtext_number_of_charges, String.valueOf(deviceEvent.numCharges))
|
|
|
|
: ""
|
|
|
|
, context);
|
|
|
|
} else {
|
|
|
|
GB.removeBatteryNotification(context);
|
|
|
|
}
|
2015-08-18 17:37:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
gbDevice.sendDeviceUpdateIntent(context);
|
|
|
|
}
|
|
|
|
|
2016-04-03 00:50:45 +02:00
|
|
|
public void handleGBDeviceEvent(GBDeviceEventDisplayMessage message) {
|
|
|
|
GB.log(message.message, message.severity, null);
|
|
|
|
|
|
|
|
Intent messageIntent = new Intent(GB.ACTION_DISPLAY_MESSAGE);
|
|
|
|
messageIntent.putExtra(GB.DISPLAY_MESSAGE_MESSAGE, message.message);
|
|
|
|
messageIntent.putExtra(GB.DISPLAY_MESSAGE_DURATION, message.duration);
|
|
|
|
messageIntent.putExtra(GB.DISPLAY_MESSAGE_SEVERITY, message.severity);
|
|
|
|
|
|
|
|
LocalBroadcastManager.getInstance(context).sendBroadcast(messageIntent);
|
|
|
|
}
|
2019-09-14 00:05:39 +02:00
|
|
|
|
|
|
|
public String customStringFilter(String inputString) {
|
|
|
|
return inputString;
|
|
|
|
}
|
2015-04-14 01:24:03 +02:00
|
|
|
}
|