/* @VaadinApache2LicenseForJavaFiles@ */ package com.vaadin.service; import java.io.File; import java.io.Serializable; import java.net.URL; import java.util.Collection; import com.vaadin.Application; import com.vaadin.terminal.ApplicationResource; import com.vaadin.terminal.gwt.server.AbstractCommunicationManager; /** * ApplicationContext provides information about the running * context of the application. Each context is shared by all applications that * are open for one user. In a web-environment this corresponds to a * HttpSession. * * @author Vaadin Ltd. * @since 3.1 */ public interface ApplicationContext extends Serializable { /** * Returns application context base directory. * * Typically an application is deployed in a such way that is has an * application directory. For web applications this directory is the root * directory of the web applications. In some cases applications might not * have an application directory (for example web applications running * inside a war). * * @return The application base directory or null if the application has no * base directory. */ public File getBaseDirectory(); /** * Returns a collection of all the applications in this context. * * Each application context contains all active applications for one user. * * @return A collection containing all the applications in this context. */ public Collection getApplications(); /** * Adds a transaction listener to this context. The transaction listener is * called before and after each each request related to this session except * when serving static resources. * * The transaction listener must not be null. * * @see com.vaadin.service.ApplicationContext#addTransactionListener(com.vaadin.service.ApplicationContext.TransactionListener) */ public void addTransactionListener(TransactionListener listener); /** * Removes a transaction listener from this context. * * @param listener * the listener to be removed. * @see TransactionListener */ public void removeTransactionListener(TransactionListener listener); /** * Generate a URL that can be used as the relative location of e.g. an * {@link ApplicationResource}. * * This method should only be called from the processing of a UIDL request, * not from a background thread. The return value is null if used outside a * suitable request. * * @deprecated this method is intended for terminal implementation only and * is subject to change/removal from the interface (to * {@link AbstractCommunicationManager}) * * @param resource * @param urlKey * a key for the resource that can later be extracted from a URL * with {@link #getURLKey(URL, String)} */ @Deprecated public String generateApplicationResourceURL(ApplicationResource resource, String urlKey); /** * Tests if a URL is for an application resource (APP/...). * * @deprecated this method is intended for terminal implementation only and * is subject to change/removal from the interface (to * {@link AbstractCommunicationManager}) * * @param context * @param relativeUri * @return */ @Deprecated public boolean isApplicationResourceURL(URL context, String relativeUri); /** * Gets the identifier (key) from an application resource URL. This key is * the one that was given to * {@link #generateApplicationResourceURL(ApplicationResource, String)} when * creating the URL. * * @deprecated this method is intended for terminal implementation only and * is subject to change/removal from the interface (to * {@link AbstractCommunicationManager}) * * * @param context * @param relativeUri * @return */ @Deprecated public String getURLKey(URL context, String relativeUri); /** * Interface for listening to transaction events. Implement this interface * to listen to all transactions between the client and the application. * */ public interface TransactionListener extends Serializable { /** * Invoked at the beginning of every transaction. * * The transaction is linked to the context, not the application so if * you have multiple applications running in the same context you need * to check that the request is associated with the application you are * interested in. This can be done looking at the application parameter. * * @param application * the Application object. * @param transactionData * the Data identifying the transaction. */ public void transactionStart(Application application, Object transactionData); /** * Invoked at the end of every transaction. * * The transaction is linked to the context, not the application so if * you have multiple applications running in the same context you need * to check that the request is associated with the application you are * interested in. This can be done looking at the application parameter. * * @param applcation * the Application object. * @param transactionData * the Data identifying the transaction. */ public void transactionEnd(Application application, Object transactionData); } }