From e11f48115c93229700b7504450b324bdcf644fb2 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Mon, 17 Oct 2011 17:46:27 -0400
Subject: [PATCH] Handle the earliest tags from the Linux kernel repository (issue 25)

---
 src/com/gitblit/client/EditUserDialog.java |   71 +++++++++++++++++++++--------------
 1 files changed, 43 insertions(+), 28 deletions(-)

diff --git a/src/com/gitblit/client/EditUserDialog.java b/src/com/gitblit/client/EditUserDialog.java
index 5fce8c5..c60b2b2 100644
--- a/src/com/gitblit/client/EditUserDialog.java
+++ b/src/com/gitblit/client/EditUserDialog.java
@@ -26,7 +26,9 @@
 import java.text.MessageFormat;
 import java.util.ArrayList;
 import java.util.Arrays;
+import java.util.HashSet;
 import java.util.List;
+import java.util.Set;
 
 import javax.swing.ImageIcon;
 import javax.swing.JButton;
@@ -54,6 +56,8 @@
 
 	private final IStoredSettings settings;
 
+	private boolean isCreate;
+	
 	private boolean canceled = true;
 
 	private JTextField usernameField;
@@ -68,18 +72,23 @@
 
 	private JPalette<String> repositoryPalette;
 
+	private Set<String> usernames;
+
 	public EditUserDialog(IStoredSettings settings) {
 		this(new UserModel(""), settings);
-		setTitle("Create User");
+		this.isCreate = true;
+		setTitle(Translation.get("gb.newUser"));		
 	}
 
 	public EditUserDialog(UserModel anUser, IStoredSettings settings) {
 		super();
 		this.user = new UserModel("");
 		this.settings = settings;
+		this.usernames = new HashSet<String>();
+		this.isCreate = false;
 		initialize(anUser);
 		setModal(true);
-		setTitle("Edit User: " + anUser.username);
+		setTitle(Translation.get("gb.edit") + ": " + anUser.username);
 		setIconImage(new ImageIcon(getClass().getResource("/gitblt-favicon.png")).getImage());
 	}
 
@@ -88,24 +97,26 @@
 		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);
+		canAdminCheckbox = new JCheckBox(Translation.get("gb.canAdminDescription"), anUser.canAdmin);
 		notFederatedCheckbox = new JCheckBox(
-				"block federated Gitblit instances from pulling this account",
+				Translation.get("gb.excludeFromFederationDescription"),
 				anUser.excludeFromFederation);
 
 		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.canAdmin"), canAdminCheckbox));
+		fieldsPanel.add(newFieldPanel(Translation.get("gb.excludeFromFederation"),
+				notFederatedCheckbox));
 
 		repositoryPalette = new JPalette<String>();
 		JPanel panel = new JPanel(new BorderLayout());
 		panel.add(fieldsPanel, BorderLayout.NORTH);
-		panel.add(newFieldPanel("restricted repositories", repositoryPalette), BorderLayout.CENTER);
+		panel.add(newFieldPanel(Translation.get("gb.restrictedRepositories"), repositoryPalette),
+				BorderLayout.CENTER);
 
-		JButton createButton = new JButton("Save");
+		JButton createButton = new JButton(Translation.get("gb.save"));
 		createButton.addActionListener(new ActionListener() {
 			public void actionPerformed(ActionEvent event) {
 				if (validateFields()) {
@@ -115,7 +126,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;
@@ -159,20 +170,17 @@
 	private boolean validateFields() {
 		String uname = usernameField.getText();
 		if (StringUtils.isEmpty(uname)) {
-			showValidationError("Please enter a username!");
+			error("Please enter a username!");
 			return false;
 		}
 
-		// 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;
-		// }
-		// }
+		// verify username uniqueness on create
+		if (isCreate) {
+			if (usernames.contains(uname.toLowerCase())) {
+				error(MessageFormat.format("Username ''{0}'' is unavailable.", uname));
+				return false;
+			}
+		}
 
 		int minLength = settings.getInteger(Keys.realm.minPasswordLength, 5);
 		if (minLength < 4) {
@@ -180,17 +188,17 @@
 		}
 		char[] pw = passwordField.getPassword();
 		if (pw == null || pw.length < minLength) {
-			showValidationError(MessageFormat.format(
+			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!");
+			error("Please confirm the password!");
 			return false;
 		}
 		if (!Arrays.equals(pw, cpw)) {
-			showValidationError("Passwords do not match!");
+			error("Passwords do not match!");
 			return false;
 		}
 		user.username = uname;
@@ -209,11 +217,18 @@
 		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) {
 		List<String> restricted = new ArrayList<String>();
 		for (RepositoryModel repo : repositories) {

--
Gitblit v1.9.1