All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.vaadin.server.communication.SessionRequestHandler Maven / Gradle / Ivy

There is a newer version: 8.27.3
Show newest version
/*
 * Vaadin Framework 7
 *
 * Copyright (C) 2000-2024 Vaadin Ltd
 *
 * This program is available under Vaadin Commercial License and Service Terms.
 *
 * See  for the full
 * license.
 */
package com.vaadin.server.communication;

import java.io.IOException;
import java.util.ArrayList;

import com.vaadin.server.RequestHandler;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinResponse;
import com.vaadin.server.VaadinSession;

/**
 * Handles a request by passing it to each registered {@link RequestHandler} in
 * the session in turn until one produces a response. This method is used for
 * requests that have not been handled by any specific functionality in the
 * servlet/portlet.
 * 

* The request handlers are invoked in the reverse order in which they were * added to the session until a response has been produced. This means that the * most recently added handler is used first and the first request handler that * was added to the session is invoked towards the end unless any previous * handler has already produced a response. *

*

* The session is not locked during execution of the request handlers. The * request handler can itself decide if it needs to lock the session or not. *

* * @see VaadinSession#addRequestHandler(RequestHandler) * @see RequestHandler * * @since 7.1 */ public class SessionRequestHandler implements RequestHandler { @Override public boolean handleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response) throws IOException { // Use a copy to avoid ConcurrentModificationException session.lock(); ArrayList requestHandlers; try { requestHandlers = new ArrayList( session.getRequestHandlers()); } finally { session.unlock(); } for (RequestHandler handler : requestHandlers) { if (handler.handleRequest(session, request, response)) { return true; } } // If not handled return false; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy