summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Moger <james.moger@gitblit.com>2012-10-30 17:04:47 -0400
committerJames Moger <james.moger@gitblit.com>2012-10-30 17:04:47 -0400
commitdd630f8aebde8c3138dc0d55ebf4a16d0db806b7 (patch)
tree98902cb6cee40f3b1a593987fb348aa29763182c
parentabcb146f0c4e5c99e5e44349a65e6fd49e9296d9 (diff)
downloadgitblit-dd630f8aebde8c3138dc0d55ebf4a16d0db806b7.tar.gz
gitblit-dd630f8aebde8c3138dc0d55ebf4a16d0db806b7.zip
Fix intermittent Wicket page expirations on EditNNN pages
-rw-r--r--src/com/gitblit/wicket/pages/EditRepositoryPage.java5
-rw-r--r--src/com/gitblit/wicket/pages/EditTeamPage.java5
-rw-r--r--src/com/gitblit/wicket/pages/EditUserPage.java5
-rw-r--r--src/com/gitblit/wicket/pages/RootSubPage.java18
4 files changed, 33 insertions, 0 deletions
diff --git a/src/com/gitblit/wicket/pages/EditRepositoryPage.java b/src/com/gitblit/wicket/pages/EditRepositoryPage.java
index f791cf60..cc0db680 100644
--- a/src/com/gitblit/wicket/pages/EditRepositoryPage.java
+++ b/src/com/gitblit/wicket/pages/EditRepositoryPage.java
@@ -115,6 +115,11 @@ public class EditRepositoryPage extends RootSubPage {
setStatelessHint(false);
setOutputMarkupId(true);
}
+
+ @Override
+ protected boolean requiresPageMap() {
+ return true;
+ }
protected void setupPage(RepositoryModel model) {
this.repositoryModel = model;
diff --git a/src/com/gitblit/wicket/pages/EditTeamPage.java b/src/com/gitblit/wicket/pages/EditTeamPage.java
index 8ced03c2..a22361f1 100644
--- a/src/com/gitblit/wicket/pages/EditTeamPage.java
+++ b/src/com/gitblit/wicket/pages/EditTeamPage.java
@@ -75,6 +75,11 @@ public class EditTeamPage extends RootSubPage {
setOutputMarkupId(true);
}
+ @Override
+ protected boolean requiresPageMap() {
+ return true;
+ }
+
protected void setupPage(final TeamModel teamModel) {
if (isCreate) {
super.setupPage(getString("gb.newTeam"), "");
diff --git a/src/com/gitblit/wicket/pages/EditUserPage.java b/src/com/gitblit/wicket/pages/EditUserPage.java
index 19d297b1..7942d6fa 100644
--- a/src/com/gitblit/wicket/pages/EditUserPage.java
+++ b/src/com/gitblit/wicket/pages/EditUserPage.java
@@ -76,6 +76,11 @@ public class EditUserPage extends RootSubPage {
setStatelessHint(false);
setOutputMarkupId(true);
}
+
+ @Override
+ protected boolean requiresPageMap() {
+ return true;
+ }
protected void setupPage(final UserModel userModel) {
if (isCreate) {
diff --git a/src/com/gitblit/wicket/pages/RootSubPage.java b/src/com/gitblit/wicket/pages/RootSubPage.java
index 891c892a..e7e12ccc 100644
--- a/src/com/gitblit/wicket/pages/RootSubPage.java
+++ b/src/com/gitblit/wicket/pages/RootSubPage.java
@@ -19,6 +19,7 @@ import java.util.ArrayList;
import java.util.List;
import org.apache.wicket.PageParameters;
+import org.apache.wicket.Session;
import org.apache.wicket.markup.html.basic.Label;
import com.gitblit.Constants.AccessRestrictionType;
@@ -38,10 +39,27 @@ public abstract class RootSubPage extends RootPage {
public RootSubPage() {
super();
+ createPageMapIfNeeded();
}
public RootSubPage(PageParameters params) {
super(params);
+ createPageMapIfNeeded();
+ }
+
+ protected boolean requiresPageMap() {
+ return false;
+ }
+
+ protected void createPageMapIfNeeded() {
+ if (requiresPageMap()) {
+ // because Gitblit strives for page-statelessness
+ // Wicket seems to get confused as to when it really should
+ // generate a page map for complex pages. Conditionally ensure we
+ // have a page map for complex AJAX pages like the EditNNN pages.
+ Session.get().pageMapForName(null, true);
+ setVersioned(true);
+ }
}
@Override