diff --git a/src/java/davmail/caldav/CaldavConnection.java b/src/java/davmail/caldav/CaldavConnection.java index eb95b276..f3c73fc2 100644 --- a/src/java/davmail/caldav/CaldavConnection.java +++ b/src/java/davmail/caldav/CaldavConnection.java @@ -155,8 +155,8 @@ public class CaldavConnection extends AbstractConnection { sendUnauthorized(); } else { decodeCredentials(headers.get("authorization")); - // authenticate only once - if (session == null) { + // authenticate only once, but check credentials + if (session == null || !session.checkCredentials(userName, password)) { try { session = ExchangeSessionFactory.getInstance(userName, password); } catch (DavMailAuthenticationException e) { diff --git a/src/java/davmail/exchange/ExchangeSession.java b/src/java/davmail/exchange/ExchangeSession.java index ef42f603..d024cb62 100644 --- a/src/java/davmail/exchange/ExchangeSession.java +++ b/src/java/davmail/exchange/ExchangeSession.java @@ -263,6 +263,18 @@ public class ExchangeSession { return isExpired; } + /** + * Compare credentials to current session credentials. + * + * @param userName user name + * @param password user password + * @return true if credentials match + */ + public boolean checkCredentials(String userName, String password) { + return userName != null && password != null + && userName.equals(poolKey.userName) && password.equals(poolKey.password); + } + /** * Test authentication mode : form based or basic. *