12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- /*
- * Copyright 2012 gitblit.com.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.gitblit.wicket;
-
- import org.apache.wicket.AbstractRestartResponseException;
- import org.apache.wicket.Page;
- import org.apache.wicket.PageParameters;
- import org.apache.wicket.RequestCycle;
- import org.apache.wicket.protocol.http.RequestUtils;
- import org.apache.wicket.request.target.basic.RedirectRequestTarget;
-
- /**
- * This exception bypasses the servlet container rewriting relative redirect
- * urls. The container can and does decode the carefully crafted %2F path
- * separators on a redirect. :( Bad, bad servlet container.
- *
- * org.eclipse.jetty.server.Response#L447: String path=uri.getDecodedPath();
- *
- * @author James Moger
- */
- public class GitblitRedirectException extends AbstractRestartResponseException {
-
- private static final long serialVersionUID = 1L;
-
- public <C extends Page> GitblitRedirectException(Class<C> pageClass) {
- this(pageClass, null);
- }
-
- public <C extends Page> GitblitRedirectException(Class<C> pageClass, PageParameters params) {
- RequestCycle cycle = RequestCycle.get();
- String relativeUrl = cycle.urlFor(pageClass, params).toString();
- String absoluteUrl = RequestUtils.toAbsolutePath(relativeUrl);
- cycle.setRequestTarget(new RedirectRequestTarget(absoluteUrl));
- cycle.setRedirect(true);
- }
- }
|