Expose supported UIs in GetServerInfo
Requires moving GerritInfo into gerrit-server. Change-Id: I447c29c553e693c4aa02665610101588bdde38c6
This commit is contained in:
@@ -1,87 +0,0 @@
|
||||
// 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.httpd;
|
||||
|
||||
import static com.google.common.base.MoreObjects.firstNonNull;
|
||||
import static com.google.common.base.Preconditions.checkArgument;
|
||||
|
||||
import com.google.gerrit.extensions.client.UiType;
|
||||
|
||||
import org.eclipse.jgit.lib.Config;
|
||||
|
||||
public class GerritOptions {
|
||||
private final boolean headless;
|
||||
private final boolean slave;
|
||||
private final boolean enablePolyGerrit;
|
||||
private final boolean enableGwtUi;
|
||||
private final boolean forcePolyGerritDev;
|
||||
private final UiType defaultUi;
|
||||
|
||||
public GerritOptions(Config cfg, boolean headless, boolean slave,
|
||||
boolean forcePolyGerritDev) {
|
||||
this.slave = slave;
|
||||
this.enablePolyGerrit = forcePolyGerritDev
|
||||
|| cfg.getBoolean("gerrit", null, "enablePolyGerrit", false);
|
||||
this.enableGwtUi = cfg.getBoolean("gerrit", null, "enableGwtUi", true);
|
||||
this.forcePolyGerritDev = forcePolyGerritDev;
|
||||
this.headless = headless || (!enableGwtUi && !enablePolyGerrit);
|
||||
|
||||
UiType defaultUi = enablePolyGerrit && !enableGwtUi
|
||||
? UiType.POLYGERRIT
|
||||
: UiType.GWT;
|
||||
String uiStr = firstNonNull(
|
||||
cfg.getString("gerrit", null, "ui"),
|
||||
defaultUi.name());
|
||||
this.defaultUi = firstNonNull(UiType.parse(uiStr), UiType.NONE);
|
||||
|
||||
switch (defaultUi) {
|
||||
case GWT:
|
||||
checkArgument(enableGwtUi,
|
||||
"gerrit.ui = %s but GWT UI is disabled", defaultUi);
|
||||
break;
|
||||
case POLYGERRIT:
|
||||
checkArgument(enablePolyGerrit,
|
||||
"gerrit.ui = %s but PolyGerrit is disabled", defaultUi);
|
||||
break;
|
||||
case NONE:
|
||||
default:
|
||||
throw new IllegalArgumentException("invalid gerrit.ui: " + uiStr);
|
||||
}
|
||||
}
|
||||
|
||||
public boolean headless() {
|
||||
return headless;
|
||||
}
|
||||
|
||||
public boolean enableGwtUi() {
|
||||
return !headless && enableGwtUi;
|
||||
}
|
||||
|
||||
public boolean enableMasterFeatures() {
|
||||
return !slave;
|
||||
}
|
||||
|
||||
public boolean enablePolyGerrit() {
|
||||
return !headless && enablePolyGerrit;
|
||||
}
|
||||
|
||||
public boolean forcePolyGerritDev() {
|
||||
return !headless && forcePolyGerritDev;
|
||||
}
|
||||
|
||||
public UiType defaultUi() {
|
||||
return defaultUi;
|
||||
}
|
||||
}
|
||||
@@ -34,6 +34,7 @@ import com.google.gerrit.httpd.rpc.doc.QueryDocumentationFilter;
|
||||
import com.google.gerrit.reviewdb.client.Change;
|
||||
import com.google.gerrit.reviewdb.client.Project;
|
||||
import com.google.gerrit.server.config.AuthConfig;
|
||||
import com.google.gerrit.server.config.GerritOptions;
|
||||
import com.google.gwtexpui.server.CacheControlFilter;
|
||||
import com.google.inject.Key;
|
||||
import com.google.inject.Provider;
|
||||
|
||||
@@ -25,6 +25,7 @@ import com.google.gerrit.httpd.rpc.UiRpcModule;
|
||||
import com.google.gerrit.lifecycle.LifecycleModule;
|
||||
import com.google.gerrit.server.RemotePeer;
|
||||
import com.google.gerrit.server.config.AuthConfig;
|
||||
import com.google.gerrit.server.config.GerritOptions;
|
||||
import com.google.gerrit.server.config.GerritRequestModule;
|
||||
import com.google.gerrit.server.config.GitwebCgiConfig;
|
||||
import com.google.gerrit.server.git.AsyncReceiveCommits;
|
||||
|
||||
@@ -22,11 +22,11 @@ import static java.nio.file.Files.isReadable;
|
||||
import com.google.common.cache.Cache;
|
||||
import com.google.common.collect.ImmutableList;
|
||||
import com.google.gerrit.extensions.client.UiType;
|
||||
import com.google.gerrit.httpd.GerritOptions;
|
||||
import com.google.gerrit.httpd.XsrfCookieFilter;
|
||||
import com.google.gerrit.httpd.raw.ResourceServlet.Resource;
|
||||
import com.google.gerrit.launcher.GerritLauncher;
|
||||
import com.google.gerrit.server.cache.CacheModule;
|
||||
import com.google.gerrit.server.config.GerritOptions;
|
||||
import com.google.gerrit.server.config.GerritServerConfig;
|
||||
import com.google.gerrit.server.config.SitePaths;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
Reference in New Issue
Block a user