View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *     http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.shiro.session;
20  
21  import java.io.Serializable;
22  import java.util.Collection;
23  import java.util.Date;
24  
25  /**
26   * A {@code Session} is a stateful data context associated with a single Subject (user, daemon process,
27   * etc.) who interacts with a software system over a period of time.
28   * <p/>
29   * A {@code Session} is intended to be managed by the business tier and accessible via other
30   * tiers without being tied to any given client technology.  This is a <em>great</em> benefit to Java
31   * systems, since until now, the only viable session mechanisms were the
32   * {@code javax.servlet.http.HttpSession} or Stateful Session EJB's, which many times
33   * unnecessarily coupled applications to web or ejb technologies.
34   *
35   * @since 0.1
36   */
37  public interface Session {
38  
39      /**
40       * Returns the unique identifier assigned by the system upon session creation.
41       * <p/>
42       * All return values from this method are expected to have proper {@code toString()},
43       * {@code equals()}, and {@code hashCode()} implementations. Good candidates for such
44       * an identifier are {@link java.util.UUID UUID}s, {@link java.lang.Integer Integer}s, and
45       * {@link java.lang.String String}s.
46       *
47       * @return The unique identifier assigned to the session upon creation.
48       */
49      Serializable getId();
50  
51      /**
52       * Returns the time the session was started; that is, the time the system created the instance.
53       *
54       * @return The time the system created the session.
55       */
56      Date getStartTimestamp();
57  
58      /**
59       * Returns the last time the application received a request or method invocation from the user associated
60       * with this session.  Application calls to this method do not affect this access time.
61       *
62       * @return The time the user last interacted with the system.
63       * @see #touch()
64       */
65      Date getLastAccessTime();
66  
67      /**
68       * Returns the time in milliseconds that the session session may remain idle before expiring.
69       * <ul>
70       * <li>A negative return value means the session will never expire.</li>
71       * <li>A non-negative return value (0 or greater) means the session expiration will occur if idle for that
72       * length of time.</li>
73       * </ul>
74       * <b>*Note:</b> if you are used to the {@code HttpSession}'s {@code getMaxInactiveInterval()} method, the scale on
75       * this method is different: Shiro Sessions use millisecond values for timeout whereas
76       * {@code HttpSession.getMaxInactiveInterval} uses seconds.  Always use millisecond values with Shiro sessions.
77       *
78       * @return the time in milliseconds the session may remain idle before expiring.
79       * @throws InvalidSessionException if the session has been stopped or expired prior to calling this method.
80       * @since 0.2
81       */
82      long getTimeout() throws InvalidSessionException;
83  
84      /**
85       * Sets the time in milliseconds that the session may remain idle before expiring.
86       * <ul>
87       * <li>A negative value means the session will never expire.</li>
88       * <li>A non-negative value (0 or greater) means the session expiration will occur if idle for that
89       * length of time.</li>
90       * </ul>
91       * <p/>
92       * <b>*Note:</b> if you are used to the {@code HttpSession}'s {@code getMaxInactiveInterval()} method, the scale on
93       * this method is different: Shiro Sessions use millisecond values for timeout whereas
94       * {@code HttpSession.getMaxInactiveInterval} uses seconds.  Always use millisecond values with Shiro sessions.
95       *
96       * @param maxIdleTimeInMillis the time in milliseconds that the session may remain idle before expiring.
97       * @throws InvalidSessionException if the session has been stopped or expired prior to calling this method.
98       * @since 0.2
99       */
100     void setTimeout(long maxIdleTimeInMillis) throws InvalidSessionException;
101 
102     /**
103      * Returns the host name or IP string of the host that originated this session, or {@code null}
104      * if the host is unknown.
105      *
106      * @return the host name or IP string of the host that originated this session, or {@code null}
107      * if the host address is unknown.
108      */
109     String getHost();
110 
111     /**
112      * Explicitly updates the {@link #getLastAccessTime() lastAccessTime} of this session to the current time when
113      * this method is invoked.  This method can be used to ensure a session does not time out.
114      * <p/>
115      * Most programmers won't use this method directly and will instead rely on the last access time to be updated
116      * automatically as a result of an incoming web request or remote procedure call/method invocation.
117      * <p/>
118      * However, this method is particularly useful when supporting rich-client applications such as
119      * Java Web Start app, Java or Flash applets, etc.  Although rare, it is possible in a rich-client
120      * environment that a user continuously interacts with the client-side application without a
121      * server-side method call ever being invoked.  If this happens over a long enough period of
122      * time, the user's server-side session could time-out.  Again, such cases are rare since most
123      * rich-clients frequently require server-side method invocations.
124      * <p/>
125      * In this example though, the user's session might still be considered valid because
126      * the user is actively &quot;using&quot; the application, just not communicating with the
127      * server. But because no server-side method calls are invoked, there is no way for the server
128      * to know if the user is sitting idle or not, so it must assume so to maintain session
129      * integrity.  This {@code touch()} method could be invoked by the rich-client application code during those
130      * times to ensure that the next time a server-side method is invoked, the invocation will not
131      * throw an {@link ExpiredSessionException ExpiredSessionException}.  In short terms, it could be used periodically
132      * to ensure a session does not time out.
133      * <p/>
134      * How often this rich-client &quot;maintenance&quot; might occur is entirely dependent upon
135      * the application and would be based on variables such as session timeout configuration,
136      * usage characteristics of the client application, network utilization and application server
137      * performance.
138      *
139      * @throws InvalidSessionException if this session has stopped or expired prior to calling this method.
140      */
141     void touch() throws InvalidSessionException;
142 
143     /**
144      * Explicitly stops (invalidates) this session and releases all associated resources.
145      * <p/>
146      * If this session has already been authenticated (i.e. the {@code Subject} that
147      * owns this session has logged-in), calling this method explicitly might have undesired side effects:
148      * <p/>
149      * It is common for a {@code Subject} implementation to retain authentication state in the
150      * {@code Session}.  If the session
151      * is explicitly stopped by application code by calling this method directly, it could clear out any
152      * authentication state that might exist, thereby effectively removing
153      *      the &quot;authenticated&quot; state of the {@code Subject}.
154      * <p/>
155      * As such, you might consider {@link org.apache.shiro.subject.Subject#logout logging-out} the 'owning'
156      * {@code Subject} instead of manually calling this method, as a log out is expected to stop the
157      * corresponding session automatically, and also allows framework code to execute additional cleanup logic.
158      *
159      * @throws InvalidSessionException if this session has stopped or expired prior to calling this method.
160      */
161     void stop() throws InvalidSessionException;
162 
163     /**
164      * Returns the keys of all the attributes stored under this session.  If there are no
165      * attributes, this returns an empty collection.
166      *
167      * @return the keys of all attributes stored under this session, or an empty collection if
168      * there are no session attributes.
169      * @throws InvalidSessionException if this session has stopped or expired prior to calling this method.
170      * @since 0.2
171      */
172     Collection<Object> getAttributeKeys() throws InvalidSessionException;
173 
174     /**
175      * Returns the object bound to this session identified by the specified key.  If there is no
176      * object bound under the key, {@code null} is returned.
177      *
178      * @param key the unique name of the object bound to this session
179      * @return the object bound under the specified {@code key} name or {@code null} if there is
180      * no object bound under that name.
181      * @throws InvalidSessionException if this session has stopped or expired prior to calling
182      *                                 this method.
183      */
184     Object getAttribute(Object key) throws InvalidSessionException;
185 
186     /**
187      * Binds the specified {@code value} to this session, uniquely identified by the specified
188      * {@code key} name.  If there is already an object bound under the {@code key} name, that
189      * existing object will be replaced by the new {@code value}.
190      * <p/>
191      * If the {@code value} parameter is null, it has the same effect as if
192      * {@link #removeAttribute(Object) removeAttribute} was called.
193      *
194      * @param key   the name under which the {@code value} object will be bound in this session
195      * @param value the object to bind in this session.
196      * @throws InvalidSessionException if this session has stopped or expired prior to calling
197      *                                 this method.
198      */
199     void setAttribute(Object key, Object value) throws InvalidSessionException;
200 
201     /**
202      * Removes (unbinds) the object bound to this session under the specified {@code key} name.
203      *
204      * @param key the name uniquely identifying the object to remove
205      * @return the object removed or {@code null} if there was no object bound under the name
206      * {@code key}.
207      * @throws InvalidSessionException if this session has stopped or expired prior to calling
208      *                                 this method.
209      */
210     Object removeAttribute(Object key) throws InvalidSessionException;
211 }