From e5d0bacbf746e09a9194822b231cb27090f58973 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Thu, 10 Apr 2014 19:00:52 -0400
Subject: [PATCH] Implement simple JSON-based plugin registry and install command

---
 src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java |   22 ++++++++++------------
 1 files changed, 10 insertions(+), 12 deletions(-)

diff --git a/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java b/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
index 896391f..3c37866 100644
--- a/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
+++ b/src/main/java/com/gitblit/transport/ssh/commands/RootDispatcher.java
@@ -24,14 +24,15 @@
 import com.gitblit.models.UserModel;
 import com.gitblit.transport.ssh.SshDaemonClient;
 import com.gitblit.transport.ssh.git.GitDispatcher;
-import com.gitblit.transport.ssh.gitblit.GitblitDispatcher;
+import com.gitblit.transport.ssh.keys.KeysDispatcher;
 
 /**
  * The root dispatcher is the dispatch command that handles registering all
  * other commands.
  *
  */
-public class RootDispatcher extends DispatchCommand {
+@CommandMetaData(name = "")
+class RootDispatcher extends DispatchCommand {
 
 	private Logger log = LoggerFactory.getLogger(getClass());
 
@@ -39,9 +40,11 @@
 		super();
 		setContext(new SshCommandContext(gitblit, client, cmdLine));
 
-		final UserModel user = client.getUser();
-		registerDispatcher(user, GitblitDispatcher.class);
-		registerDispatcher(user, GitDispatcher.class);
+		UserModel user = client.getUser();
+		register(user, VersionCommand.class);
+		register(user, GitDispatcher.class);
+		register(user, KeysDispatcher.class);
+		register(user, PluginDispatcher.class);
 
 		List<DispatchCommand> exts = gitblit.getExtensions(DispatchCommand.class);
 		for (DispatchCommand ext : exts) {
@@ -49,16 +52,11 @@
 			String plugin = gitblit.whichPlugin(extClass).getDescriptor().getPluginId();
 			CommandMetaData meta = extClass.getAnnotation(CommandMetaData.class);
 			log.info("Dispatcher {} is loaded from plugin {}", meta.name(), plugin);
-			registerDispatcher(user, ext);
+			register(user, ext);
 		}
 	}
 
 	@Override
-	protected final void registerCommands(UserModel user) {
-	}
-
-	@Override
-	protected final void registerCommand(UserModel user, Class<? extends BaseCommand> cmd) {
-		throw new RuntimeException("The root dispatcher does not accept commands, only dispatchers!");
+	protected final void setup(UserModel user) {
 	}
 }
\ No newline at end of file

--
Gitblit v1.9.1