01: /*
02: * The contents of this file are subject to the terms
03: * of the Common Development and Distribution License
04: * (the "License"). You may not use this file except
05: * in compliance with the License.
06: *
07: * You can obtain a copy of the license at
08: * https://jwsdp.dev.java.net/CDDLv1.0.html
09: * See the License for the specific language governing
10: * permissions and limitations under the License.
11: *
12: * When distributing Covered Code, include this CDDL
13: * HEADER in each file and include the License file at
14: * https://jwsdp.dev.java.net/CDDLv1.0.html If applicable,
15: * add the following below this CDDL HEADER, with the
16: * fields enclosed by brackets "[]" replaced with your
17: * own identifying information: Portions Copyright [yyyy]
18: * [name of copyright owner]
19: */
20: /*
21: * $Id: AudienceRestrictionCondition.java,v 1.5 2007/01/08 16:06:06 shyam_rao Exp $
22: */
23:
24: /*
25: * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
26: * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
27: */
28:
29: package com.sun.xml.wss.saml.assertion.saml11.jaxb20;
30:
31: import com.sun.xml.wss.saml.SAMLException;
32:
33: import com.sun.xml.wss.logging.LogDomainConstants;
34: import com.sun.xml.wss.saml.internal.saml11.jaxb20.AudienceRestrictionConditionType;
35: import com.sun.xml.wss.saml.util.SAMLJAXBUtil;
36:
37: import java.util.List;
38: import java.util.logging.Logger;
39:
40: import javax.xml.bind.JAXBContext;
41:
42: /**
43: * This is an implementation of the abstract <code>Condition</code> class, which
44: * specifes that the assertion this AuthenticationCondition is part of, is
45: *addressed to one or more specific audience.
46: */
47: public class AudienceRestrictionCondition extends
48: AudienceRestrictionConditionType implements
49: com.sun.xml.wss.saml.AudienceRestrictionCondition {
50:
51: protected static final Logger log = Logger.getLogger(
52: LogDomainConstants.WSS_API_DOMAIN,
53: LogDomainConstants.WSS_API_DOMAIN_BUNDLE);
54:
55: private void setAudience(List audience) {
56: this .audience = audience;
57: }
58:
59: /**
60: This constructor takes in a <code>List</code> of audience for this
61: condition, each of them being a String.
62: @param audience A List of audience to be included within this condition
63: @exception SAMLException if the <code>List</code> is empty or if there is
64: some error in processing the contents of the <code>List</code>
65: */
66: public AudienceRestrictionCondition(List audience) {
67: setAudience(audience);
68: }
69:
70: /**
71: * Constructs an <code>AudienceRestrictionCondition</code> element from an
72: * existing XML block.
73: *
74: * @param audienceRestrictionConditionElement A
75: * <code>org.w3c.dom.Element</code> representing DOM tree for
76: * <code>AudienceRestrictionCondition</code> object.
77: * @exception SAMLException if it could not process the
78: * <code>org.w3c.dom.Element</code> properly, implying that there
79: * is an error in the sender or in the element definition.
80: */
81: public static AudienceRestrictionConditionType fromElement(
82: org.w3c.dom.Element element) throws SAMLException {
83: try {
84: JAXBContext jc = SAMLJAXBUtil.getJAXBContext();
85:
86: javax.xml.bind.Unmarshaller u = jc.createUnmarshaller();
87: return (AudienceRestrictionConditionType) u
88: .unmarshal(element);
89: } catch (Exception ex) {
90: throw new SAMLException(ex.getMessage());
91: }
92: }
93: }
|