Log full exception chain.
[java-idp.git] / src / edu / internet2 / middleware / shibboleth / common / TargetFederationComponent.java
1 /*
2  * The Shibboleth License, Version 1. Copyright (c) 2002 University Corporation for Advanced Internet Development, Inc.
3  * All rights reserved Redistribution and use in source and binary forms, with or without modification, are permitted
4  * provided that the following conditions are met: Redistributions of source code must retain the above copyright
5  * notice, this list of conditions and the following disclaimer. Redistributions in binary form must reproduce the
6  * above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other
7  * materials provided with the distribution, if any, must include the following acknowledgment: "This product includes
8  * software developed by the University Corporation for Advanced Internet Development <http://www.ucaid.edu>Internet2
9  * Project. Alternately, this acknowledegement may appear in the software itself, if and wherever such third-party
10  * acknowledgments normally appear. Neither the name of Shibboleth nor the names of its contributors, nor Internet2,
11  * nor the University Corporation for Advanced Internet Development, Inc., nor UCAID may be used to endorse or promote
12  * products derived from this software without specific prior written permission. For written permission, please
13  * contact shibboleth@shibboleth.org Products derived from this software may not be called Shibboleth, Internet2,
14  * UCAID, or the University Corporation for Advanced Internet Development, nor may Shibboleth appear in their name,
15  * without prior written permission of the University Corporation for Advanced Internet Development. THIS SOFTWARE IS
16  * PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND WITH ALL FAULTS. ANY EXPRESS OR IMPLIED WARRANTIES,
17  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND
18  * NON-INFRINGEMENT ARE DISCLAIMED AND THE ENTIRE RISK OF SATISFACTORY QUALITY, PERFORMANCE, ACCURACY, AND EFFORT IS
19  * WITH LICENSEE. IN NO EVENT SHALL THE COPYRIGHT OWNER, CONTRIBUTORS OR THE UNIVERSITY CORPORATION FOR ADVANCED
20  * INTERNET DEVELOPMENT, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
22  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
23  * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24  * POSSIBILITY OF SUCH DAMAGE.
25  */
26
27 package edu.internet2.middleware.shibboleth.common;
28
29 import java.util.ArrayList;
30 import java.util.Iterator;
31
32 import javax.servlet.http.HttpServlet;
33
34 import org.apache.log4j.Logger;
35 import org.w3c.dom.Element;
36
37 import edu.internet2.middleware.shibboleth.metadata.Metadata;
38 import edu.internet2.middleware.shibboleth.metadata.MetadataException;
39 import edu.internet2.middleware.shibboleth.metadata.Provider;
40
41 /**
42  * @author Walter Hoehn (wassa@columbia.edu)
43  */
44 public class TargetFederationComponent extends HttpServlet implements Metadata {
45
46         private static Logger   log                     = Logger.getLogger(TargetFederationComponent.class.getName());
47
48         private ArrayList               fedMetadata     = new ArrayList();
49
50         protected void addFederationProvider(Element element) {
51                 log.debug("Found Federation Provider configuration element.");
52                 if (!element.getTagName().equals("FederationProvider")) {
53                         log.error("Error while attemtping to load Federation Provider.  Malformed provider specificaion.");
54                         return;
55                 }
56
57                 try {
58                         fedMetadata.add(FederationProviderFactory.loadProvider(element));
59                 } catch (MetadataException e) {
60                         log.error("Unable to load Federation Provider.  Skipping...");
61                 }
62         }
63
64         protected int providerCount() {
65                 return fedMetadata.size();
66         }
67
68         public Provider lookup(String providerId) {
69
70                 Iterator iterator = fedMetadata.iterator();
71                 while (iterator.hasNext()) {
72                         Provider provider = ((Metadata) iterator.next()).lookup(providerId);
73                         if (provider != null) {
74                                 return provider;
75                         }
76                 }
77                 return null;
78         }
79 }
80
81 class FederationProviderFactory {
82
83         private static Logger   log     = Logger.getLogger(FederationProviderFactory.class.getName());
84
85         public static Metadata loadProvider(Element e) throws MetadataException {
86
87                 String className = e.getAttribute("type");
88                 if (className == null || className.equals("")) {
89                         log.error("Federation Provider requires specification of the attribute \"type\".");
90                         throw new MetadataException("Failed to initialize Federation Provider.");
91                 } else {
92                         try {
93                                 Class[] params = {Class.forName("org.w3c.dom.Element"),};
94                                 return (Metadata) Class.forName(className).getConstructor(params).newInstance(new Object[]{e});
95                         } catch (Exception loaderException) {
96                                 log.error("Failed to load Federation Provider implementation class: " + loaderException);
97                 Throwable cause = loaderException.getCause();
98                 while (cause != null) {
99                                         log.error("caused by: " + cause);
100                     cause = cause.getCause();
101                 }
102                                 throw new MetadataException("Failed to initialize Federation Provider.");
103                         }
104                 }
105         }
106 }