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: AttributeStatement.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.AttributeStatementType;
35: import com.sun.xml.wss.saml.util.SAMLJAXBUtil;
36: import org.w3c.dom.Element;
37:
38: import java.util.List;
39: import java.util.logging.Logger;
40:
41: import javax.xml.bind.JAXBContext;
42:
43: /**
44: *The <code>AttributeStatement</code> element supplies a statement by the issuer that the
45: *specified subject is associated with the specified attributes.
46: */
47: public class AttributeStatement extends AttributeStatementType
48: implements com.sun.xml.wss.saml.AttributeStatement {
49:
50: protected static final Logger log = Logger.getLogger(
51: LogDomainConstants.WSS_API_DOMAIN,
52: LogDomainConstants.WSS_API_DOMAIN_BUNDLE);
53:
54: private void setAttributes(List attr) {
55: this .attribute = attr;
56: }
57:
58: /**
59: *Dafault constructor
60: */
61: public AttributeStatement(Subject subj, List attr) {
62: setSubject(subj);
63: setAttributes(attr);
64: }
65:
66: /**
67: * Constructs an <code>AttributStatement</code> element from an existing
68: * XML block
69: * @param element representing a DOM tree element
70: * @exception SAMLException if there is an error in the sender or in the
71: * element definition.
72: */
73: public static AttributeStatementType fromElement(Element element)
74: throws SAMLException {
75: try {
76: JAXBContext jc = SAMLJAXBUtil.getJAXBContext();
77:
78: javax.xml.bind.Unmarshaller u = jc.createUnmarshaller();
79: return (AttributeStatementType) u.unmarshal(element);
80: } catch (Exception ex) {
81: throw new SAMLException(ex.getMessage());
82: }
83: }
84: }
|