Add optional, but on by default, check to ensure that IdP session cookie comes from...
[java-idp.git] / src / main / java / edu / internet2 / middleware / shibboleth / idp / session / impl / SessionImpl.java
1 /*
2  * Copyright 2006 University Corporation for Advanced Internet Development, Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 package edu.internet2.middleware.shibboleth.idp.session.impl;
18
19 import java.util.HashMap;
20 import java.util.Map;
21
22 import javax.crypto.SecretKey;
23
24 import edu.internet2.middleware.shibboleth.common.session.impl.AbstractSession;
25 import edu.internet2.middleware.shibboleth.idp.session.AuthenticationMethodInformation;
26 import edu.internet2.middleware.shibboleth.idp.session.ServiceInformation;
27 import edu.internet2.middleware.shibboleth.idp.session.Session;
28
29 /** Session information for user logged into the IdP. */
30 public class SessionImpl extends AbstractSession implements Session {
31
32     /** Serial version UID. */
33     private static final long serialVersionUID = 2927868242208211623L;
34     
35     /** Secret key associated with the session. */
36     private SecretKey sessionKey;
37
38     /** The list of methods used to authenticate the user. */
39     private HashMap<String, AuthenticationMethodInformation> authnMethods;
40
41     /** The list of services to which the user has logged in. */
42     private HashMap<String, ServiceInformation> servicesInformation;
43
44     /**
45      * Constructor.
46      * 
47      * @param sessionId ID of the session
48      * @param key a secret key to associate with the session
49      * @param timeout inactivity timeout for the session in milliseconds
50      */
51     public SessionImpl(String sessionId, SecretKey key, long timeout) {
52         super(sessionId, timeout);
53
54         sessionKey = key;
55         
56         authnMethods = new HashMap<String, AuthenticationMethodInformation>();
57         servicesInformation = new HashMap<String, ServiceInformation>();
58     }
59     
60     /** {@inheritDoc} */
61     public SecretKey getSessionSecretKey() {
62         return sessionKey;
63     }
64
65     /** {@inheritDoc} */
66     public Map<String, AuthenticationMethodInformation> getAuthenticationMethods() {
67         return authnMethods;
68     }
69
70     /** {@inheritDoc} */
71     public Map<String, ServiceInformation> getServicesInformation() {
72         return servicesInformation;
73     }
74
75     /**
76      * Gets the service information for the given entity ID.
77      * 
78      * @param entityId entity ID to retrieve the service information for
79      * 
80      * @return the service information or null
81      */
82     public ServiceInformation getServiceInformation(String entityId) {
83         return servicesInformation.get(entityId);
84     }
85 }