summaryrefslogtreecommitdiffstats
path: root/src/com/itmill
diff options
context:
space:
mode:
authorJani Laakso <jani.laakso@itmill.com>2007-12-04 18:13:55 +0000
committerJani Laakso <jani.laakso@itmill.com>2007-12-04 18:13:55 +0000
commit2bfeca0498c879c11f11a54a22ad87cccdaa78c2 (patch)
tree827aa1d49b3348f7fb3273ddb39db38cf211284f /src/com/itmill
parent0df0319345e22146c3ff8b12802937b37f5dc06d (diff)
downloadvaadin-framework-2bfeca0498c879c11f11a54a22ad87cccdaa78c2.tar.gz
vaadin-framework-2bfeca0498c879c11f11a54a22ad87cccdaa78c2.zip
Fixed #943 (Creating new applications without altering web.xml)
How to use * Try http://localhost:8080/myContext/run/com.itmill.toolkit.demo.Calc web.xml contains run/* servlet with applicationRunner=true parameter. This should not affect Toolkit in any way if applicationRunner is not defined. Currently it is defined only with run/* This needs review. Reason why I did this is to * skip one step more for newbies * "how to start" flash demo is simpler (included XML is enough for any new application) Side-effects * UIDL request have part of URI path after their UIDL request, see firebug svn changeset:3160/svn branch:trunk
Diffstat (limited to 'src/com/itmill')
-rw-r--r--src/com/itmill/toolkit/terminal/gwt/server/ApplicationServlet.java139
1 files changed, 104 insertions, 35 deletions
diff --git a/src/com/itmill/toolkit/terminal/gwt/server/ApplicationServlet.java b/src/com/itmill/toolkit/terminal/gwt/server/ApplicationServlet.java
index 529d1f4229..c7d9f8357d 100644
--- a/src/com/itmill/toolkit/terminal/gwt/server/ApplicationServlet.java
+++ b/src/com/itmill/toolkit/terminal/gwt/server/ApplicationServlet.java
@@ -146,6 +146,8 @@ public class ApplicationServlet extends HttpServlet {
private String debugMode = "";
+ private boolean applicationRunnerMode = false;
+
private ClassLoader classLoader;
/**
@@ -163,12 +165,17 @@ public class ApplicationServlet extends HttpServlet {
throws javax.servlet.ServletException {
super.init(servletConfig);
- // Gets the application class name
- String applicationClassName = servletConfig
- .getInitParameter("application");
- if (applicationClassName == null) {
- System.err
- .println("Application not specified in servlet parameters");
+ // Get applicationRunner
+ String applicationRunner = servletConfig
+ .getInitParameter("applicationRunner");
+ if (applicationRunner != null) {
+ if ("true".equals(applicationRunner))
+ applicationRunnerMode = true;
+ else if ("false".equals(applicationRunner))
+ applicationRunnerMode = false;
+ else
+ throw new ServletException(
+ "If applicationRunner parameter is given for an application, it must be 'true' or 'false'");
}
// Stores the application parameters into Properties object
@@ -225,13 +232,23 @@ public class ApplicationServlet extends HttpServlet {
// Loads the application class using the same class loader
// as the servlet itself
- try {
- applicationClass = classLoader.loadClass(applicationClassName);
- } catch (ClassNotFoundException e) {
- throw new ServletException("Failed to load application class: "
- + applicationClassName);
+ if (!applicationRunnerMode) {
+ // Gets the application class name
+ String applicationClassName = servletConfig
+ .getInitParameter("application");
+ if (applicationClassName == null)
+ throw new ServletException(
+ "Application not specified in servlet parameters");
+ try {
+ applicationClass = classLoader.loadClass(applicationClassName);
+ } catch (ClassNotFoundException e) {
+ throw new ServletException("Failed to load application class: "
+ + applicationClassName);
+ }
+ } else {
+ // This servlet is in application runner mode, it uses classloader
+ // later to create Applications based on URL
}
-
}
/**
@@ -302,10 +319,19 @@ public class ApplicationServlet extends HttpServlet {
protected void service(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
- if (request.getPathInfo() != null
- && request.getPathInfo().startsWith("/ITMILL/")) {
- serveStaticResourcesInITMILL(request, response);
- return;
+ if (request.getPathInfo() != null) {
+ if (applicationRunnerMode
+ && (request.getPathInfo().indexOf("/", 1) != -1)) {
+ String resourceUrl = request.getPathInfo().substring(
+ request.getPathInfo().indexOf('/', 1));
+ if (resourceUrl.startsWith("/ITMILL/")) {
+ serveStaticResourcesInITMILL(resourceUrl, response);
+ return;
+ }
+ } else if (request.getPathInfo().startsWith("/ITMILL/")) {
+ serveStaticResourcesInITMILL(request.getPathInfo(), response);
+ return;
+ }
}
Application application = null;
@@ -342,10 +368,25 @@ public class ApplicationServlet extends HttpServlet {
// Handles AJAX UIDL requests
String resourceId = request.getPathInfo();
- if (resourceId != null && resourceId.startsWith(AJAX_UIDL_URI)) {
- getApplicationManager(application).handleUidlRequest(request,
- response);
- return;
+ if (resourceId != null) {
+ if (applicationRunnerMode) {
+ if (resourceId.indexOf("/", 1) != -1) {
+ String resourceUrl = resourceId.substring(resourceId
+ .indexOf('/', 1));
+ if (resourceId != null
+ && (resourceUrl.startsWith(AJAX_UIDL_URI))) {
+ getApplicationManager(application)
+ .handleUidlRequest(request, response);
+ return;
+ }
+ }
+ } else {
+ if (resourceId.startsWith(AJAX_UIDL_URI)) {
+ getApplicationManager(application).handleUidlRequest(
+ request, response);
+ return;
+ }
+ }
}
// Handles the URI if the application is still running
@@ -427,9 +468,8 @@ public class ApplicationServlet extends HttpServlet {
* @param response
* @throws IOException
*/
- private void serveStaticResourcesInITMILL(HttpServletRequest request,
+ private void serveStaticResourcesInITMILL(String filename,
HttpServletResponse response) throws IOException {
- String filename = request.getPathInfo();
ServletContext sc = getServletContext();
InputStream is = sc.getResourceAsStream(filename);
if (is == null) {
@@ -498,17 +538,28 @@ public class ApplicationServlet extends HttpServlet {
+ "<script type=\"text/javascript\">\n"
+ " var itmill = {\n" + " appUri:'");
- String[] urlParts = getApplicationUrl(request).toString().split("\\/");
- String appUrl = "";
// don't use server and port in uri. It may cause problems with some
// virtual server configurations which lose the server name
- for (int i = 3; i < urlParts.length; i++) {
- appUrl += "/" + urlParts[i];
- }
- if (appUrl.endsWith("/")) {
- appUrl = appUrl.substring(0, appUrl.length() - 1);
+ String appUrl = "";
+ String[] urlParts;
+ if (applicationRunnerMode) {
+ String servletPath = request.getContextPath()
+ + request.getServletPath();
+ if (request.getPathInfo().indexOf('/', 1) == -1)
+ servletPath += request.getPathInfo();
+ else
+ servletPath += request.getPathInfo().substring(1,
+ request.getPathInfo().indexOf('/', 1));
+ appUrl = servletPath;
+ } else {
+ urlParts = getApplicationUrl(request).toString().split("\\/");
+ for (int i = 3; i < urlParts.length; i++) {
+ appUrl += "/" + urlParts[i];
+ }
+ if (appUrl.endsWith("/")) {
+ appUrl = appUrl.substring(0, appUrl.length() - 1);
+ }
}
-
page.write(appUrl);
String widgetset = applicationProperties
@@ -770,6 +821,8 @@ public class ApplicationServlet extends HttpServlet {
.getServerPort() == 80) ? "" : ":"
+ request.getServerPort())
+ request.getRequestURI());
+ if (applicationRunnerMode)
+ return reqURL;
String servletPath = request.getContextPath()
+ request.getServletPath();
if (servletPath.length() == 0
@@ -825,13 +878,19 @@ public class ApplicationServlet extends HttpServlet {
if (servletPath.length() < aPath.length()) {
servletPath += "/";
}
- if (servletPath.equals(aPath)) {
+ if (applicationRunnerMode) {
+ if (request.getPathInfo().indexOf('/', 1) == -1)
+ servletPath += request.getPathInfo();
+ else
+ servletPath += request.getPathInfo().substring(1,
+ request.getPathInfo().indexOf('/', 1));
+ }
+ if (servletPath.equals(aPath)) {
// Found a running application
if (a.isRunning()) {
return a;
}
-
// Application has stopped, so remove it before creating a new
// application
WebApplicationContext.getApplicationContext(session)
@@ -839,12 +898,23 @@ public class ApplicationServlet extends HttpServlet {
break;
}
}
-
// Creates application, because a running one was not found
WebApplicationContext context = WebApplicationContext
.getApplicationContext(request.getSession());
URL applicationUrl = getApplicationUrl(request);
+ if (applicationRunnerMode) {
+ String applicationClassName = applicationUrl.getPath().substring(
+ applicationUrl.getPath().lastIndexOf('/') + 1);
+ try {
+ applicationClass = classLoader.loadClass(applicationClassName);
+ } catch (ClassNotFoundException e) {
+ throw new InstantiationException(
+ "Failed to load application class: "
+ + applicationClassName);
+ }
+ }
+
// Creates new application and start it
try {
Application application = (Application) applicationClass
@@ -854,9 +924,8 @@ public class ApplicationServlet extends HttpServlet {
// Sets initial locale from the request
application.setLocale(request.getLocale());
- // Starts application and check license
+ // Starts application
application.start(applicationUrl, applicationProperties, context);
-
return application;
} catch (IllegalAccessException e) {