Refactoring

pull/200/head
M66B 4 years ago
parent b60da5cf11
commit 34aa1112eb

@ -312,8 +312,9 @@ public class ActivityCompose extends ActivityBase implements FragmentManager.OnB
ServiceSynchronize.eval(context, "outbox/drafts"); ServiceSynchronize.eval(context, "outbox/drafts");
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel("send:" + id, 10); (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("send:" + id, NotificationHelper.NOTIFICATION_TAGGED);
return message.id; return message.id;
} }

@ -1081,8 +1081,10 @@ public class ActivityView extends ActivityBilling implements FragmentManager.OnB
} }
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.notify(Helper.NOTIFICATION_UPDATE, builder.build()); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NotificationHelper.NOTIFICATION_UPDATE,
builder.build());
} catch (Throwable ex) { } catch (Throwable ex) {
Log.w(ex); Log.w(ex);
} }

@ -207,7 +207,7 @@ class Core {
if (EntityOperation.HEADERS.equals(op.name) || if (EntityOperation.HEADERS.equals(op.name) ||
EntityOperation.RAW.equals(op.name)) EntityOperation.RAW.equals(op.name))
nm.cancel(op.name + ":" + op.message, 10); nm.cancel(op.name + ":" + op.message, NotificationHelper.NOTIFICATION_TAGGED);
if (!Objects.equals(folder.id, op.folder)) if (!Objects.equals(folder.id, op.folder))
throw new IllegalArgumentException("Invalid folder=" + folder.id + "/" + op.folder); throw new IllegalArgumentException("Invalid folder=" + folder.id + "/" + op.folder);
@ -628,7 +628,9 @@ class Core {
if (title != null) { if (title != null) {
NotificationCompat.Builder builder = NotificationCompat.Builder builder =
getNotificationError(context, "warning", title, ex); getNotificationError(context, "warning", title, ex);
nm.notify(op.name + ":" + op.message, 10, builder.build()); nm.notify(op.name + ":" + op.message,
NotificationHelper.NOTIFICATION_TAGGED,
builder.build());
} }
} else { } else {
@ -4075,7 +4077,7 @@ class Core {
for (Long id : remove) { for (Long id : remove) {
String tag = "unseen." + group + "." + Math.abs(id); String tag = "unseen." + group + "." + Math.abs(id);
EntityLog.log(context, "Notify cancel tag=" + tag + " id=" + id); EntityLog.log(context, "Notify cancel tag=" + tag + " id=" + id);
nm.cancel(tag, 10); nm.cancel(tag, NotificationHelper.NOTIFICATION_TAGGED);
data.groupNotifying.get(group).remove(id); data.groupNotifying.get(group).remove(id);
db.message().setMessageNotifying(Math.abs(id), 0); db.message().setMessageNotifying(Math.abs(id), 0);
@ -4084,7 +4086,7 @@ class Core {
if (notifications.size() == 0) { if (notifications.size() == 0) {
String tag = "unseen." + group + "." + 0; String tag = "unseen." + group + "." + 0;
EntityLog.log(context, "Notify cancel tag=" + tag); EntityLog.log(context, "Notify cancel tag=" + tag);
nm.cancel(tag, 10); nm.cancel(tag, NotificationHelper.NOTIFICATION_TAGGED);
} }
for (Long id : add) { for (Long id : add) {
@ -4114,7 +4116,7 @@ class Core {
: " channel=" + notification.getChannelId()) + : " channel=" + notification.getChannelId()) +
" sort=" + notification.getSortKey()); " sort=" + notification.getSortKey());
try { try {
nm.notify(tag, 10, notification); nm.notify(tag, NotificationHelper.NOTIFICATION_TAGGED, notification);
// https://github.com/leolin310148/ShortcutBadger/wiki/Xiaomi-Device-Support // https://github.com/leolin310148/ShortcutBadger/wiki/Xiaomi-Device-Support
if (id == 0 && badge && Helper.isXiaomi()) if (id == 0 && badge && Helper.isXiaomi())
ShortcutBadger.applyNotification(context, notification, current); ShortcutBadger.applyNotification(context, notification, current);

@ -1266,8 +1266,8 @@ public class FragmentAccount extends FragmentBase {
if (!synchronize) { if (!synchronize) {
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("receive:" + account.id, 10); nm.cancel("receive:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
nm.cancel("alert:" + account.id, 10); nm.cancel("alert:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
} }
args.putBoolean("saved", true); args.putBoolean("saved", true);

@ -917,7 +917,7 @@ public class FragmentFolders extends FragmentBase {
if (now - last > EXPORT_PROGRESS_INTERVAL) { if (now - last > EXPORT_PROGRESS_INTERVAL) {
last = now; last = now;
builder.setProgress(ids.size(), i, false); builder.setProgress(ids.size(), i, false);
nm.notify("export", 10, builder.build()); nm.notify("export", NotificationHelper.NOTIFICATION_TAGGED, builder.build());
} }
long id = ids.get(i); long id = ids.get(i);
@ -990,7 +990,7 @@ public class FragmentFolders extends FragmentBase {
Log.e(ex); Log.e(ex);
} }
} finally { } finally {
nm.cancel("export", 10); nm.cancel("export", NotificationHelper.NOTIFICATION_TAGGED);
} }
return null; return null;

@ -7571,8 +7571,9 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
ServiceSynchronize.eval(context, "delete"); ServiceSynchronize.eval(context, "delete");
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel("send:" + id, 10); (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("send:" + id, NotificationHelper.NOTIFICATION_TAGGED);
return null; return null;
} }

@ -448,8 +448,9 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc
prefs.edit().putBoolean("updates", checked).apply(); prefs.edit().putBoolean("updates", checked).apply();
swCheckWeekly.setEnabled(checked); swCheckWeekly.setEnabled(checked);
if (!checked) { if (!checked) {
NotificationManager nm = (NotificationManager) getContext().getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel(Helper.NOTIFICATION_UPDATE); (NotificationManager) getContext().getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel(NotificationHelper.NOTIFICATION_UPDATE);
} }
} }
}); });

@ -623,9 +623,10 @@ public class FragmentPop extends FragmentBase {
ServiceSynchronize.eval(context, "POP3"); ServiceSynchronize.eval(context, "POP3");
if (!synchronize) { if (!synchronize) {
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel("receive:" + account.id, 10); (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("alert:" + account.id, 10); nm.cancel("receive:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
nm.cancel("alert:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
} }
args.putBoolean("saved", true); args.putBoolean("saved", true);

@ -144,11 +144,6 @@ public class Helper {
private static Boolean hasPlayStore = null; private static Boolean hasPlayStore = null;
private static Boolean hasValidFingerprint = null; private static Boolean hasValidFingerprint = null;
static final int NOTIFICATION_SYNCHRONIZE = 1;
static final int NOTIFICATION_SEND = 2;
static final int NOTIFICATION_EXTERNAL = 3;
static final int NOTIFICATION_UPDATE = 4;
static final float LOW_LIGHT = 0.6f; static final float LOW_LIGHT = 0.6f;
static final int BUFFER_SIZE = 8192; // Same as in Files class static final int BUFFER_SIZE = 8192; // Same as in Files class

@ -37,6 +37,12 @@ import org.json.JSONException;
import org.json.JSONObject; import org.json.JSONObject;
class NotificationHelper { class NotificationHelper {
static final int NOTIFICATION_SYNCHRONIZE = 100;
static final int NOTIFICATION_SEND = 200;
static final int NOTIFICATION_EXTERNAL = 300;
static final int NOTIFICATION_UPDATE = 400;
static final int NOTIFICATION_TAGGED = 500;
@RequiresApi(api = Build.VERSION_CODES.O) @RequiresApi(api = Build.VERSION_CODES.O)
static void createNotificationChannels(Context context) { static void createNotificationChannels(Context context) {
// https://issuetracker.google.com/issues/65108694 // https://issuetracker.google.com/issues/65108694

@ -58,7 +58,8 @@ public class ServiceExternal extends Service {
public void onCreate() { public void onCreate() {
Log.i("Service external create"); Log.i("Service external create");
super.onCreate(); super.onCreate();
startForeground(Helper.NOTIFICATION_EXTERNAL, getNotification().build()); startForeground(NotificationHelper.NOTIFICATION_EXTERNAL,
getNotification().build());
} }
@Override @Override
@ -75,7 +76,8 @@ public class ServiceExternal extends Service {
Log.logExtras(intent); Log.logExtras(intent);
super.onStartCommand(intent, flags, startId); super.onStartCommand(intent, flags, startId);
startForeground(Helper.NOTIFICATION_EXTERNAL, getNotification().build()); startForeground(NotificationHelper.NOTIFICATION_EXTERNAL,
getNotification().build());
if (intent == null) if (intent == null)
return START_NOT_STICKY; return START_NOT_STICKY;

@ -83,7 +83,8 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
public void onCreate() { public void onCreate() {
EntityLog.log(this, "Service send create"); EntityLog.log(this, "Service send create");
super.onCreate(); super.onCreate();
startForeground(Helper.NOTIFICATION_SEND, getNotificationService().build()); startForeground(NotificationHelper.NOTIFICATION_SEND,
getNotificationService().build());
PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
wlOutbox = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, BuildConfig.APPLICATION_ID + ":send"); wlOutbox = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, BuildConfig.APPLICATION_ID + ":send");
@ -98,8 +99,10 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
EntityLog.log(ServiceSend.this, "Unsent=" + (unsent == null ? null : unsent.count)); EntityLog.log(ServiceSend.this, "Unsent=" + (unsent == null ? null : unsent.count));
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.notify(Helper.NOTIFICATION_SEND, getNotificationService().build()); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NotificationHelper.NOTIFICATION_SEND,
getNotificationService().build());
} catch (Throwable ex) { } catch (Throwable ex) {
Log.w(ex); Log.w(ex);
} }
@ -177,8 +180,9 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
stopForeground(true); stopForeground(true);
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel(Helper.NOTIFICATION_SEND); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel(NotificationHelper.NOTIFICATION_SEND);
super.onDestroy(); super.onDestroy();
} }
@ -192,7 +196,8 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
@Override @Override
public int onStartCommand(Intent intent, int flags, int startId) { public int onStartCommand(Intent intent, int flags, int startId) {
super.onStartCommand(intent, flags, startId); super.onStartCommand(intent, flags, startId);
startForeground(Helper.NOTIFICATION_SEND, getNotificationService().build()); startForeground(NotificationHelper.NOTIFICATION_SEND,
getNotificationService().build());
Log.i("Send intent=" + intent); Log.i("Send intent=" + intent);
Log.logExtras(intent); Log.logExtras(intent);
@ -319,8 +324,10 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
EntityLog.log(ServiceSend.this, "Service send suitable=" + suitable); EntityLog.log(ServiceSend.this, "Service send suitable=" + suitable);
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.notify(Helper.NOTIFICATION_SEND, getNotificationService().build()); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NotificationHelper.NOTIFICATION_SEND,
getNotificationService().build());
} catch (Throwable ex) { } catch (Throwable ex) {
Log.w(ex); Log.w(ex);
} }
@ -419,8 +426,10 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
try { try {
int tries_left = (unrecoverable ? 0 : RETRY_MAX - op.tries); int tries_left = (unrecoverable ? 0 : RETRY_MAX - op.tries);
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify("send:" + message.id, 10, getNotificationError( nm.notify("send:" + message.id,
MessageHelper.formatAddressesShort(message.to), ex, tries_left).build()); NotificationHelper.NOTIFICATION_TAGGED,
getNotificationError(
MessageHelper.formatAddressesShort(message.to), ex, tries_left).build());
} catch (Throwable ex1) { } catch (Throwable ex1) {
Log.w(ex1); Log.w(ex1);
} }
@ -473,7 +482,7 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
} }
db.message().setMessageError(message.id, null); db.message().setMessageError(message.id, null);
nm.cancel("send:" + message.id, 10); nm.cancel("send:" + message.id, NotificationHelper.NOTIFICATION_TAGGED);
if (message.ui_snoozed == null) if (message.ui_snoozed == null)
EntityOperation.queue(this, message, EntityOperation.SEND); EntityOperation.queue(this, message, EntityOperation.SEND);
@ -734,8 +743,9 @@ public class ServiceSend extends ServiceBase implements SharedPreferences.OnShar
db.endTransaction(); db.endTransaction();
} }
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel("send:" + message.id, 10); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("send:" + message.id, NotificationHelper.NOTIFICATION_TAGGED);
// Check sent message // Check sent message
if (sid != null) { if (sid != null) {

@ -171,7 +171,8 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
if (isBackgroundService(this)) if (isBackgroundService(this))
stopForeground(true); stopForeground(true);
else else
startForeground(Helper.NOTIFICATION_SYNCHRONIZE, getNotificationService(null, null).build()); startForeground(NotificationHelper.NOTIFICATION_SYNCHRONIZE,
getNotificationService(null, null).build());
// Listen for network changes // Listen for network changes
ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE); ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
@ -367,8 +368,10 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
if (!isBackgroundService(ServiceSynchronize.this)) if (!isBackgroundService(ServiceSynchronize.this))
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.notify(Helper.NOTIFICATION_SYNCHRONIZE, getNotificationService(lastAccounts, lastOperations).build()); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NotificationHelper.NOTIFICATION_SYNCHRONIZE,
getNotificationService(lastAccounts, lastOperations).build());
} catch (Throwable ex) { } catch (Throwable ex) {
/* /*
java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.lang.Iterable.iterator()' on a null object reference java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.lang.Iterable.iterator()' on a null object reference
@ -774,8 +777,9 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
*/ */
} }
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel(Helper.NOTIFICATION_SYNCHRONIZE); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel(NotificationHelper.NOTIFICATION_SYNCHRONIZE);
super.onDestroy(); super.onDestroy();
} }
@ -799,7 +803,8 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
if (isBackgroundService(this)) if (isBackgroundService(this))
stopForeground(true); stopForeground(true);
else else
startForeground(Helper.NOTIFICATION_SYNCHRONIZE, getNotificationService(null, null).build()); startForeground(NotificationHelper.NOTIFICATION_SYNCHRONIZE,
getNotificationService(null, null).build());
if (action != null) if (action != null)
try { try {
@ -1240,7 +1245,8 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
if (!ConnectionHelper.isMaxConnections(message)) if (!ConnectionHelper.isMaxConnections(message))
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify("alert:" + account.id, 10, nm.notify("alert:" + account.id,
NotificationHelper.NOTIFICATION_TAGGED,
getNotificationAlert(account.name, message).build()); getNotificationAlert(account.name, message).build());
} catch (Throwable ex) { } catch (Throwable ex) {
Log.w(ex); Log.w(ex);
@ -1272,7 +1278,8 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
try { try {
state.setBackoff(2 * CONNECT_BACKOFF_ALARM_MAX * 60); state.setBackoff(2 * CONNECT_BACKOFF_ALARM_MAX * 60);
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify("receive:" + account.id, 10, nm.notify("receive:" + account.id,
NotificationHelper.NOTIFICATION_TAGGED,
Core.getNotificationError(this, "error", account.name, ex) Core.getNotificationError(this, "error", account.name, ex)
.build()); .build());
} catch (Throwable ex1) { } catch (Throwable ex1) {
@ -1932,9 +1939,10 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
db.account().setAccountConnected(account.id, account.last_connected); db.account().setAccountConnected(account.id, account.last_connected);
db.account().setAccountWarning(account.id, capIdle ? null : getString(R.string.title_no_idle)); db.account().setAccountWarning(account.id, capIdle ? null : getString(R.string.title_no_idle));
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel("receive:" + account.id, 10); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel("alert:" + account.id, 10); nm.cancel("receive:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
nm.cancel("alert:" + account.id, NotificationHelper.NOTIFICATION_TAGGED);
// Schedule keep alive alarm // Schedule keep alive alarm
Intent intent = new Intent(this, ServiceSynchronize.class); Intent intent = new Intent(this, ServiceSynchronize.class);
@ -1992,7 +2000,8 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
.format(account.last_connected)), ex); .format(account.last_connected)), ex);
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify("receive:" + account.id, 10, nm.notify("receive:" + account.id,
NotificationHelper.NOTIFICATION_TAGGED,
Core.getNotificationError(this, "warning", account.name, warning) Core.getNotificationError(this, "warning", account.name, warning)
.build()); .build());
} catch (Throwable ex1) { } catch (Throwable ex1) {
@ -2351,8 +2360,10 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
if (!isBackgroundService(ServiceSynchronize.this)) if (!isBackgroundService(ServiceSynchronize.this))
try { try {
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.notify(Helper.NOTIFICATION_SYNCHRONIZE, getNotificationService(lastAccounts, lastOperations).build()); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NotificationHelper.NOTIFICATION_SYNCHRONIZE,
getNotificationService(lastAccounts, lastOperations).build());
} catch (Throwable ex) { } catch (Throwable ex) {
Log.w(ex); Log.w(ex);
} }

@ -193,8 +193,9 @@ public class ServiceUI extends IntentService {
// https://issuetracker.google.com/issues/159152393 // https://issuetracker.google.com/issues/159152393
String tag = "unseen." + group + ":" + id; String tag = "unseen." + group + ":" + id;
NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); NotificationManager nm =
nm.cancel(tag, 10); (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
nm.cancel(tag, NotificationHelper.NOTIFICATION_TAGGED);
} }
private void onMove(long id, String folderType) { private void onMove(long id, String folderType) {

Loading…
Cancel
Save