From 13417cf9c6eec555b51da49742e47939d2f5715b Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Fri, 19 Oct 2012 22:47:33 -0400
Subject: [PATCH] Exclude submodules from zip downloads (issue 151)

---
 src/com/gitblit/client/RepositoriesPanel.java |   41 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 40 insertions(+), 1 deletions(-)

diff --git a/src/com/gitblit/client/RepositoriesPanel.java b/src/com/gitblit/client/RepositoriesPanel.java
index 685a70a..54158e8 100644
--- a/src/com/gitblit/client/RepositoriesPanel.java
+++ b/src/com/gitblit/client/RepositoriesPanel.java
@@ -29,6 +29,7 @@
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
+import java.util.Map;
 
 import javax.swing.JButton;
 import javax.swing.JLabel;
@@ -47,6 +48,7 @@
 
 import com.gitblit.Constants;
 import com.gitblit.Constants.RpcRequest;
+import com.gitblit.Keys;
 import com.gitblit.models.FeedModel;
 import com.gitblit.models.RepositoryModel;
 import com.gitblit.utils.StringUtils;
@@ -80,6 +82,8 @@
 
 	private JTextField filterTextfield;
 
+	private JButton clearCache;
+
 	public RepositoriesPanel(GitblitClient gitblit) {
 		super();
 		this.gitblit = gitblit;
@@ -101,6 +105,13 @@
 		refreshRepositories.addActionListener(new ActionListener() {
 			public void actionPerformed(ActionEvent e) {
 				refreshRepositories();
+			}
+		});
+		
+		clearCache = new JButton(Translation.get("gb.clearCache"));
+		clearCache.addActionListener(new ActionListener() {
+			public void actionPerformed(ActionEvent e) {
+				clearCache();
 			}
 		});
 
@@ -240,6 +251,7 @@
 		repositoryTablePanel.add(new JScrollPane(table), BorderLayout.CENTER);
 
 		JPanel repositoryControls = new JPanel(new FlowLayout(FlowLayout.CENTER, Utils.MARGIN, 0));
+		repositoryControls.add(clearCache);
 		repositoryControls.add(refreshRepositories);
 		repositoryControls.add(browseRepository);
 		repositoryControls.add(createRepository);
@@ -250,7 +262,7 @@
 		repositoryControls.add(searchRepository);
 
 		setLayout(new BorderLayout(Utils.MARGIN, Utils.MARGIN));
-		header = new HeaderPanel(Translation.get("gb.repositories"), "gitweb-favicon.png");
+		header = new HeaderPanel(Translation.get("gb.repositories"), "git-orange-16x16.png");
 		add(header, BorderLayout.NORTH);
 		add(repositoryTablePanel, BorderLayout.CENTER);
 		add(repositoryControls, BorderLayout.SOUTH);
@@ -283,6 +295,7 @@
 	protected abstract void updateTeamsTable();
 
 	protected void disableManagement() {
+		clearCache.setVisible(false);
 		createRepository.setVisible(false);
 		editRepository.setVisible(false);
 		delRepository.setVisible(false);
@@ -346,6 +359,26 @@
 		};
 		worker.execute();
 	}
+	
+	protected void clearCache() {
+		GitblitWorker worker = new GitblitWorker(RepositoriesPanel.this,
+				RpcRequest.CLEAR_REPOSITORY_CACHE) {
+			@Override
+			protected Boolean doRequest() throws IOException {
+				if (gitblit.clearRepositoryCache()) {
+					gitblit.refreshRepositories();
+					return true;
+				}
+				return false;
+			}
+
+			@Override
+			protected void onSuccess() {
+				updateTable(false);
+			}
+		};
+		worker.execute();
+	}
 
 	/**
 	 * Displays the create repository dialog and fires a SwingWorker to update
@@ -355,6 +388,8 @@
 	protected void createRepository() {
 		EditRepositoryDialog dialog = new EditRepositoryDialog(gitblit.getProtocolVersion());
 		dialog.setLocationRelativeTo(RepositoriesPanel.this);
+		dialog.setAccessRestriction(gitblit.getDefaultAccessRestriction());
+		dialog.setAuthorizationControl(gitblit.getDefaultAuthorizationControl());
 		dialog.setUsers(null, gitblit.getUsernames(), null);
 		dialog.setTeams(gitblit.getTeamnames(), null);
 		dialog.setRepositories(gitblit.getRepositories());
@@ -430,6 +465,10 @@
 				gitblit.getPreReceiveScriptsInherited(repository), repository.preReceiveScripts);
 		dialog.setPostReceiveScripts(gitblit.getPostReceiveScriptsUnused(repository),
 				gitblit.getPostReceiveScriptsInherited(repository), repository.postReceiveScripts);
+		if (gitblit.getSettings().hasKey(Keys.groovy.customFields)) {
+			Map<String, String> map = gitblit.getSettings().get(Keys.groovy.customFields).getMap();
+			dialog.setCustomFields(repository, map);
+		}
 		dialog.setVisible(true);
 		final RepositoryModel revisedRepository = dialog.getRepository();
 		final List<String> permittedUsers = dialog.getPermittedUsers();

--
Gitblit v1.9.1