fix STARTTLS handling, sr=mscott 325379

This commit is contained in:
bienvenu%nventure.com 2006-07-18 02:42:07 +00:00
parent b0183d8a91
commit 551a505080
3 changed files with 32 additions and 4 deletions

View File

@ -190,6 +190,10 @@ NS_IMETHODIMP nsImapIncomingServer::SetKey(const char * aKey) // override nsMsg
if (otherUsersNamespace && PL_strlen(otherUsersNamespace))
hostSession->SetNamespaceFromPrefForHost(aKey, otherUsersNamespace,
kOtherUsersNamespace);
PRInt32 capability;
rv = GetCapabilityPref(&capability);
NS_ENSURE_SUCCESS(rv, rv);
hostSession->SetCapabilityForHost(aKey, capability);
return rv;
}

View File

@ -723,7 +723,6 @@ nsresult nsImapProtocol::SetupWithUrl(nsIURI * aURL, nsISupports* aConsumer)
PRUint32 capability = kCapabilityUndefined;
m_hostSessionList->GetCapabilityForHost(GetImapServerKey(), capability);
GetServerStateParser().SetCapabilityFlag(capability);
PRBool shuttingDown;
(void) server->GetUseSecAuth(&m_useSecAuth);
@ -798,10 +797,13 @@ nsresult nsImapProtocol::SetupWithUrl(nsIURI * aURL, nsISupports* aConsumer)
if (NS_FAILED(rv) && m_socketType == nsIMsgIncomingServer::tryTLS)
{
connectionType = nsnull;
m_socketType = nsIMsgIncomingServer::defaultSocket;
rv = socketService->CreateTransport(&connectionType, connectionType != nsnull,
*socketHost, socketPort, proxyInfo,
getter_AddRefs(m_transport));
}
// remember so we can know whether we can issue a start tls or not...
m_connectionType = connectionType;
if (m_transport && m_mockChannel)
{
// Ensure that the socket can get the notification callbacks
@ -1370,7 +1372,8 @@ PRBool nsImapProtocol::ProcessCurrentURL()
}
else
{
if ((m_socketType == nsIMsgIncomingServer::tryTLS
if (m_connectionType.Equals("starttls")
&& (m_socketType == nsIMsgIncomingServer::tryTLS
&& (GetServerStateParser().GetCapabilityFlag() & kHasStartTLSCapability))
|| m_socketType == nsIMsgIncomingServer::alwaysUseTLS)
{
@ -1391,7 +1394,20 @@ PRBool nsImapProtocol::ProcessCurrentURL()
{
rv = sslControl->StartTLS();
if (NS_SUCCEEDED(rv))
{
Capability();
PRInt32 capabilityFlag = GetServerStateParser().GetCapabilityFlag();
// Courier imap doesn't return STARTTLS capability if we've done
// a STARTTLS! But we need to remember this capability so we'll
// try to use STARTTLS next time.
if (!(capabilityFlag & kHasStartTLSCapability))
{
capabilityFlag |= kHasStartTLSCapability;
GetServerStateParser().SetCapabilityFlag(capabilityFlag);
m_hostSessionList->SetCapabilityForHost(GetImapServerKey(), capabilityFlag);
CommitCapability();
}
}
}
}
if (NS_FAILED(rv))
@ -1412,7 +1428,14 @@ PRBool nsImapProtocol::ProcessCurrentURL()
m_transport->Close(rv);
}
}
// in this case, we didn't know the server supported TLS when
// we created the socket, so we're going to retry with
// STARTTLS.
else if (m_socketType == nsIMsgIncomingServer::tryTLS
&& (GetServerStateParser().GetCapabilityFlag() & kHasStartTLSCapability))
{
return RetryUrl();
}
logonFailed = !TryToLogon();
}
} // if death signal not received

View File

@ -367,7 +367,8 @@ private:
PRBool m_imapThreadIsRunning;
void ImapThreadMainLoop(void);
PRInt32 m_connectionStatus;
nsCString m_connectionType;
PRBool m_nextUrlReadyToRun;
nsWeakPtr m_server;