Be sure to use inbound message issuer and not peer Id
[java-idp.git] / src / edu / internet2 / middleware / shibboleth / idp / profile / SAMLMetadataProfileHandler.java
1 /*
2  * Copyright [2007] [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.io.File;
20 import java.io.OutputStreamWriter;
21
22 import javax.servlet.http.HttpServletRequestWrapper;
23
24 import org.opensaml.Configuration;
25 import org.opensaml.saml2.metadata.provider.FilesystemMetadataProvider;
26 import org.opensaml.saml2.metadata.provider.MetadataProviderException;
27 import org.opensaml.ws.transport.InTransport;
28 import org.opensaml.ws.transport.OutTransport;
29 import org.opensaml.xml.XMLObject;
30 import org.opensaml.xml.io.Marshaller;
31 import org.opensaml.xml.util.XMLHelper;
32 import org.slf4j.Logger;
33 import org.slf4j.LoggerFactory;
34
35 import edu.internet2.middleware.shibboleth.common.profile.ProfileException;
36 import edu.internet2.middleware.shibboleth.common.profile.provider.AbstractRequestURIMappedProfileHandler;
37
38 /**
39  * A simple profile handler that serves up the IdP's metadata. Eventually this handler should auto generate the metadata
40  * but, for now, it just provides information from a static file.
41  */
42 public class SAMLMetadataProfileHandler extends AbstractRequestURIMappedProfileHandler {
43
44     /** Class logger. */
45     private final Logger log = LoggerFactory.getLogger(SAMLMetadataProfileHandler.class);
46
47     /** Metadata provider. */
48     private FilesystemMetadataProvider metadataProvider;
49
50     /**
51      * Constructor.
52      * 
53      * @param metadataFile the IdPs metadata file
54      */
55     public SAMLMetadataProfileHandler(String metadataFile) {
56         try {
57             metadataProvider = new FilesystemMetadataProvider(new File(metadataFile));
58         } catch (MetadataProviderException e) {
59             log.error("Unable to read metadata file " + metadataFile, e);
60         }
61     }
62
63     /** {@inheritDoc} */
64     public void processRequest(InTransport in, OutTransport out) throws ProfileException {
65         XMLObject metadata;
66
67         try {
68             String requestedEntity = ((HttpServletRequestWrapper) in).getParameter("entity");
69             if (requestedEntity == null) {
70                 metadata = metadataProvider.getEntityDescriptor(requestedEntity);
71             } else {
72                 metadata = metadataProvider.getMetadata();
73             }
74
75             Marshaller marshaller = Configuration.getMarshallerFactory().getMarshaller(metadata);
76             XMLHelper.writeNode(marshaller.marshall(metadata), new OutputStreamWriter(out.getOutgoingStream()));
77         } catch (Exception e) {
78             log.error("Unable to retrieve and return metadata", e);
79             throw new ProfileException(e);
80         }
81     }
82 }