summaryrefslogtreecommitdiffstats
path: root/src/com/vaadin
diff options
context:
space:
mode:
authorMatti Tahvonen <matti.tahvonen@itmill.com>2011-01-19 14:48:57 +0000
committerMatti Tahvonen <matti.tahvonen@itmill.com>2011-01-19 14:48:57 +0000
commit2b3608fe37002c3e25807a30d73c13facf356530 (patch)
tree3dcb995ee49b9530510d1fe32ac9d1fb31b138bd /src/com/vaadin
parent6c0ff7452815dcc2efab394099ca36c3f26e68c9 (diff)
downloadvaadin-framework-2b3608fe37002c3e25807a30d73c13facf356530.tar.gz
vaadin-framework-2b3608fe37002c3e25807a30d73c13facf356530.zip
opening the servlet implementation for customized communication ( e.g. jsonp, websockets)
* WebApplicationContext implementation can now be overridden in servlets via getApplicationContext method. Deprecated createCommunicationManager method as it is now obsolete (introduced earlier in 6.5 branch, dontpush is the only known user). * opened getApplicationUrl for special implementations svn changeset:16950/svn branch:6.5
Diffstat (limited to 'src/com/vaadin')
-rw-r--r--src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java52
-rw-r--r--src/com/vaadin/terminal/gwt/server/ApplicationRunnerServlet.java2
-rw-r--r--src/com/vaadin/terminal/gwt/server/GAEApplicationServlet.java2
3 files changed, 39 insertions, 17 deletions
diff --git a/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java b/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
index 9379766130..bf3ba8f759 100644
--- a/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
+++ b/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
@@ -432,8 +432,8 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
* Get or create a WebApplicationContext and an ApplicationManager
* for the session
*/
- WebApplicationContext webApplicationContext = WebApplicationContext
- .getApplicationContext(request.getSession());
+ WebApplicationContext webApplicationContext = getApplicationContext(request
+ .getSession());
CommunicationManager applicationManager = webApplicationContext
.getApplicationManager(application, this);
@@ -934,8 +934,8 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
throws ServletException, MalformedURLException {
Application newApplication = getNewApplication(request);
- final WebApplicationContext context = WebApplicationContext
- .getApplicationContext(request.getSession());
+ final WebApplicationContext context = getApplicationContext(request
+ .getSession());
context.addApplication(newApplication);
return newApplication;
@@ -2008,7 +2008,7 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
* if the application is denied access to the persistent data
* store represented by the given URL.
*/
- URL getApplicationUrl(HttpServletRequest request)
+ protected URL getApplicationUrl(HttpServletRequest request)
throws MalformedURLException {
final URL reqURL = new URL(
(request.isSecure() ? "https://" : "http://")
@@ -2066,8 +2066,7 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
throw new SessionExpiredException();
}
- WebApplicationContext context = WebApplicationContext
- .getApplicationContext(session);
+ WebApplicationContext context = getApplicationContext(session);
// Gets application list for the session.
final Collection<Application> applications = context.getApplications();
@@ -2088,8 +2087,8 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
}
// Application has stopped, so remove it before creating a new
// application
- WebApplicationContext.getApplicationContext(session)
- .removeApplication(sessionApplication);
+ getApplicationContext(session).removeApplication(
+ sessionApplication);
break;
}
}
@@ -2121,8 +2120,7 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
final HttpSession session = request.getSession();
if (session != null) {
- WebApplicationContext.getApplicationContext(session)
- .removeApplication(application);
+ getApplicationContext(session).removeApplication(application);
}
response.sendRedirect(response.encodeRedirectURL(logoutUrl));
@@ -2214,13 +2212,31 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
application.close();
if (session != null) {
- WebApplicationContext context = WebApplicationContext
- .getApplicationContext(session);
+ WebApplicationContext context = getApplicationContext(session);
context.removeApplication(application);
}
}
/**
+ *
+ * Gets the application context from an HttpSession. If no context is
+ * currently stored in a session a new context is created and stored in the
+ * session.
+ *
+ * @param session
+ * the HTTP session.
+ * @return the application context for HttpSession.
+ */
+ protected WebApplicationContext getApplicationContext(HttpSession session) {
+ /*
+ * TODO the ApplicationContext.getApplicationContext() should be removed
+ * and logic moved here. Now overriding context type is possible, but
+ * the whole creation logic should be here. MT 1101
+ */
+ return WebApplicationContext.getApplicationContext(session);
+ }
+
+ /**
* Implementation of ParameterHandler.ErrorEvent interface.
*/
public class ParameterHandlerErrorImpl implements
@@ -2307,12 +2323,18 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
* Override this method if you need to use a specialized communicaiton
* mananger implementation.
*
- * TODO figure out the right place for CM instantiation, must be
- * overridieable
+ * @deprecated Instead of overriding this method, override
+ * {@link WebApplicationContext} implementation via
+ * {@link AbstractApplicationServlet#getApplicationContext(HttpSession)}
+ * method and in that customized implementation return your
+ * CommunicationManager in
+ * {@link WebApplicationContext#getApplicationManager(Application, AbstractApplicationServlet)}
+ * method.
*
* @param application
* @return
*/
+ @Deprecated
public CommunicationManager createCommunicationManager(
Application application) {
return new CommunicationManager(application);
diff --git a/src/com/vaadin/terminal/gwt/server/ApplicationRunnerServlet.java b/src/com/vaadin/terminal/gwt/server/ApplicationRunnerServlet.java
index 5e660ab82c..10f0b94dda 100644
--- a/src/com/vaadin/terminal/gwt/server/ApplicationRunnerServlet.java
+++ b/src/com/vaadin/terminal/gwt/server/ApplicationRunnerServlet.java
@@ -48,7 +48,7 @@ public class ApplicationRunnerServlet extends AbstractApplicationServlet {
}
@Override
- URL getApplicationUrl(HttpServletRequest request)
+ protected URL getApplicationUrl(HttpServletRequest request)
throws MalformedURLException {
URL url = super.getApplicationUrl(request);
diff --git a/src/com/vaadin/terminal/gwt/server/GAEApplicationServlet.java b/src/com/vaadin/terminal/gwt/server/GAEApplicationServlet.java
index 5f8e59e056..86dbd910d5 100644
--- a/src/com/vaadin/terminal/gwt/server/GAEApplicationServlet.java
+++ b/src/com/vaadin/terminal/gwt/server/GAEApplicationServlet.java
@@ -320,7 +320,7 @@ public class GAEApplicationServlet extends ApplicationServlet {
}
}
// will create new context if the above did not
- return WebApplicationContext.getApplicationContext(session);
+ return getApplicationContext(session);
}