Fix exception when providing bad credentials
authorMathieu Baudier <mbaudier@argeo.org>
Mon, 23 Nov 2015 09:53:41 +0000 (09:53 +0000)
committerMathieu Baudier <mbaudier@argeo.org>
Mon, 23 Nov 2015 09:53:41 +0000 (09:53 +0000)
git-svn-id: https://svn.argeo.org/commons/trunk@8586 4cfe0d0a-d680-48aa-b62c-e0a02a3f76cc

org.argeo.cms/src/org/argeo/cms/widgets/auth/CmsLogin.java
org.argeo.cms/src/org/argeo/cms/widgets/auth/CmsLoginShell.java

index 91c28078ee5fb33ba3523718dc09c39359230053..298b3965b9fdc0bfc2b79ecaa6ec6f700de4e810 100644 (file)
@@ -20,7 +20,8 @@ import javax.security.auth.callback.UnsupportedCallbackException;
 import javax.security.auth.login.LoginContext;
 import javax.security.auth.login.LoginException;
 
-import org.argeo.cms.CmsException;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
 import org.argeo.cms.CmsMsg;
 import org.argeo.cms.CmsStyles;
 import org.argeo.cms.CmsView;
@@ -48,6 +49,8 @@ import org.eclipse.swt.widgets.Shell;
 import org.eclipse.swt.widgets.Text;
 
 public class CmsLogin implements CmsStyles, CallbackHandler {
+       private final static Log log = LogFactory.getLog(CmsLogin.class);
+
        private Composite parent;
        private Text usernameT, passwordT;
        private Composite credentialsBlock;
@@ -205,7 +208,7 @@ public class CmsLogin implements CmsStyles, CallbackHandler {
                // save already entered values
                String usernameStr = usernameT.getText();
                char[] pwd = passwordT.getTextChars();
-               
+
                for (Control child : parent.getChildren())
                        child.dispose();
                createContents(parent);
@@ -250,7 +253,7 @@ public class CmsLogin implements CmsStyles, CallbackHandler {
                return c;
        }
 
-       protected void login() {
+       protected boolean login() {
                Subject subject = cmsView.getSubject();
                LoginContext loginContext;
                try {
@@ -260,10 +263,13 @@ public class CmsLogin implements CmsStyles, CallbackHandler {
                        new LoginContext(LOGIN_CONTEXT_ANONYMOUS, subject).logout();
                        loginContext = new LoginContext(LOGIN_CONTEXT_USER, subject, this);
                        loginContext.login();
-               } catch (LoginException e1) {
-                       throw new CmsException("Cannot authenticate", e1);
+               } catch (LoginException e) {
+                       // throw new CmsException("Cannot authenticate", e1);
+                       log.error("Cannot login", e);
+                       return false;
                }
                cmsView.authChange(loginContext);
+               return true;
        }
 
        protected void logout() {
index 66dc5a673fbd0bfe37d762d5c0c06396a6e7ca24..a1ca970905361ffbb6926c37188286b89f79b84d 100644 (file)
@@ -30,9 +30,12 @@ public class CmsLoginShell extends CmsLogin {
        }
 
        @Override
-       protected void login() {
-               super.login();
-               closeShell();
+       protected boolean login() {
+               try {
+                       return super.login();
+               } finally {
+                       closeShell();
+               }
        }
 
        @Override