- protected Session getCurrentSession(Request request) {
- try {
- return webInterface.sessionManager().useSession(request.getToadletContext());
- } catch (RedirectException re1) {
- return null;
+ protected Session getCurrentSession(ToadletContext toadletContenxt) {
+ return getCurrentSession(toadletContenxt, true);
+ }
+
+ /**
+ * Returns the current session, creating a new session if there is no
+ * current session and {@code create} is {@code true}.
+ *
+ * @param toadletContenxt
+ * The toadlet context
+ * @param create
+ * {@code true} to create a new session if there is no current
+ * session, {@code false} otherwise
+ * @return The current session, or {@code null} if there is no current
+ * session
+ */
+ protected Session getCurrentSession(ToadletContext toadletContenxt, boolean create) {
+ Session session = webInterface.getSessionManager().useSession(toadletContenxt);
+ if (create && (session == null)) {
+ session = webInterface.getSessionManager().createSession(UUID.randomUUID().toString(), toadletContenxt);