Split out REST parts of PluginModule into PluginRestApiModule

Command-line programs that don't start a Gerrit daemon may want to
load plugins using this module, but don't need the additional
dependencies brought in by being a RestApiModule.

Change-Id: I4524ba7e04112101cd3a890e171658ad037ef1ee
This commit is contained in:
Dave Borowitz
2013-09-10 15:01:31 -07:00
parent 50a7a3a61d
commit 0690b1ea06
4 changed files with 41 additions and 18 deletions

View File

@@ -56,7 +56,7 @@ import com.google.gerrit.server.mail.SignedTokenEmailTokenVerifier;
import com.google.gerrit.server.mail.SmtpEmailSender; import com.google.gerrit.server.mail.SmtpEmailSender;
import com.google.gerrit.server.patch.IntraLineWorkerPool; import com.google.gerrit.server.patch.IntraLineWorkerPool;
import com.google.gerrit.server.plugins.PluginGuiceEnvironment; import com.google.gerrit.server.plugins.PluginGuiceEnvironment;
import com.google.gerrit.server.plugins.PluginModule; import com.google.gerrit.server.plugins.PluginRestApiModule;
import com.google.gerrit.server.schema.SchemaVersionCheck; import com.google.gerrit.server.schema.SchemaVersionCheck;
import com.google.gerrit.server.ssh.NoSshKeyCache; import com.google.gerrit.server.ssh.NoSshKeyCache;
import com.google.gerrit.server.ssh.NoSshModule; import com.google.gerrit.server.ssh.NoSshModule;
@@ -255,7 +255,7 @@ public class Daemon extends SiteProgram {
modules.add(new DefaultCacheFactory.Module()); modules.add(new DefaultCacheFactory.Module());
modules.add(new SmtpEmailSender.Module()); modules.add(new SmtpEmailSender.Module());
modules.add(new SignedTokenEmailTokenVerifier.Module()); modules.add(new SignedTokenEmailTokenVerifier.Module());
modules.add(new PluginModule()); modules.add(new PluginRestApiModule());
AbstractModule changeIndexModule; AbstractModule changeIndexModule;
switch (IndexModule.getIndexType(cfgInjector)) { switch (IndexModule.getIndexType(cfgInjector)) {
case LUCENE: case LUCENE:

View File

@@ -14,21 +14,17 @@
package com.google.gerrit.server.plugins; package com.google.gerrit.server.plugins;
import static com.google.gerrit.server.plugins.PluginResource.PLUGIN_KIND;
import com.google.gerrit.extensions.registration.DynamicMap;
import com.google.gerrit.extensions.restapi.RestApiModule;
import com.google.gerrit.extensions.systemstatus.ServerInformation; import com.google.gerrit.extensions.systemstatus.ServerInformation;
import com.google.gerrit.lifecycle.LifecycleModule; import com.google.gerrit.lifecycle.LifecycleModule;
import com.google.inject.AbstractModule;
public class PluginModule extends RestApiModule { public class PluginModule extends AbstractModule {
@Override @Override
protected void configure() { protected void configure() {
bind(ServerInformationImpl.class); bind(ServerInformationImpl.class);
bind(ServerInformation.class).to(ServerInformationImpl.class); bind(ServerInformation.class).to(ServerInformationImpl.class);
bind(PluginCleanerTask.class); bind(PluginCleanerTask.class);
bind(PluginsCollection.class);
bind(PluginGuiceEnvironment.class); bind(PluginGuiceEnvironment.class);
bind(PluginLoader.class); bind(PluginLoader.class);
bind(CopyConfigModule.class); bind(CopyConfigModule.class);
@@ -38,13 +34,5 @@ public class PluginModule extends RestApiModule {
listener().to(PluginLoader.class); listener().to(PluginLoader.class);
} }
}); });
DynamicMap.mapOf(binder(), PLUGIN_KIND);
put(PLUGIN_KIND).to(InstallPlugin.Overwrite.class);
delete(PLUGIN_KIND).to(DisablePlugin.class);
get(PLUGIN_KIND, "status").to(GetStatus.class);
post(PLUGIN_KIND, "disable").to(DisablePlugin.class);
post(PLUGIN_KIND, "enable").to(EnablePlugin.class);
post(PLUGIN_KIND, "reload").to(ReloadPlugin.class);
} }
} }

View File

@@ -0,0 +1,35 @@
// Copyright (C) 2013 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.server.plugins;
import static com.google.gerrit.server.plugins.PluginResource.PLUGIN_KIND;
import com.google.gerrit.extensions.registration.DynamicMap;
import com.google.gerrit.extensions.restapi.RestApiModule;
public class PluginRestApiModule extends RestApiModule {
@Override
protected void configure() {
install(new PluginModule());
bind(PluginsCollection.class);
DynamicMap.mapOf(binder(), PLUGIN_KIND);
put(PLUGIN_KIND).to(InstallPlugin.Overwrite.class);
delete(PLUGIN_KIND).to(DisablePlugin.class);
get(PLUGIN_KIND, "status").to(GetStatus.class);
post(PLUGIN_KIND, "disable").to(DisablePlugin.class);
post(PLUGIN_KIND, "enable").to(EnablePlugin.class);
post(PLUGIN_KIND, "reload").to(ReloadPlugin.class);
}
}

View File

@@ -44,7 +44,7 @@ import com.google.gerrit.server.mail.SignedTokenEmailTokenVerifier;
import com.google.gerrit.server.mail.SmtpEmailSender; import com.google.gerrit.server.mail.SmtpEmailSender;
import com.google.gerrit.server.patch.IntraLineWorkerPool; import com.google.gerrit.server.patch.IntraLineWorkerPool;
import com.google.gerrit.server.plugins.PluginGuiceEnvironment; import com.google.gerrit.server.plugins.PluginGuiceEnvironment;
import com.google.gerrit.server.plugins.PluginModule; import com.google.gerrit.server.plugins.PluginRestApiModule;
import com.google.gerrit.server.schema.DataSourceModule; import com.google.gerrit.server.schema.DataSourceModule;
import com.google.gerrit.server.schema.DataSourceProvider; import com.google.gerrit.server.schema.DataSourceProvider;
import com.google.gerrit.server.schema.DataSourceType; import com.google.gerrit.server.schema.DataSourceType;
@@ -257,7 +257,7 @@ public class WebAppInitializer extends GuiceServletContextListener
modules.add(new DefaultCacheFactory.Module()); modules.add(new DefaultCacheFactory.Module());
modules.add(new SmtpEmailSender.Module()); modules.add(new SmtpEmailSender.Module());
modules.add(new SignedTokenEmailTokenVerifier.Module()); modules.add(new SignedTokenEmailTokenVerifier.Module());
modules.add(new PluginModule()); modules.add(new PluginRestApiModule());
AbstractModule changeIndexModule; AbstractModule changeIndexModule;
switch (IndexModule.getIndexType(cfgInjector)) { switch (IndexModule.getIndexType(cfgInjector)) {
case LUCENE: case LUCENE: