org.apache.wicket.page.AbstractPageManager Maven / Gradle / Ivy
Go to download
A module that creates a .jar from the classes in wicket, wicket-util and wicket-request modules in order
to create a valid OSGi bundle of the wicket framework.
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.wicket.page;
import org.apache.wicket.util.lang.Args;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Convenience class for {@link IPageManager} implementations. Subclass should extend
* {@link RequestAdapter} and override {@link #newRequestAdater()} method to return it's
* {@link RequestAdapter} implementation.
*
* @author Matej Knopp
*/
public abstract class AbstractPageManager implements IPageManager
{
private static final Logger log = LoggerFactory.getLogger(AbstractPageManager.class);
private final IPageManagerContext context;
/**
* Construct.
*
* @param context
*/
public AbstractPageManager(IPageManagerContext context)
{
this.context = Args.notNull(context, "context");
}
/**
*
* @param context
* @return a new request adapter
*/
protected abstract RequestAdapter newRequestAdapter(IPageManagerContext context);
/**
*
* @see org.apache.wicket.page.IPageManager#supportsVersioning()
*/
public abstract boolean supportsVersioning();
/**
*
* @see org.apache.wicket.page.IPageManager#sessionExpired(java.lang.String)
*/
public abstract void sessionExpired(String sessionId);
/**
* @return The page manager context
*/
public IPageManagerContext getContext()
{
return context;
}
/**
* @see #newRequestAdapter(IPageManagerContext)
*
* @return the request adapter
*/
protected RequestAdapter getRequestAdapter()
{
RequestAdapter adapter = (RequestAdapter)getContext().getRequestData();
if (adapter == null)
{
adapter = newRequestAdapter(getContext());
getContext().setRequestData(adapter);
}
return adapter;
}
/**
* @see org.apache.wicket.page.IPageManager#commitRequest()
*/
public void commitRequest()
{
getRequestAdapter().commitRequest();
}
/**
* @see org.apache.wicket.page.IPageManager#getPage(int)
*/
public IManageablePage getPage(int id)
{
IManageablePage page = getRequestAdapter().getPage(id);
if (page != null)
{
touchPage(page);
}
return page;
}
/**
* @see org.apache.wicket.page.IPageManager#newSessionCreated()
*/
public void newSessionCreated()
{
getRequestAdapter().newSessionCreated();
}
/**
* @see org.apache.wicket.page.IPageManager#touchPage(org.apache.wicket.page.IManageablePage)
*/
public void touchPage(IManageablePage page)
{
if (!page.isPageStateless())
{
getContext().bind();
}
getRequestAdapter().touch(page);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy