From 98a934554a8a88e0b64e9bc4069ee2af82286efa Mon Sep 17 00:00:00 2001 From: Leif Åstrand Date: Sun, 9 Sep 2012 21:49:19 +0300 Subject: Allow storing values in VaadinSession (#9514) --- server/src/com/vaadin/server/VaadinSession.java | 109 ++++++++++++++++++++++++ 1 file changed, 109 insertions(+) (limited to 'server/src') diff --git a/server/src/com/vaadin/server/VaadinSession.java b/server/src/com/vaadin/server/VaadinSession.java index c6b2d91f29..a91c011ddf 100644 --- a/server/src/com/vaadin/server/VaadinSession.java +++ b/server/src/com/vaadin/server/VaadinSession.java @@ -204,6 +204,8 @@ public class VaadinSession implements HttpSessionBindingListener, Serializable { private transient WrappedSession session; + private final Map attributes = new HashMap(); + /** * @see javax.servlet.http.HttpSessionBindingListener#valueBound(HttpSessionBindingEvent) */ @@ -1306,4 +1308,111 @@ public class VaadinSession implements HttpSessionBindingListener, Serializable { return lock; } + /** + * Stores a value in this vaadin session. This can be used to associate data + * with the current user so that it can be retrieved at a later point from + * some other part of the application. Setting the value to + * null clears the stored value. + * + * @see #getAttribute(String) + * + * @param name + * the name to associate the value with, can not be + * null + * @param value + * the value to associate with the name, or null to + * remove a previous association. + */ + public void setAttribute(String name, Object value) { + if (name == null) { + throw new IllegalArgumentException("name can not be null"); + } + if (value != null) { + attributes.put(name, value); + } else { + attributes.remove(name); + } + } + + /** + * Stores a value in this vaadin session. This can be used to associate data + * with the current user so that it can be retrieved at a later point from + * some other part of the application. Setting the value to + * null clears the stored value. + *

+ * The fully qualified name of the type is used as the name when storing the + * value. The outcome of calling this method is thus the same as if calling
+ *
+ * setAttribute(type.getName(), value); + * + * @see #getAttribute(Class) + * @see #setAttribute(String, Object) + * + * @param type + * the type that the stored value represents, can not be null + * @param value + * the value to associate with the type, or null to + * remove a previous association. + */ + public void setAttribute(Class type, T value) { + if (type == null) { + throw new IllegalArgumentException("type can not be null"); + } + if (value != null && !type.isInstance(value)) { + throw new IllegalArgumentException("value of type " + + type.getName() + " expected but got " + + value.getClass().getName()); + } + setAttribute(type.getName(), value); + } + + /** + * Gets a stored attribute value. If a value has been stored for the + * session, that value is returned. If no value is stored for the name, + * null is returned. + * + * @see #setAttribute(String, Object) + * + * @param name + * the name of the value to get, can not be null. + * @return the value, or null if no value has been stored or if + * it has been set to null. + */ + public Object getAttribute(String name) { + if (name == null) { + throw new IllegalArgumentException("name can not be null"); + } + return attributes.get(name); + } + + /** + * Gets a stored attribute value. If a value has been stored for the + * session, that value is returned. If no value is stored for the name, + * null is returned. + *

+ * The fully qualified name of the type is used as the name when getting the + * value. The outcome of calling this method is thus the same as if calling
+ *
+ * getAttribute(type.getName()); + * + * @see #setAttribute(Class, Object) + * @see #getAttribute(String) + * + * @param type + * the type of the value to get, can not be null. + * @return the value, or null if no value has been stored or if + * it has been set to null. + */ + public T getAttribute(Class type) { + if (type == null) { + throw new IllegalArgumentException("type can not be null"); + } + Object value = getAttribute(type.getName()); + if (value == null) { + return null; + } else { + return type.cast(value); + } + } + } -- cgit v1.2.3