Begin fleshing out request/response profile objects
[java-idp.git] / src / edu / internet2 / middleware / shibboleth / idp / profile / ProfileRequestDispatcher.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.profile;
18
19 import java.util.Map;
20
21 import javax.servlet.ServletException;
22 import javax.servlet.http.HttpServletRequest;
23 import javax.servlet.http.HttpServletResponse;
24
25 import org.springframework.web.servlet.HttpServletBean;
26
27 import edu.internet2.middleware.shibboleth.common.profile.ProfileHandler;
28 import edu.internet2.middleware.shibboleth.common.relyingparty.RelyingPartyManager;
29 import edu.internet2.middleware.shibboleth.common.session.SessionManager;
30 import edu.internet2.middleware.shibboleth.idp.session.Session;
31
32 /**
33  * Servlet responsible for dispatching incoming requests to the appropriate {@link ProfileHandler}.
34  */
35 public class ProfileRequestDispatcher extends HttpServletBean {
36
37     /** Registered profile handlers. */
38     private Map<String, ProfileHandler> profileHandlers;
39
40     /** User session manager. */
41     private SessionManager<Session> sessionManager;
42
43     /** Relying party configuration manager. */
44     private RelyingPartyManager rpManager;
45
46     /**
47      * Gets the profile handlers currently registered.
48      * 
49      * @return profile handlers currently registered
50      */
51     public Map<String, ProfileHandler> getProfileHandlers() {
52         return profileHandlers;
53     }
54
55     /**
56      * Sets all the profile handlers to use.
57      * 
58      * @param handlers the profile handlers to use
59      */
60     public void setProfileHandlers(Map<String, ProfileHandler> handlers) {
61         profileHandlers = handlers;
62     }
63
64     /** {@inheritDoc} */
65     public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException {
66         String path = request.getPathInfo();
67         ProfileHandler handler = profileHandlers.get(path);
68
69         if (handler != null) {
70             ShibbolethProfileRequest profileReq = new ShibbolethProfileRequest(request, null, sessionManager, rpManager);
71             ShibbolethProfileResponse profileResp = new ShibbolethProfileResponse(response, null);
72             handler.processRequest(profileReq, profileResp);
73         }
74
75         // TODO handle case where there is no registered profile
76     }
77 }