import java.util.List;
import java.util.Locale;
+import javax.security.auth.Subject;
import javax.security.auth.callback.Callback;
import javax.security.auth.callback.CallbackHandler;
import javax.security.auth.callback.LanguageCallback;
import javax.security.auth.callback.NameCallback;
import javax.security.auth.callback.PasswordCallback;
import javax.security.auth.callback.UnsupportedCallbackException;
-import javax.security.auth.login.FailedLoginException;
import javax.security.auth.login.LoginContext;
import javax.security.auth.login.LoginException;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.argeo.cms.CmsMsg;
-import org.argeo.cms.auth.CurrentUser;
import org.argeo.cms.auth.HttpRequestCallback;
import org.argeo.cms.i18n.LocaleUtils;
import org.argeo.cms.ui.CmsStyles;
private final CmsView cmsView;
+ // optional subject to be set explicitly
+ private Subject subject = null;
+
public CmsLogin(CmsView cmsView) {
this.cmsView = cmsView;
defaultLocale = Activator.getNodeState().getDefaultLocale();
}
protected boolean isAnonymous() {
- return CurrentUser.isAnonymous(cmsView.getLoginContext().getSubject());
+ return cmsView.isAnonymous();
}
public final void createUi(Composite parent) {
Integer textWidth = 120;
CmsUtils.style(parent, CMS_USER_MENU);
-
// new Label(this, SWT.NONE).setText(CmsMsg.username.lead());
usernameT = new Text(credentialsBlock, SWT.BORDER);
usernameT.setMessage(username.lead(locale));
}
/**
- * To be overridden in order to provide custome login button and other
- * links.
+ * To be overridden in order to provide custom login button and other links.
*/
protected void extendsCredentialsBlock(Composite credentialsBlock, Locale selectedLocale,
SelectionListener loginSelectionListener) {
}
protected boolean login() {
+ // TODO use CmsVie in order to retrieve subject?
// Subject subject = cmsView.getLoginContext().getSubject();
- LoginContext loginContext = cmsView.getLoginContext();
+ // LoginContext loginContext = cmsView.getLoginContext();
try {
//
// LOGIN
//
- loginContext.logout();
- loginContext = new LoginContext(NodeConstants.LOGIN_CONTEXT_USER, this);
+ // loginContext.logout();
+ LoginContext loginContext;
+ if (subject == null)
+ loginContext = new LoginContext(NodeConstants.LOGIN_CONTEXT_USER, this);
+ else
+ loginContext = new LoginContext(NodeConstants.LOGIN_CONTEXT_USER, subject, this);
loginContext.login();
- } catch (FailedLoginException e) {
- log.warn(e.getMessage());
+ cmsView.authChange(loginContext);
+ return true;
+ } catch (LoginException e) {
+ if (log.isTraceEnabled())
+ log.warn("Login failed: " + e.getMessage(), e);
+ else
+ log.warn("Login failed: " + e.getMessage());
+
try {
Thread.sleep(3000);
} catch (InterruptedException e2) {
}
// ErrorFeedback.show("Login failed", e);
return false;
- } catch (LoginException e) {
- log.error("Cannot login", e);
- return false;
}
- cmsView.authChange(loginContext);
- return true;
+ // catch (LoginException e) {
+ // log.error("Cannot login", e);
+ // return false;
+ // }
}
protected void logout() {
((NameCallback) callback).setName(usernameT.getText());
else if (callback instanceof PasswordCallback && passwordT != null)
((PasswordCallback) callback).setPassword(passwordT.getTextChars());
- else if (callback instanceof HttpRequestCallback){
+ else if (callback instanceof HttpRequestCallback) {
((HttpRequestCallback) callback).setRequest(UiContext.getHttpRequest());
((HttpRequestCallback) callback).setResponse(UiContext.getHttpResponse());
+ } else if (callback instanceof LanguageCallback) {
+ Locale toUse = null;
+ if (localeChoice != null)
+ toUse = localeChoice.getSelectedLocale();
+ else if (defaultLocale != null)
+ toUse = defaultLocale;
+
+ if (toUse != null) {
+ ((LanguageCallback) callback).setLocale(toUse);
+ UiContext.setLocale(toUse);
+ }
+
}
- else if (callback instanceof LanguageCallback && localeChoice != null)
- ((LanguageCallback) callback).setLocale(localeChoice.getSelectedLocale());
}
}
+ public void setSubject(Subject subject) {
+ this.subject = subject;
+ }
+
}