blob: 735b1a6740cf632684f385a729dba473e5939301 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2012, 2013 Tasktop Technologies and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* https://www.eclipse.org/legal/epl-2.0
*
* SPDX-License-Identifier: EPL-2.0
*
* Tasktop Technologies - initial API and implementation
*******************************************************************************/
package org.eclipse.mylyn.internal.commons.repositories.ui.auth;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.jface.window.Window;
import org.eclipse.mylyn.commons.repositories.core.auth.AuthenticationRequest;
import org.eclipse.mylyn.commons.repositories.core.auth.AuthenticationType;
import org.eclipse.mylyn.commons.repositories.core.auth.UserAuthenticationRequest;
import org.eclipse.mylyn.commons.repositories.core.auth.UserCredentials;
import org.eclipse.mylyn.commons.ui.dialogs.CredentialsDialog;
import org.eclipse.mylyn.commons.ui.dialogs.CredentialsDialog.Mode;
import org.eclipse.osgi.util.NLS;
import org.eclipse.swt.widgets.Shell;
/**
* @author Steffen Pingel
*/
public class UserCredentialsProviderUi extends AbstractCredentialsProviderUi<UserCredentials> {
private UserCredentials credentials;
@Override
public UserCredentials getCredentials() {
return credentials;
}
@Override
public IStatus open(Shell shell, AuthenticationRequest<AuthenticationType<UserCredentials>> request) {
CredentialsDialog dialog = new CredentialsDialog(shell, Mode.USER);
UserCredentials oldCredentials = request.getLocation().getCredentials(request.getAuthenticationType());
if (oldCredentials != null) {
dialog.setUsername(oldCredentials.getUserName());
dialog.setDomain((oldCredentials.getDomain() != null) ? oldCredentials.getDomain() : ""); //$NON-NLS-1$
dialog.setPassword(oldCredentials.getPassword());
dialog.setSavePassword(oldCredentials.getSavePassword());
}
if (request instanceof UserAuthenticationRequest) {
dialog.setNeedsDomain(((UserAuthenticationRequest) request).needsDomain());
}
dialog.create();
dialog.setTitle(NLS.bind(Messages.UserCredentialsProviderUi_Credentials_for, request.getLocation().getLabel()));
// caller provided message takes precedence
if (request.getMessage() != null) {
dialog.setMessage(request.getMessage());
} else {
dialog.setMessage(getDefaultMessage(request));
}
int resultCode = dialog.open();
if (resultCode == Window.OK) {
credentials = new UserCredentials(dialog.getUserName(), dialog.getPassword(), dialog.getDomain(),
dialog.getSavePassword());
request.getLocation().setCredentials(request.getAuthenticationType(), credentials);
if (request.getAuthenticationType() == AuthenticationType.REPOSITORY) {
request.getLocation().setUserName(dialog.getUserName());
}
return Status.OK_STATUS;
} else {
return Status.CANCEL_STATUS;
}
}
private String getDefaultMessage(AuthenticationRequest<AuthenticationType<UserCredentials>> request) {
AuthenticationType<UserCredentials> authType = request.getAuthenticationType();
if (AuthenticationType.REPOSITORY == authType) {
return Messages.UserCredentialsProviderUi_Enter_repository_credentials;
} else if (AuthenticationType.HTTP == authType) {
return Messages.UserCredentialsProviderUi_Enter_HTTP_credentials;
} else if (AuthenticationType.PROXY == authType) {
return Messages.UserCredentialsProviderUi_Enter_proxy_credentials;
}
return null;
}
}