Replace PolyGerritUiIndexServlet with SingleFileServlet
Change-Id: I19688f1145d67784f71cd9fd060798a51eae8a40
This commit is contained in:
parent
12380e0a0d
commit
6a55317d4c
@ -1,35 +0,0 @@
|
|||||||
// Copyright (C) 2015 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.raw;
|
|
||||||
|
|
||||||
import com.google.common.cache.Cache;
|
|
||||||
|
|
||||||
import java.nio.file.Path;
|
|
||||||
|
|
||||||
class PolyGerritUiIndexServlet extends ResourceServlet {
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
|
|
||||||
private final Path index;
|
|
||||||
|
|
||||||
PolyGerritUiIndexServlet(Cache<Path, Resource> cache, Path ui) {
|
|
||||||
super(cache, true);
|
|
||||||
index = ui.resolve("index.html");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Path getResourcePath(String pathInfo) {
|
|
||||||
return index;
|
|
||||||
}
|
|
||||||
}
|
|
@ -73,6 +73,8 @@ public class StaticModule extends ServletModule {
|
|||||||
private static final String DOC_SERVLET = "DocServlet";
|
private static final String DOC_SERVLET = "DocServlet";
|
||||||
private static final String FAVICON_SERVLET = "FaviconServlet";
|
private static final String FAVICON_SERVLET = "FaviconServlet";
|
||||||
private static final String GWT_UI_SERVLET = "GwtUiServlet";
|
private static final String GWT_UI_SERVLET = "GwtUiServlet";
|
||||||
|
private static final String POLYGERRIT_INDEX_SERVLET =
|
||||||
|
"PolyGerritUiIndexServlet";
|
||||||
private static final String ROBOTS_TXT_SERVLET = "RobotsTxtServlet";
|
private static final String ROBOTS_TXT_SERVLET = "RobotsTxtServlet";
|
||||||
|
|
||||||
private final GerritOptions options;
|
private final GerritOptions options;
|
||||||
@ -228,18 +230,21 @@ public class StaticModule extends ServletModule {
|
|||||||
// separate servlet.
|
// separate servlet.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Key<HttpServlet> indexKey = named(POLYGERRIT_INDEX_SERVLET);
|
||||||
for (String p : POLYGERRIT_INDEX_PATHS) {
|
for (String p : POLYGERRIT_INDEX_PATHS) {
|
||||||
filter(p).through(XsrfCookieFilter.class);
|
filter(p).through(XsrfCookieFilter.class);
|
||||||
serve(p).with(PolyGerritUiIndexServlet.class);
|
serve(p).with(indexKey);
|
||||||
}
|
}
|
||||||
serve("/*").with(PolyGerritUiServlet.class);
|
serve("/*").with(PolyGerritUiServlet.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
@Singleton
|
@Singleton
|
||||||
PolyGerritUiIndexServlet getPolyGerritUiIndexServlet(
|
@Named(POLYGERRIT_INDEX_SERVLET)
|
||||||
|
HttpServlet getPolyGerritUiIndexServlet(
|
||||||
@Named(CACHE) Cache<Path, Resource> cache) {
|
@Named(CACHE) Cache<Path, Resource> cache) {
|
||||||
return new PolyGerritUiIndexServlet(cache, polyGerritBasePath());
|
return new SingleFileServlet(
|
||||||
|
cache, polyGerritBasePath().resolve("index.html"), isDev());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
@ -256,14 +261,17 @@ public class StaticModule extends ServletModule {
|
|||||||
return new BowerComponentsServlet(cache, getPaths().buckOut);
|
return new BowerComponentsServlet(cache, getPaths().buckOut);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isDev() {
|
||||||
|
return options.forcePolyGerritDev() || getPaths().warFs == null;
|
||||||
|
}
|
||||||
|
|
||||||
private Path polyGerritBasePath() {
|
private Path polyGerritBasePath() {
|
||||||
Paths p = getPaths();
|
Paths p = getPaths();
|
||||||
boolean forceDev = options.forcePolyGerritDev();
|
if (options.forcePolyGerritDev()) {
|
||||||
if (forceDev) {
|
|
||||||
checkArgument(p.buckOut != null,
|
checkArgument(p.buckOut != null,
|
||||||
"no buck-out directory found for PolyGerrit developer mode");
|
"no buck-out directory found for PolyGerrit developer mode");
|
||||||
}
|
}
|
||||||
return forceDev || p.warFs == null
|
return isDev()
|
||||||
? p.buckOut.getParent().resolve("polygerrit-ui").resolve("app")
|
? p.buckOut.getParent().resolve("polygerrit-ui").resolve("app")
|
||||||
: p.warFs.getPath("/polygerrit_ui");
|
: p.warFs.getPath("/polygerrit_ui");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user