/* * Copyright [2005] [University Corporation for Advanced Internet Development, Inc.] * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.opensaml.saml2.metadata.impl; import java.util.ArrayList; import java.util.Collections; import java.util.List; import javax.xml.namespace.QName; import org.opensaml.saml2.metadata.AssertionIDRequestService; import org.opensaml.saml2.metadata.AttributeService; import org.opensaml.saml2.metadata.AuthnAuthorityDescriptor; import org.opensaml.saml2.metadata.AuthnQueryService; import org.opensaml.saml2.metadata.Endpoint; import org.opensaml.saml2.metadata.NameIDFormat; import org.opensaml.xml.XMLObject; import org.opensaml.xml.util.XMLObjectChildrenList; /** * Concreate implementation of {@link org.opensaml.saml2.metadata.AuthnAuthorityDescriptor} */ public class AuthnAuthorityDescriptorImpl extends RoleDescriptorImpl implements AuthnAuthorityDescriptor { /** AuthnQueryService endpoints. */ private final XMLObjectChildrenList<AuthnQueryService> authnQueryServices; /** AuthnQueryService endpoints. */ private final XMLObjectChildrenList<AssertionIDRequestService> assertionIDRequestServices; /** NameID formats supported by this descriptor. */ private final XMLObjectChildrenList<NameIDFormat> nameIDFormats; /** * Constructor . * * @param namespaceURI the namespace the element is in * @param elementLocalName the local name of the XML element this Object represents * @param namespacePrefix the prefix for the given namespace */ protected AuthnAuthorityDescriptorImpl(String namespaceURI, String elementLocalName, String namespacePrefix) { super(namespaceURI, elementLocalName, namespacePrefix); authnQueryServices = new XMLObjectChildrenList<AuthnQueryService>(this); assertionIDRequestServices = new XMLObjectChildrenList<AssertionIDRequestService>(this); nameIDFormats = new XMLObjectChildrenList<NameIDFormat>(this); } /** {@inheritDoc} */ public List<AuthnQueryService> getAuthnQueryServices() { return authnQueryServices; } /** {@inheritDoc} */ public List<AssertionIDRequestService> getAssertionIDRequestServices() { return assertionIDRequestServices; } /** {@inheritDoc} */ public List<NameIDFormat> getNameIDFormats() { return nameIDFormats; } /** {@inheritDoc} */ public List<Endpoint> getEndpoints() { List<Endpoint> endpoints = new ArrayList<Endpoint>(); endpoints.addAll(authnQueryServices); endpoints.addAll(assertionIDRequestServices); return Collections.unmodifiableList(endpoints); } /** {@inheritDoc} */ public List<Endpoint> getEndpoints(QName type) { if(type.equals(AuthnQueryService.DEFAULT_ELEMENT_NAME)){ return Collections.unmodifiableList(new ArrayList<Endpoint>(authnQueryServices)); }else if(type.equals(AssertionIDRequestService.DEFAULT_ELEMENT_NAME)){ return Collections.unmodifiableList(new ArrayList<Endpoint>(assertionIDRequestServices)); } return null; } /** {@inheritDoc} */ public List<XMLObject> getOrderedChildren() { ArrayList<XMLObject> children = new ArrayList<XMLObject>(); children.addAll(super.getOrderedChildren()); children.addAll(authnQueryServices); children.addAll(assertionIDRequestServices); children.addAll(nameIDFormats); return Collections.unmodifiableList(children); } }