mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-27 18:17:33 +01:00
Fixed things based on feedback
This commit is contained in:
parent
8a91628322
commit
31eabe9605
@ -1,6 +1,7 @@
|
|||||||
package nodomain.freeyourgadget.gadgetbridge;
|
package nodomain.freeyourgadget.gadgetbridge;
|
||||||
|
|
||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
|
import android.app.NotificationManager;
|
||||||
import android.app.NotificationManager.Policy;
|
import android.app.NotificationManager.Policy;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@ -13,7 +14,6 @@ import android.net.Uri;
|
|||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Build.VERSION;
|
import android.os.Build.VERSION;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.provider.ContactsContract;
|
|
||||||
import android.provider.ContactsContract.PhoneLookup;
|
import android.provider.ContactsContract.PhoneLookup;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
@ -64,6 +64,7 @@ public class GBApplication extends Application {
|
|||||||
private static Appender<ILoggingEvent> fileLogger;
|
private static Appender<ILoggingEvent> fileLogger;
|
||||||
private static Prefs prefs;
|
private static Prefs prefs;
|
||||||
private static GBPrefs gbPrefs;
|
private static GBPrefs gbPrefs;
|
||||||
|
private static NotificationManager notificationManager;
|
||||||
|
|
||||||
public static final String ACTION_QUIT
|
public static final String ACTION_QUIT
|
||||||
= "nodomain.freeyourgadget.gadgetbridge.gbapplication.action.quit";
|
= "nodomain.freeyourgadget.gadgetbridge.gbapplication.action.quit";
|
||||||
@ -124,6 +125,10 @@ public class GBApplication extends Application {
|
|||||||
filterLocal.addAction(ACTION_QUIT);
|
filterLocal.addAction(ACTION_QUIT);
|
||||||
LocalBroadcastManager.getInstance(this).registerReceiver(mReceiver, filterLocal);
|
LocalBroadcastManager.getInstance(this).registerReceiver(mReceiver, filterLocal);
|
||||||
|
|
||||||
|
if (isRunningMarshmallowOrLater()) {
|
||||||
|
notificationManager = (NotificationManager) context.getSystemService(context.NOTIFICATION_SERVICE);
|
||||||
|
}
|
||||||
|
|
||||||
// for testing DB stuff
|
// for testing DB stuff
|
||||||
// SQLiteDatabase db = mActivityDatabaseHandler.getWritableDatabase();
|
// SQLiteDatabase db = mActivityDatabaseHandler.getWritableDatabase();
|
||||||
// db.close();
|
// db.close();
|
||||||
@ -256,7 +261,10 @@ public class GBApplication extends Application {
|
|||||||
return VERSION.SDK_INT >= Build.VERSION_CODES.M;
|
return VERSION.SDK_INT >= Build.VERSION_CODES.M;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isPriorityNumber(int prioritySenders, String number) {
|
private static boolean isPrioritySender(int prioritySenders, String number) {
|
||||||
|
if (prioritySenders == Policy.PRIORITY_SENDERS_ANY) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
Uri uri = Uri.withAppendedPath(PhoneLookup.CONTENT_FILTER_URI, Uri.encode(number));
|
Uri uri = Uri.withAppendedPath(PhoneLookup.CONTENT_FILTER_URI, Uri.encode(number));
|
||||||
String[] projection = new String[]{PhoneLookup._ID, PhoneLookup.STARRED};
|
String[] projection = new String[]{PhoneLookup._ID, PhoneLookup.STARRED};
|
||||||
Cursor cursor = context.getContentResolver().query(uri, projection, null, null, null);
|
Cursor cursor = context.getContentResolver().query(uri, projection, null, null, null);
|
||||||
@ -272,21 +280,38 @@ public class GBApplication extends Application {
|
|||||||
cursor.close();
|
cursor.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
switch (prioritySenders) {
|
if (prioritySenders == Policy.PRIORITY_SENDERS_CONTACTS && exists) {
|
||||||
case Policy.PRIORITY_SENDERS_ANY:
|
|
||||||
return true;
|
return true;
|
||||||
case Policy.PRIORITY_SENDERS_CONTACTS:
|
} else if (prioritySenders == Policy.PRIORITY_SENDERS_STARRED && starred == 1) {
|
||||||
if (exists) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
case Policy.PRIORITY_SENDERS_STARRED:
|
return false;
|
||||||
if (PhoneLookup.STARRED.equals(starred)) {
|
}
|
||||||
return true;
|
}
|
||||||
|
|
||||||
|
public static boolean isPriorityNumber(int priorityType, String number) {
|
||||||
|
NotificationManager.Policy notificationPolicy = notificationManager.getNotificationPolicy();
|
||||||
|
if(priorityType == Policy.PRIORITY_CATEGORY_MESSAGES) {
|
||||||
|
if ((notificationPolicy.priorityCategories & Policy.PRIORITY_CATEGORY_MESSAGES) == Policy.PRIORITY_CATEGORY_MESSAGES) {
|
||||||
|
return isPrioritySender(notificationPolicy.priorityMessageSenders, number);
|
||||||
|
}
|
||||||
|
} else if (priorityType == Policy.PRIORITY_CATEGORY_CALLS) {
|
||||||
|
if ((notificationPolicy.priorityCategories & Policy.PRIORITY_CATEGORY_CALLS) == Policy.PRIORITY_CATEGORY_CALLS) {
|
||||||
|
return isPrioritySender(notificationPolicy.priorityCallSenders, number);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int getGrantedInterruptionFilter() {
|
||||||
|
if (prefs.getBoolean("notification_filter", false) && GBApplication.isRunningMarshmallowOrLater()) {
|
||||||
|
if (notificationManager.isNotificationPolicyAccessGranted()) {
|
||||||
|
return notificationManager.getCurrentInterruptionFilter();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NotificationManager.INTERRUPTION_FILTER_ALL;
|
||||||
|
}
|
||||||
|
|
||||||
public static HashSet<String> blacklist = null;
|
public static HashSet<String> blacklist = null;
|
||||||
|
|
||||||
private static void loadBlackList() {
|
private static void loadBlackList() {
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package nodomain.freeyourgadget.gadgetbridge.activities;
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
import android.app.NotificationManager;
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
@ -10,7 +9,6 @@ import android.preference.Preference;
|
|||||||
import android.preference.PreferenceCategory;
|
import android.preference.PreferenceCategory;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
import android.service.notification.NotificationListenerService;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -34,17 +34,14 @@ public class K9Receiver extends BroadcastReceiver {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (prefs.getBoolean("notification_filter", false) && GBApplication.isRunningMarshmallowOrLater()) {
|
switch (GBApplication.getGrantedInterruptionFilter()) {
|
||||||
NotificationManager notificationManager = (NotificationManager) context.getSystemService(context.NOTIFICATION_SERVICE);
|
case NotificationManager.INTERRUPTION_FILTER_ALL:
|
||||||
if (notificationManager.isNotificationPolicyAccessGranted()) {
|
break;
|
||||||
switch (notificationManager.getCurrentInterruptionFilter()) {
|
|
||||||
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
||||||
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
||||||
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
String uriWanted = intent.getData().toString();
|
String uriWanted = intent.getData().toString();
|
||||||
|
|
||||||
|
@ -168,10 +168,9 @@ public class NotificationListener extends NotificationListenerService {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (prefs.getBoolean("notification_filter", false) && GBApplication.isRunningMarshmallowOrLater()) {
|
switch (GBApplication.getGrantedInterruptionFilter()) {
|
||||||
NotificationManager notificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
|
case NotificationManager.INTERRUPTION_FILTER_ALL:
|
||||||
if (notificationManager.isNotificationPolicyAccessGranted()) {
|
break;
|
||||||
switch (notificationManager.getCurrentInterruptionFilter()) {
|
|
||||||
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
||||||
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
||||||
return;
|
return;
|
||||||
@ -179,8 +178,6 @@ public class NotificationListener extends NotificationListenerService {
|
|||||||
// FIXME: Handle Reminders and Events if they are enabled in Do Not Disturb
|
// FIXME: Handle Reminders and Events if they are enabled in Do Not Disturb
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
String source = sbn.getPackageName();
|
String source = sbn.getPackageName();
|
||||||
Notification notification = sbn.getNotification();
|
Notification notification = sbn.getNotification();
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package nodomain.freeyourgadget.gadgetbridge.externalevents;
|
package nodomain.freeyourgadget.gadgetbridge.externalevents;
|
||||||
|
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
|
import android.app.NotificationManager.Policy;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@ -68,22 +69,18 @@ public class PhoneCallReceiver extends BroadcastReceiver {
|
|||||||
if ("never".equals(prefs.getString("notification_mode_calls", "always"))) {
|
if ("never".equals(prefs.getString("notification_mode_calls", "always"))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (prefs.getBoolean("notification_filter", false) && GBApplication.isRunningMarshmallowOrLater()) {
|
switch (GBApplication.getGrantedInterruptionFilter()) {
|
||||||
NotificationManager notificationManager = (NotificationManager) context.getSystemService(context.NOTIFICATION_SERVICE);
|
case NotificationManager.INTERRUPTION_FILTER_ALL:
|
||||||
if (notificationManager.isNotificationPolicyAccessGranted()) {
|
break;
|
||||||
switch (notificationManager.getCurrentInterruptionFilter()) {
|
|
||||||
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
||||||
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
||||||
return;
|
return;
|
||||||
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
||||||
NotificationManager.Policy notificationPolicy = notificationManager.getNotificationPolicy();
|
if (GBApplication.isPriorityNumber(Policy.PRIORITY_CATEGORY_CALLS, mSavedNumber)) {
|
||||||
if (!GBApplication.isPriorityNumber(notificationPolicy.priorityCallSenders, mSavedNumber)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// FIXME: Handle Repeat callers if it is enabled in Do Not Disturb
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
// FIXME: Handle Repeat callers if it is enabled in Do Not Disturb
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
CallSpec callSpec = new CallSpec();
|
CallSpec callSpec = new CallSpec();
|
||||||
callSpec.number = mSavedNumber;
|
callSpec.number = mSavedNumber;
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
package nodomain.freeyourgadget.gadgetbridge.externalevents;
|
package nodomain.freeyourgadget.gadgetbridge.externalevents;
|
||||||
|
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
|
import android.app.NotificationManager.Policy;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.telephony.SmsMessage;
|
import android.telephony.SmsMessage;
|
||||||
import android.util.Log;
|
|
||||||
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
|
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
|
||||||
@ -43,21 +43,17 @@ public class SMSReceiver extends BroadcastReceiver {
|
|||||||
notificationSpec.body = message.getDisplayMessageBody();
|
notificationSpec.body = message.getDisplayMessageBody();
|
||||||
notificationSpec.phoneNumber = message.getOriginatingAddress();
|
notificationSpec.phoneNumber = message.getOriginatingAddress();
|
||||||
if (notificationSpec.phoneNumber != null) {
|
if (notificationSpec.phoneNumber != null) {
|
||||||
if (prefs.getBoolean("notification_filter", false) && GBApplication.isRunningMarshmallowOrLater()) {
|
switch (GBApplication.getGrantedInterruptionFilter()) {
|
||||||
NotificationManager notificationManager = (NotificationManager) context.getSystemService(context.NOTIFICATION_SERVICE);
|
case NotificationManager.INTERRUPTION_FILTER_ALL:
|
||||||
if (notificationManager.isNotificationPolicyAccessGranted()) {
|
break;
|
||||||
switch (notificationManager.getCurrentInterruptionFilter()) {
|
|
||||||
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
case NotificationManager.INTERRUPTION_FILTER_ALARMS:
|
||||||
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
case NotificationManager.INTERRUPTION_FILTER_NONE:
|
||||||
return;
|
return;
|
||||||
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
case NotificationManager.INTERRUPTION_FILTER_PRIORITY:
|
||||||
NotificationManager.Policy notificationPolicy = notificationManager.getNotificationPolicy();
|
if (GBApplication.isPriorityNumber(Policy.PRIORITY_CATEGORY_MESSAGES, notificationSpec.phoneNumber)) {
|
||||||
if (!GBApplication.isPriorityNumber(notificationPolicy.priorityMessageSenders, notificationSpec.phoneNumber)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
return;
|
||||||
}
|
}
|
||||||
GBApplication.deviceService().onNotification(notificationSpec);
|
GBApplication.deviceService().onNotification(notificationSpec);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user