diff options
author | Matt A. Tobin <email@mattatobin.com> | 2019-11-10 22:13:47 -0500 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2019-11-10 22:13:47 -0500 |
commit | 43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9 (patch) | |
tree | 20e6fa0ccbd7b0e7deb7c057f33fe51398ef7d3f /mailnews/imap/src/nsImapServerResponseParser.cpp | |
parent | 97826b14c7558748543b1558e5d2a37652cb2bba (diff) | |
download | UXP-43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9.tar UXP-43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9.tar.gz UXP-43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9.tar.lz UXP-43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9.tar.xz UXP-43919ab8c75d6cd32ff3fdc4b3e01cdfb10178b9.zip |
Bug 344205 - React correctly to NO/BAD tagged response to imap IDLE.
User is notifified and IDLE state is not entered if IDLE command fails.
Tag #1273
Diffstat (limited to 'mailnews/imap/src/nsImapServerResponseParser.cpp')
-rw-r--r-- | mailnews/imap/src/nsImapServerResponseParser.cpp | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/mailnews/imap/src/nsImapServerResponseParser.cpp b/mailnews/imap/src/nsImapServerResponseParser.cpp index d37231ab9..b4c94ca94 100644 --- a/mailnews/imap/src/nsImapServerResponseParser.cpp +++ b/mailnews/imap/src/nsImapServerResponseParser.cpp @@ -188,6 +188,9 @@ void nsImapServerResponseParser::ParseIMAPServerResponse(const char *aCurrentCom if (commandToken && ContinueParse()) PreProcessCommandToken(commandToken, aCurrentCommand); + // For checking expected response to IDLE command below. + bool untagged = false; + if (ContinueParse()) { ResetLexAnalyzer(); @@ -212,6 +215,7 @@ void nsImapServerResponseParser::ParseIMAPServerResponse(const char *aCurrentCom else if (!inIdle && !fCurrentCommandFailed && !aGreetingWithCapability) AdvanceToNextToken(); } + untagged = true; } // command continuation request [RFC3501, Sec. 7.5] @@ -244,7 +248,29 @@ void nsImapServerResponseParser::ParseIMAPServerResponse(const char *aCurrentCom // fWaitingForMoreClientInput so we don't lose that information.... if ((fNextToken && *fNextToken == '+') || inIdle) { - fWaitingForMoreClientInput = true; + if (inIdle && !((fNextToken && *fNextToken == '+') || untagged)) + { + // IDLE "response" + will not be "eaten" as described above since it + // is not an authentication response. So if IDLE response does not + // begin with '+' (continuation) or '*' (untagged and probably useful + // response) then something is wrong and it is probably a tagged + // NO or BAD due to transient error or bad configuration of the server. + if (!PL_strcmp(fCurrentCommandTag, fNextToken)) + { + response_tagged(); + } + else + { + // Expected tag doesn't match the received tag. Not good, start over. + response_fatal(); + } + // Show an alert notication containing the server response to bad IDLE. + fServerConnection.AlertUserEventFromServer(fCurrentLine, true); + } + else + { + fWaitingForMoreClientInput = true; + } } // if we aren't still waiting for more input.... else if (!fWaitingForMoreClientInput && !aGreetingWithCapability) @@ -262,7 +288,7 @@ void nsImapServerResponseParser::ParseIMAPServerResponse(const char *aCurrentCom // a failed command may change the eIMAPstate ProcessBadCommand(commandToken); if (fReportingErrors && !aIgnoreBadAndNOResponses) - fServerConnection.AlertUserEventFromServer(fCurrentLine); + fServerConnection.AlertUserEventFromServer(fCurrentLine, false); } } } |