From a5e762ba4ab82f0c6ef71d853c5103f19bbf8e22 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 11 Oct 2012 08:10:20 -0400 Subject: [PATCH] Tweak canFork description --- src/com/gitblit/client/EditUserDialog.java | 250 ++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 191 insertions(+), 59 deletions(-) diff --git a/src/com/gitblit/client/EditUserDialog.java b/src/com/gitblit/client/EditUserDialog.java index 5fce8c5..4ef036e 100644 --- a/src/com/gitblit/client/EditUserDialog.java +++ b/src/com/gitblit/client/EditUserDialog.java @@ -23,10 +23,13 @@ import java.awt.Insets; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; +import java.awt.event.KeyEvent; import java.text.MessageFormat; import java.util.ArrayList; -import java.util.Arrays; +import java.util.Collections; +import java.util.HashSet; import java.util.List; +import java.util.Set; import javax.swing.ImageIcon; import javax.swing.JButton; @@ -37,12 +40,16 @@ import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JPasswordField; +import javax.swing.JRootPane; +import javax.swing.JTabbedPane; import javax.swing.JTextField; +import javax.swing.KeyStroke; import com.gitblit.Constants.AccessRestrictionType; -import com.gitblit.IStoredSettings; import com.gitblit.Keys; import com.gitblit.models.RepositoryModel; +import com.gitblit.models.ServerSettings; +import com.gitblit.models.TeamModel; import com.gitblit.models.UserModel; import com.gitblit.utils.StringUtils; @@ -50,9 +57,13 @@ private static final long serialVersionUID = 1L; + private final String username; + private final UserModel user; - private final IStoredSettings settings; + private final ServerSettings settings; + + private boolean isCreate; private boolean canceled = true; @@ -61,51 +72,126 @@ private JPasswordField passwordField; private JPasswordField confirmPasswordField; + + private JTextField displayNameField; + + private JTextField emailAddressField; private JCheckBox canAdminCheckbox; + + private JCheckBox canForkCheckbox; + + private JCheckBox canCreateCheckbox; private JCheckBox notFederatedCheckbox; private JPalette<String> repositoryPalette; - public EditUserDialog(IStoredSettings settings) { - this(new UserModel(""), settings); - setTitle("Create User"); + private JPalette<TeamModel> teamsPalette; + + private Set<String> usernames; + + public EditUserDialog(int protocolVersion, ServerSettings settings) { + this(protocolVersion, new UserModel(""), settings); + this.isCreate = true; + setTitle(Translation.get("gb.newUser")); } - public EditUserDialog(UserModel anUser, IStoredSettings settings) { + public EditUserDialog(int protocolVersion, UserModel anUser, ServerSettings settings) { super(); + this.username = anUser.username; this.user = new UserModel(""); this.settings = settings; - initialize(anUser); + this.usernames = new HashSet<String>(); + this.isCreate = false; + initialize(protocolVersion, anUser); setModal(true); - setTitle("Edit User: " + anUser.username); + setTitle(Translation.get("gb.edit") + ": " + anUser.username); setIconImage(new ImageIcon(getClass().getResource("/gitblt-favicon.png")).getImage()); } - private void initialize(UserModel anUser) { + @Override + protected JRootPane createRootPane() { + KeyStroke stroke = KeyStroke.getKeyStroke(KeyEvent.VK_ESCAPE, 0); + JRootPane rootPane = new JRootPane(); + rootPane.registerKeyboardAction(new ActionListener() { + public void actionPerformed(ActionEvent actionEvent) { + setVisible(false); + } + }, stroke, JComponent.WHEN_IN_FOCUSED_WINDOW); + return rootPane; + } + + private void initialize(int protocolVersion, UserModel anUser) { usernameField = new JTextField(anUser.username == null ? "" : anUser.username, 25); passwordField = new JPasswordField(anUser.password == null ? "" : anUser.password, 25); confirmPasswordField = new JPasswordField(anUser.password == null ? "" : anUser.password, 25); - canAdminCheckbox = new JCheckBox("can administer Gitblit server", anUser.canAdmin); + displayNameField = new JTextField(anUser.displayName == null ? "" : anUser.displayName, 25); + emailAddressField = new JTextField(anUser.emailAddress == null ? "" : anUser.emailAddress, 25); + canAdminCheckbox = new JCheckBox(Translation.get("gb.canAdminDescription"), anUser.canAdmin); + canForkCheckbox = new JCheckBox(Translation.get("gb.canForkDescription"), anUser.canFork); + canCreateCheckbox = new JCheckBox(Translation.get("gb.canCreateDescription"), anUser.canCreate); notFederatedCheckbox = new JCheckBox( - "block federated Gitblit instances from pulling this account", + Translation.get("gb.excludeFromFederationDescription"), anUser.excludeFromFederation); + + // credentials are optionally controlled by 3rd-party authentication + usernameField.setEnabled(settings.supportsCredentialChanges); + passwordField.setEnabled(settings.supportsCredentialChanges); + confirmPasswordField.setEnabled(settings.supportsCredentialChanges); + + displayNameField.setEnabled(settings.supportsDisplayNameChanges); + emailAddressField.setEnabled(settings.supportsEmailAddressChanges); JPanel fieldsPanel = new JPanel(new GridLayout(0, 1)); - fieldsPanel.add(newFieldPanel("username", usernameField)); - fieldsPanel.add(newFieldPanel("password", passwordField)); - fieldsPanel.add(newFieldPanel("confirm password", confirmPasswordField)); - fieldsPanel.add(newFieldPanel("can admin", canAdminCheckbox)); - fieldsPanel.add(newFieldPanel("exclude from federation", notFederatedCheckbox)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.username"), usernameField)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.password"), passwordField)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.confirmPassword"), confirmPasswordField)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.displayName"), displayNameField)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.emailAddress"), emailAddressField)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.canAdmin"), canAdminCheckbox)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.canFork"), canForkCheckbox)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.canCreate"), canCreateCheckbox)); + fieldsPanel.add(newFieldPanel(Translation.get("gb.excludeFromFederation"), + notFederatedCheckbox)); + final Insets _insets = new Insets(5, 5, 5, 5); repositoryPalette = new JPalette<String>(); - JPanel panel = new JPanel(new BorderLayout()); - panel.add(fieldsPanel, BorderLayout.NORTH); - panel.add(newFieldPanel("restricted repositories", repositoryPalette), BorderLayout.CENTER); + teamsPalette = new JPalette<TeamModel>(); + teamsPalette.setEnabled(settings.supportsTeamMembershipChanges); - JButton createButton = new JButton("Save"); + JPanel fieldsPanelTop = new JPanel(new BorderLayout()); + fieldsPanelTop.add(fieldsPanel, BorderLayout.NORTH); + + JPanel repositoriesPanel = new JPanel(new BorderLayout()) { + + private static final long serialVersionUID = 1L; + + public Insets getInsets() { + return _insets; + } + }; + repositoriesPanel.add(repositoryPalette, BorderLayout.CENTER); + + JPanel teamsPanel = new JPanel(new BorderLayout()) { + + private static final long serialVersionUID = 1L; + + public Insets getInsets() { + return _insets; + } + }; + teamsPanel.add(teamsPalette, BorderLayout.CENTER); + + JTabbedPane panel = new JTabbedPane(JTabbedPane.TOP); + panel.addTab(Translation.get("gb.general"), fieldsPanelTop); + if (protocolVersion > 1) { + panel.addTab(Translation.get("gb.teamMemberships"), teamsPanel); + } + panel.addTab(Translation.get("gb.restrictedRepositories"), repositoriesPanel); + + JButton createButton = new JButton(Translation.get("gb.save")); createButton.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent event) { if (validateFields()) { @@ -115,7 +201,7 @@ } }); - JButton cancelButton = new JButton("Cancel"); + JButton cancelButton = new JButton(Translation.get("gb.cancel")); cancelButton.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent event) { canceled = true; @@ -127,7 +213,6 @@ controls.add(cancelButton); controls.add(createButton); - final Insets _insets = new Insets(5, 5, 5, 5); JPanel centerPanel = new JPanel(new BorderLayout(5, 5)) { private static final long serialVersionUID = 1L; @@ -143,7 +228,6 @@ getContentPane().setLayout(new BorderLayout(5, 5)); getContentPane().add(centerPanel, BorderLayout.CENTER); pack(); - setLocationRelativeTo(null); } private JPanel newFieldPanel(String label, JComponent comp) { @@ -157,61 +241,101 @@ } private boolean validateFields() { - String uname = usernameField.getText(); - if (StringUtils.isEmpty(uname)) { - showValidationError("Please enter a username!"); + if (StringUtils.isEmpty(usernameField.getText())) { + error("Please enter a username!"); return false; } + String uname = usernameField.getText().toLowerCase(); + boolean rename = false; + // verify username uniqueness on create + if (isCreate) { + if (usernames.contains(uname)) { + error(MessageFormat.format("Username ''{0}'' is unavailable.", uname)); + return false; + } + } else { + // check rename collision + rename = !StringUtils.isEmpty(username) && !username.equalsIgnoreCase(uname); + if (rename) { + if (usernames.contains(uname)) { + error(MessageFormat.format( + "Failed to rename ''{0}'' because ''{1}'' already exists.", username, + uname)); + return false; + } + } + } + user.username = uname; - // TODO verify username uniqueness on create - - // if (isCreate) { - // UserModel model = GitBlit.self().getUserModel(username); - // if (model != null) { - // error(MessageFormat.format("Username ''{0}'' is unavailable.", - // username)); - // return; - // } - // } - - int minLength = settings.getInteger(Keys.realm.minPasswordLength, 5); + int minLength = settings.get(Keys.realm.minPasswordLength).getInteger(5); if (minLength < 4) { minLength = 4; } - char[] pw = passwordField.getPassword(); - if (pw == null || pw.length < minLength) { - showValidationError(MessageFormat.format( - "Password is too short. Minimum length is {0} characters.", minLength)); + + String password = new String(passwordField.getPassword()); + if (StringUtils.isEmpty(password) || password.length() < minLength) { + error(MessageFormat.format("Password is too short. Minimum length is {0} characters.", + minLength)); return false; } - char[] cpw = confirmPasswordField.getPassword(); - if (cpw == null || cpw.length != pw.length) { - showValidationError("Please confirm the password!"); + if (!password.toUpperCase().startsWith(StringUtils.MD5_TYPE) + && !password.toUpperCase().startsWith(StringUtils.COMBINED_MD5_TYPE)) { + String cpw = new String(confirmPasswordField.getPassword()); + if (cpw == null || cpw.length() != password.length()) { + error("Please confirm the password!"); + return false; + } + if (!password.equals(cpw)) { + error("Passwords do not match!"); + return false; + } + + String type = settings.get(Keys.realm.passwordStorage).getString("md5"); + if (type.equalsIgnoreCase("md5")) { + // store MD5 digest of password + user.password = StringUtils.MD5_TYPE + StringUtils.getMD5(password); + } else if (type.equalsIgnoreCase("combined-md5")) { + // store MD5 digest of username+password + user.password = StringUtils.COMBINED_MD5_TYPE + + StringUtils.getMD5(user.username + password); + } else { + // plain-text password + user.password = password; + } + } else if (rename && password.toUpperCase().startsWith(StringUtils.COMBINED_MD5_TYPE)) { + error("Gitblit is configured for combined-md5 password hashing. You must enter a new password on account rename."); return false; - } - if (!Arrays.equals(pw, cpw)) { - showValidationError("Passwords do not match!"); - return false; - } - user.username = uname; - String type = settings.getString(Keys.realm.passwordStorage, "md5"); - if (type.equalsIgnoreCase("md5")) { - // store MD5 digest of password - user.password = StringUtils.MD5_TYPE + StringUtils.getMD5(new String(pw)); } else { - user.password = new String(pw); + // no change in password + user.password = password; } + + user.displayName = displayNameField.getText().trim(); + user.emailAddress = emailAddressField.getText().trim(); + user.canAdmin = canAdminCheckbox.isSelected(); + user.canFork = canForkCheckbox.isSelected(); + user.canCreate = canCreateCheckbox.isSelected(); user.excludeFromFederation = notFederatedCheckbox.isSelected(); user.repositories.clear(); user.repositories.addAll(repositoryPalette.getSelections()); + + user.teams.clear(); + user.teams.addAll(teamsPalette.getSelections()); return true; } - private void showValidationError(String message) { - JOptionPane.showMessageDialog(EditUserDialog.this, message, "Validation Error", + private void error(String message) { + JOptionPane.showMessageDialog(EditUserDialog.this, message, Translation.get("gb.error"), JOptionPane.ERROR_MESSAGE); + } + + public void setUsers(List<UserModel> users) { + usernames.clear(); + for (UserModel user : users) { + usernames.add(user.username.toLowerCase()); + } } public void setRepositories(List<RepositoryModel> repositories, List<String> selected) { @@ -228,6 +352,14 @@ repositoryPalette.setObjects(restricted, selected); } + public void setTeams(List<TeamModel> teams, List<TeamModel> selected) { + Collections.sort(teams); + if (selected != null) { + Collections.sort(selected); + } + teamsPalette.setObjects(teams, selected); + } + public UserModel getUser() { if (canceled) { return null; -- Gitblit v1.9.1