com.vaadin.server.
Class SynchronizedRequestHandler
- java.lang.Object
-
- com.vaadin.server.SynchronizedRequestHandler
-
All Implemented Interfaces:
Direct Known Subclasses:
BootstrapHandler
,HeartbeatHandler
,UidlRequestHandler
,UIInitHandler
,UnsupportedBrowserHandler
public abstract class SynchronizedRequestHandler extends Object implements RequestHandler
RequestHandler which takes care of locking and unlocking of the VaadinSession automatically. The session is locked before
synchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
is called and unlocked after it has completed.Since:
7.1
Author:
Vaadin Ltd
See Also:
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
SynchronizedRequestHandler.ResponseWriter
ResponseWriter is optionally returned by request handlers which implement
synchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse, String)
The ResponseWriter will be executed byhandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
without holding Vaadin session lock.
-
Field Summary
Fields Modifier and Type Field Description static int
MAX_BUFFER_SIZE
Maximum capacity of request body.
-
Constructor Summary
Constructors Constructor Description SynchronizedRequestHandler()
-
Method Summary
All Methods Modifier and Type Method Description protected boolean
canHandleRequest(VaadinRequest request)
Check whether a request may be handled by this handler.
static String
getRequestBody(Reader reader)
Reads the request body into a String.
boolean
handleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response)
Called when a request needs to be handled.
boolean
isReadAndWriteOutsideSessionLock()
Returns whether request body should be read and the response written without holding
VaadinSession
lock.abstract boolean
synchronizedHandleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response)
Identical to
handleRequest(VaadinSession, VaadinRequest, VaadinResponse)
except theVaadinSession
is locked before this is called and unlocked after this has completed.Optional<SynchronizedRequestHandler.ResponseWriter>
synchronizedHandleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response, String requestBody)
Identical to
synchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
except theVaadinSession
is locked before this is called and the response requestBody has been read before locking the session and is provided as a separate parameter.
-
-
-
Method Detail
-
handleRequest
public boolean handleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response) throws IOException
Description copied from interface:
RequestHandler
Called when a request needs to be handled. If a response is written, this method should return
true
to indicate that no more request handlers should be invoked for the request.Note that request handlers by default do not lock the session. If you are using VaadinSession or anything inside the VaadinSession you must ensure the session is locked. This can be done by extending
SynchronizedRequestHandler
or by usingVaadinSession.accessSynchronously(Runnable)
orUI.accessSynchronously(Runnable)
.Specified by:
handleRequest
in interfaceRequestHandler
Parameters:
session
- The session for the requestrequest
- The request to handleresponse
- The response object to which a response can be written.Returns:
true if a response has been written and no further request handlers should be called, otherwise false
Throws:
IOException
- If an IO error occurred
-
synchronizedHandleRequest
public abstract boolean synchronizedHandleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response) throws IOException
Identical to
handleRequest(VaadinSession, VaadinRequest, VaadinResponse)
except theVaadinSession
is locked before this is called and unlocked after this has completed.Parameters:
session
- The session for the requestrequest
- The request to handleresponse
- The response object to which a response can be written.Returns:
true if a response has been written and no further request handlers should be called, otherwise false
Throws:
IOException
- If an IO error occurredSee Also:
-
isReadAndWriteOutsideSessionLock
public boolean isReadAndWriteOutsideSessionLock()
Returns whether request body should be read and the response written without holding
VaadinSession
lock.Returns:
true if
synchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse, String)
should be called. Returns false ifsynchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
should be called.Since:
-
synchronizedHandleRequest
public Optional<SynchronizedRequestHandler.ResponseWriter> synchronizedHandleRequest(VaadinSession session, VaadinRequest request, VaadinResponse response, String requestBody) throws IOException, UnsupportedOperationException
Identical to
synchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
except theVaadinSession
is locked before this is called and the response requestBody has been read before locking the session and is provided as a separate parameter.Parameters:
session
- The session for the requestrequest
- The request to handleresponse
- The response object to which a response can be written.requestBody
- Request body pre-read from the request objectReturns:
a ResponseWriter wrapped into an Optional, if this handler will write the response and no further request handlers should be called, otherwise an empty Optional. The ResponseWriter will be executed after the VaadinSession is unlocked.
Throws:
IOException
- If an IO error occurred.Since:
See Also:
-
canHandleRequest
protected boolean canHandleRequest(VaadinRequest request)
Check whether a request may be handled by this handler. This can be used as an optimization to avoid locking the session just to investigate some method property. The default implementation just returns
true
which means that all requests will be handled by callingsynchronizedHandleRequest(VaadinSession, VaadinRequest, VaadinResponse)
with the session locked.Parameters:
request
- the request to handleReturns:
true
if the request handling should continue once the session has been locked;false
if there's no need to lock the session since the request would still not be handled.Since:
7.2
-
getRequestBody
public static String getRequestBody(Reader reader) throws IOException
Reads the request body into a String.
Parameters:
reader
- a Reader containing the body of the requestReturns:
request body as a String
Throws:
IOException
- If an IO error occurred.Since:
-
-