From 2ecee9af7166ba96f64a661842df28db4dc60f6e Mon Sep 17 00:00:00 2001 From: Artur Date: Thu, 27 Apr 2017 14:33:51 +0300 Subject: Open VaadinServlet and BootstrapHandler classes for external use (#9164) --- .../java/com/vaadin/server/BootstrapHandler.java | 124 ++++++++++++++++++--- .../java/com/vaadin/server/BootstrapResponse.java | 2 +- .../main/java/com/vaadin/server/VaadinServlet.java | 4 +- 3 files changed, 113 insertions(+), 17 deletions(-) (limited to 'server') diff --git a/server/src/main/java/com/vaadin/server/BootstrapHandler.java b/server/src/main/java/com/vaadin/server/BootstrapHandler.java index 82248234ef..30b2a5d372 100644 --- a/server/src/main/java/com/vaadin/server/BootstrapHandler.java +++ b/server/src/main/java/com/vaadin/server/BootstrapHandler.java @@ -59,6 +59,7 @@ import elemental.json.JsonObject; import elemental.json.impl.JsonUtil; /** + * Handles the initial request to start the application. * * @author Vaadin Ltd * @since 7.0.0 @@ -75,6 +76,9 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { */ public static final String IGNORE_RESTART_PARAM = "ignoreRestart"; + /** + * Provides context information for the bootstrap process. + */ protected class BootstrapContext implements Serializable { private final VaadinResponse response; @@ -87,28 +91,62 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { private BootstrapUriResolver uriResolver; private WidgetsetInfo widgetsetInfo; + /** + * Creates a new context instance using the given Vaadin/HTTP response + * and bootstrap response. + * + * @param response + * the response object + * @param bootstrapResponse + * the bootstrap response object + */ public BootstrapContext(VaadinResponse response, BootstrapFragmentResponse bootstrapResponse) { this.response = response; this.bootstrapResponse = bootstrapResponse; } + /** + * Gets the Vaadin/HTTP response. + * + * @return the Vaadin/HTTP response + */ public VaadinResponse getResponse() { return response; } + /** + * Gets the Vaadin/HTTP request. + * + * @return the Vaadin/HTTP request + */ public VaadinRequest getRequest() { return bootstrapResponse.getRequest(); } + /** + * Gets the Vaadin session. + * + * @return the Vaadin session + */ public VaadinSession getSession() { return bootstrapResponse.getSession(); } + /** + * Gets the UI class which will be used. + * + * @return the UI class + */ public Class getUIClass() { return bootstrapResponse.getUiClass(); } + /** + * Gets information about the widgetset to use. + * + * @return the widgetset which will be loaded + */ public WidgetsetInfo getWidgetsetInfo() { if (widgetsetInfo == null) { widgetsetInfo = getWidgetsetForUI(this); @@ -125,6 +163,12 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { return getWidgetsetInfo().getWidgetsetName(); } + /** + * Gets the name of the theme to use. + * + * @return the name of the theme, with special characters escaped or + * removed + */ public String getThemeName() { if (themeName == null) { themeName = findAndEscapeThemeName(this); @@ -132,6 +176,11 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { return themeName; } + /** + * Gets the push mode to use. + * + * @return the desired push mode + */ public PushMode getPushMode() { if (pushMode == null) { UICreateEvent event = new UICreateEvent(getRequest(), @@ -156,6 +205,14 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { return pushMode; } + /** + * Gets the application id. + * + * The application id is defined by + * {@link VaadinService#getMainDivId(VaadinSession, VaadinRequest, Class)} + * + * @return the application id + */ public String getAppId() { if (appId == null) { appId = getRequest().getService().getMainDivId(getSession(), @@ -164,10 +221,20 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { return appId; } + /** + * Gets the bootstrap response object. + * + * @return the bootstrap response object + */ public BootstrapFragmentResponse getBootstrapResponse() { return bootstrapResponse; } + /** + * Gets the application parameters specified by the BootstrapHandler. + * + * @return the application parameters which will be written on the page + */ public JsonObject getApplicationParameters() { if (applicationParameters == null) { applicationParameters = BootstrapHandler.this @@ -177,6 +244,11 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { return applicationParameters; } + /** + * Gets the URI resolver to use for bootstrap resources. + * + * @return the URI resolver + */ public BootstrapUriResolver getUriResolver() { if (uriResolver == null) { uriResolver = new BootstrapUriResolver(this); @@ -186,10 +258,20 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { } } + /** + * The URI resolver used in the bootstrap process. + */ protected static class BootstrapUriResolver extends VaadinUriResolver { private final BootstrapContext context; private String frontendUrl; + /** + * Creates a new bootstrap resolver based on the given bootstrap + * context. + * + * @param bootstrapContext + * the bootstrap context + */ public BootstrapUriResolver(BootstrapContext bootstrapContext) { context = bootstrapContext; } @@ -255,26 +337,40 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { @Override protected String getFrontendUrl() { if (frontendUrl == null) { - DeploymentConfiguration configuration = context.getSession() - .getConfiguration(); - if (context.getSession().getBrowser().isEs6Supported()) { - frontendUrl = configuration.getApplicationOrSystemProperty( - ApplicationConstants.FRONTEND_URL_ES6, - ApplicationConstants.FRONTEND_URL_ES6_DEFAULT_VALUE); - } else { - frontendUrl = configuration.getApplicationOrSystemProperty( - ApplicationConstants.FRONTEND_URL_ES5, - ApplicationConstants.FRONTEND_URL_ES5_DEFAULT_VALUE); - } - if (!frontendUrl.endsWith("/")) { - frontendUrl += "/"; - } + frontendUrl = resolveFrontendUrl(context.getSession()); } return frontendUrl; } } + /** + * Resolves the URL to use for the {@literal frontend://} protocol. + * + * @param session + * the session of the user to resolve the protocol for + * @return the URL that frontend:// resolves to, possibly using another + * internal protocol + */ + public static String resolveFrontendUrl(VaadinSession session) { + DeploymentConfiguration configuration = session.getConfiguration(); + String frontendUrl; + if (session.getBrowser().isEs6Supported()) { + frontendUrl = configuration.getApplicationOrSystemProperty( + ApplicationConstants.FRONTEND_URL_ES6, + ApplicationConstants.FRONTEND_URL_ES6_DEFAULT_VALUE); + } else { + frontendUrl = configuration.getApplicationOrSystemProperty( + ApplicationConstants.FRONTEND_URL_ES5, + ApplicationConstants.FRONTEND_URL_ES5_DEFAULT_VALUE); + } + if (!frontendUrl.endsWith("/")) { + frontendUrl += "/"; + } + + return frontendUrl; + } + @Override protected boolean canHandleRequest(VaadinRequest request) { // We do not want to handle /APP requests here, instead let it fall diff --git a/server/src/main/java/com/vaadin/server/BootstrapResponse.java b/server/src/main/java/com/vaadin/server/BootstrapResponse.java index 3f24be3dca..f930055b6a 100644 --- a/server/src/main/java/com/vaadin/server/BootstrapResponse.java +++ b/server/src/main/java/com/vaadin/server/BootstrapResponse.java @@ -105,7 +105,7 @@ public abstract class BootstrapResponse extends EventObject { /** * Gets the UI provider that is used to provide information about the - * bootstapped UI. + * bootstrapped UI. * * @return the UI provider */ diff --git a/server/src/main/java/com/vaadin/server/VaadinServlet.java b/server/src/main/java/com/vaadin/server/VaadinServlet.java index 2c6c55f465..b0ea6f87ec 100644 --- a/server/src/main/java/com/vaadin/server/VaadinServlet.java +++ b/server/src/main/java/com/vaadin/server/VaadinServlet.java @@ -976,7 +976,7 @@ public class VaadinServlet extends HttpServlet implements Constants { * @throws IOException * if there was a problem while locating the file */ - protected URL findResourceURL(String filename) throws IOException { + public URL findResourceURL(String filename) throws IOException { URL resourceUrl = getServletContext().getResource(filename); if (resourceUrl == null) { // try if requested file is found from class loader @@ -1272,7 +1272,7 @@ public class VaadinServlet extends HttpServlet implements Constants { /** * Returns the relative path at which static files are served for a request * (if any). - * + * * @param request * HTTP request * @return relative servlet path or null if the request path does not -- cgit v1.2.3