From c729c59cedff4e800c659e524081fbd1be8db3c1 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Thu, 22 Sep 2011 16:09:37 -0400
Subject: [PATCH] Rearranged federation status enum.

---
 src/com/gitblit/GitBlit.java |   39 +++++++++++++++++++++++++++++++++------
 1 files changed, 33 insertions(+), 6 deletions(-)

diff --git a/src/com/gitblit/GitBlit.java b/src/com/gitblit/GitBlit.java
index b32440b..3e974b3 100644
--- a/src/com/gitblit/GitBlit.java
+++ b/src/com/gitblit/GitBlit.java
@@ -21,6 +21,7 @@
 import java.lang.reflect.Field;
 import java.text.MessageFormat;
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.Collections;
 import java.util.HashMap;
 import java.util.List;
@@ -521,6 +522,8 @@
 			model.showReadme = getConfig(config, "showReadme", false);
 			model.federationStrategy = FederationStrategy.fromName(getConfig(config,
 					"federationStrategy", null));
+			model.federationSets = new ArrayList<String>(Arrays.asList(config.getStringList(
+					"gitblit", null, "federationSets")));
 			model.isFederated = getConfig(config, "isFederated", false);
 			model.origin = config.getString("remote", "origin", "url");
 		}
@@ -697,6 +700,7 @@
 		config.setBoolean("gitblit", null, "showRemoteBranches", repository.showRemoteBranches);
 		config.setBoolean("gitblit", null, "isFrozen", repository.isFrozen);
 		config.setBoolean("gitblit", null, "showReadme", repository.showReadme);
+		config.setStringList("gitblit", null, "federationSets", repository.federationSets);
 		config.setString("gitblit", null, "federationStrategy",
 				repository.federationStrategy.name());
 		config.setBoolean("gitblit", null, "isFederated", repository.isFederated);
@@ -810,9 +814,16 @@
 			validPassphrase = false;
 		}
 		if (validPassphrase) {
+			// standard tokens
 			for (FederationToken tokenType : FederationToken.values()) {
 				logger.info(MessageFormat.format("Federation {0} token = {1}", tokenType.name(),
 						getFederationToken(tokenType)));
+			}
+
+			// federation set tokens
+			for (String set : settings.getStrings(Keys.federation.sets)) {
+				logger.info(MessageFormat.format("Federation Set {0} token = {1}", set,
+						getFederationToken(set)));
 			}
 		}
 
@@ -838,6 +849,7 @@
 			keys.remove(Keys.federation.allowProposals);
 			keys.remove(Keys.federation.proposalsFolder);
 			keys.remove(Keys.federation.defaultFrequency);
+			keys.remove(Keys.federation.sets);
 			Collections.sort(keys);
 			Map<String, FederationModel> federatedModels = new HashMap<String, FederationModel>();
 			for (String key : keys) {
@@ -849,10 +861,10 @@
 				}
 				String setting = values.get(1);
 				if (setting.equals("url")) {
-					// url of the remote Gitblit instance
+					// url of the origin Gitblit instance
 					federatedModels.get(server).url = settings.getString(key, "");
 				} else if (setting.equals("token")) {
-					// token for the remote Gitblit instance
+					// token for the origin Gitblit instance
 					federatedModels.get(server).token = settings.getString(key, "");
 				} else if (setting.equals("frequency")) {
 					// frequency of the pull operation
@@ -860,9 +872,9 @@
 				} else if (setting.equals("folder")) {
 					// destination folder of the pull operation
 					federatedModels.get(server).folder = settings.getString(key, "");
-				} else if (setting.equals("freeze")) {
-					// set the repository to read-only after pull
-					federatedModels.get(server).freeze = settings.getBoolean(key, true);
+				} else if (setting.equals("mirror")) {
+					// are the repositories to be true mirrors of the origin
+					federatedModels.get(server).mirror = settings.getBoolean(key, true);
 				} else if (setting.equals("mergeAccounts")) {
 					// merge remote accounts into local accounts
 					federatedModels.get(server).mergeAccounts = settings.getBoolean(key, false);
@@ -936,8 +948,13 @@
 	 */
 	public List<String> getFederationTokens() {
 		List<String> tokens = new ArrayList<String>();
+		// generate standard tokens
 		for (FederationToken type : FederationToken.values()) {
 			tokens.add(getFederationToken(type));
+		}
+		// generate tokens for federation sets
+		for (String set : settings.getStrings(Keys.federation.sets)) {
+			tokens.add(getFederationToken(set));
 		}
 		return tokens;
 	}
@@ -949,8 +966,18 @@
 	 * @return a federation token
 	 */
 	public String getFederationToken(FederationToken type) {
+		return getFederationToken(type.name());
+	}
+
+	/**
+	 * Returns the specified federation token for this Gitblit instance.
+	 * 
+	 * @param value
+	 * @return a federation token
+	 */
+	public String getFederationToken(String value) {
 		String passphrase = settings.getString(Keys.federation.passphrase, "");
-		return StringUtils.getSHA1(passphrase + "-" + type.name());
+		return StringUtils.getSHA1(passphrase + "-" + value);
 	}
 
 	/**

--
Gitblit v1.9.1