mirror of
https://github.com/moparisthebest/k-9
synced 2024-12-02 14:02:17 -05:00
Replace the old "record a message in K9 Errors and give up"
failed-message scheme with an actual android notification that opens the outbox
This commit is contained in:
parent
e964c7ba84
commit
a551dc8dff
@ -235,8 +235,6 @@ public class K9 extends Application
|
|||||||
*/
|
*/
|
||||||
public static int DEFAULT_VISIBLE_LIMIT = 25;
|
public static int DEFAULT_VISIBLE_LIMIT = 25;
|
||||||
|
|
||||||
public static int MAX_SEND_ATTEMPTS = 1;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The maximum size of an attachment we're willing to download (either View or Save)
|
* The maximum size of an attachment we're willing to download (either View or Save)
|
||||||
* Attachments that are base64 encoded (most) will be about 1.375x their actual size
|
* Attachments that are base64 encoded (most) will be about 1.375x their actual size
|
||||||
|
@ -3483,7 +3483,7 @@ public class MessagingController implements Runnable
|
|||||||
localFolder.open(OpenMode.READ_WRITE);
|
localFolder.open(OpenMode.READ_WRITE);
|
||||||
|
|
||||||
Message[] localMessages = localFolder.getMessages(null);
|
Message[] localMessages = localFolder.getMessages(null);
|
||||||
boolean anyFlagged = false;
|
Exception lastFailure = null;
|
||||||
int progress = 0;
|
int progress = 0;
|
||||||
int todo = localMessages.length;
|
int todo = localMessages.length;
|
||||||
for (MessagingListener l : getListeners())
|
for (MessagingListener l : getListeners())
|
||||||
@ -3520,13 +3520,6 @@ public class MessagingController implements Runnable
|
|||||||
|
|
||||||
if (K9.DEBUG)
|
if (K9.DEBUG)
|
||||||
Log.i(K9.LOG_TAG, "Send count for message " + message.getUid() + " is " + count.get());
|
Log.i(K9.LOG_TAG, "Send count for message " + message.getUid() + " is " + count.get());
|
||||||
if (count.incrementAndGet() > K9.MAX_SEND_ATTEMPTS)
|
|
||||||
{
|
|
||||||
Log.e(K9.LOG_TAG, "Send count for message " + message.getUid() + " has exceeded maximum attempt threshold, flagging");
|
|
||||||
message.setFlag(Flag.FLAGGED, true);
|
|
||||||
anyFlagged = true;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
localFolder.fetch(new Message[] { message }, fp, null);
|
localFolder.fetch(new Message[] { message }, fp, null);
|
||||||
try
|
try
|
||||||
@ -3550,27 +3543,18 @@ public class MessagingController implements Runnable
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LocalFolder localSentFolder =
|
LocalFolder localSentFolder = (LocalFolder) localStore.getFolder( account.getSentFolderName());
|
||||||
(LocalFolder) localStore.getFolder(
|
|
||||||
account.getSentFolderName());
|
|
||||||
if (K9.DEBUG)
|
if (K9.DEBUG)
|
||||||
Log.i(K9.LOG_TAG, "Moving sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
|
Log.i(K9.LOG_TAG, "Moving sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
|
||||||
|
|
||||||
localFolder.moveMessages(
|
localFolder.moveMessages( new Message[] { message }, localSentFolder);
|
||||||
new Message[] { message },
|
|
||||||
localSentFolder);
|
|
||||||
|
|
||||||
if (K9.DEBUG)
|
if (K9.DEBUG)
|
||||||
Log.i(K9.LOG_TAG, "Moved sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
|
Log.i(K9.LOG_TAG, "Moved sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
|
||||||
|
|
||||||
PendingCommand command = new PendingCommand();
|
PendingCommand command = new PendingCommand();
|
||||||
command.command = PENDING_COMMAND_APPEND;
|
command.command = PENDING_COMMAND_APPEND;
|
||||||
command.arguments =
|
command.arguments = new String[] { localSentFolder.getName(), message.getUid() };
|
||||||
new String[]
|
|
||||||
{
|
|
||||||
localSentFolder.getName(),
|
|
||||||
message.getUid()
|
|
||||||
};
|
|
||||||
queuePendingCommand(account, command);
|
queuePendingCommand(account, command);
|
||||||
processPendingCommands(account);
|
processPendingCommands(account);
|
||||||
}
|
}
|
||||||
@ -3578,29 +3562,13 @@ public class MessagingController implements Runnable
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
if (e instanceof MessagingException)
|
|
||||||
{
|
|
||||||
MessagingException me = (MessagingException)e;
|
|
||||||
if (!me.isPermanentFailure())
|
|
||||||
{
|
|
||||||
// Decrement the counter if the message could not possibly have been sent
|
|
||||||
int newVal = count.decrementAndGet();
|
|
||||||
if (K9.DEBUG)
|
|
||||||
Log.i(K9.LOG_TAG, "Decremented send count for message " + message.getUid() + " to " + newVal
|
|
||||||
+ "; no possible send");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
message.setFlag(Flag.X_SEND_FAILED, true);
|
message.setFlag(Flag.X_SEND_FAILED, true);
|
||||||
Log.e(K9.LOG_TAG, "Failed to send message", e);
|
Log.e(K9.LOG_TAG, "Failed to send message", e);
|
||||||
for (MessagingListener l : getListeners())
|
for (MessagingListener l : getListeners())
|
||||||
{
|
{
|
||||||
l.synchronizeMailboxFailed(
|
l.synchronizeMailboxFailed( account, localFolder.getName(), getRootCauseMessage(e));
|
||||||
account,
|
|
||||||
localFolder.getName(),
|
|
||||||
getRootCauseMessage(e));
|
|
||||||
}
|
}
|
||||||
addErrorMessage(account, null, e);
|
lastFailure = e;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
@ -3608,17 +3576,9 @@ public class MessagingController implements Runnable
|
|||||||
Log.e(K9.LOG_TAG, "Failed to fetch message for sending", e);
|
Log.e(K9.LOG_TAG, "Failed to fetch message for sending", e);
|
||||||
for (MessagingListener l : getListeners())
|
for (MessagingListener l : getListeners())
|
||||||
{
|
{
|
||||||
l.synchronizeMailboxFailed(
|
l.synchronizeMailboxFailed( account, localFolder.getName(), getRootCauseMessage(e));
|
||||||
account,
|
|
||||||
localFolder.getName(),
|
|
||||||
getRootCauseMessage(e));
|
|
||||||
}
|
}
|
||||||
addErrorMessage(account, null, e);
|
lastFailure = e;
|
||||||
|
|
||||||
/*
|
|
||||||
* We ignore this exception because a future refresh will retry this
|
|
||||||
* message.
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (localFolder.getMessageCount() == 0)
|
if (localFolder.getMessageCount() == 0)
|
||||||
@ -3629,29 +3589,24 @@ public class MessagingController implements Runnable
|
|||||||
{
|
{
|
||||||
l.sendPendingMessagesCompleted(account);
|
l.sendPendingMessagesCompleted(account);
|
||||||
}
|
}
|
||||||
if (anyFlagged)
|
if (lastFailure != null)
|
||||||
{
|
{
|
||||||
addErrorMessage(account, mApplication.getString(R.string.send_failure_subject),
|
|
||||||
mApplication.getString(R.string.send_failure_body_fmt, K9.ERROR_FOLDER_NAME));
|
|
||||||
|
|
||||||
NotificationManager notifMgr =
|
NotificationManager notifMgr = (NotificationManager)mApplication.getSystemService(Context.NOTIFICATION_SERVICE);
|
||||||
(NotificationManager)mApplication.getSystemService(Context.NOTIFICATION_SERVICE);
|
Notification notif = new Notification(R.drawable.stat_notify_email_generic, mApplication.getString(R.string.send_failure_subject), System.currentTimeMillis());
|
||||||
|
|
||||||
Notification notif = new Notification(R.drawable.stat_notify_email_generic,
|
Intent i = FolderList.actionHandleNotification(mApplication, account, account.getOutboxFolderName());
|
||||||
mApplication.getString(R.string.send_failure_subject), System.currentTimeMillis());
|
|
||||||
|
|
||||||
Intent i = MessageList.actionHandleFolderIntent(mApplication, account, account.getErrorFolderName());
|
|
||||||
|
|
||||||
PendingIntent pi = PendingIntent.getActivity(mApplication, 0, i, 0);
|
PendingIntent pi = PendingIntent.getActivity(mApplication, 0, i, 0);
|
||||||
|
|
||||||
notif.setLatestEventInfo(mApplication, mApplication.getString(R.string.send_failure_subject),
|
notif.setLatestEventInfo(mApplication, mApplication.getString(R.string.send_failure_subject), lastFailure.getMessage(), pi);
|
||||||
mApplication.getString(R.string.send_failure_body_abbrev, K9.ERROR_FOLDER_NAME), pi);
|
|
||||||
|
|
||||||
notif.flags |= Notification.FLAG_SHOW_LIGHTS;
|
notif.flags |= Notification.FLAG_SHOW_LIGHTS;
|
||||||
|
notif.flags |= Notification.FLAG_AUTO_CANCEL;
|
||||||
notif.ledARGB = K9.NOTIFICATION_LED_SENDING_FAILURE_COLOR;
|
notif.ledARGB = K9.NOTIFICATION_LED_SENDING_FAILURE_COLOR;
|
||||||
notif.ledOnMS = K9.NOTIFICATION_LED_FAST_ON_TIME;
|
notif.ledOnMS = K9.NOTIFICATION_LED_FAST_ON_TIME;
|
||||||
notif.ledOffMS = K9.NOTIFICATION_LED_FAST_OFF_TIME;
|
notif.ledOffMS = K9.NOTIFICATION_LED_FAST_OFF_TIME;
|
||||||
notifMgr.notify(-1000 - account.getAccountNumber(), notif);
|
notifMgr.notify(-1500 - account.getAccountNumber(), notif);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
|
Loading…
Reference in New Issue
Block a user