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: Attribute.java,v 1.5 2007/01/08 16:06:05 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.AttributeType;
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>Attribute</code> element specifies an attribute of the assertion subject.
45: * The <code>Attribute</code> element is an extension of the <code>AttributeDesignator</code> element
46: * that allows the attribute value to be specified.
47: */
48: public class Attribute extends AttributeType implements
49: com.sun.xml.wss.saml.Attribute {
50:
51: protected static final Logger log = Logger.getLogger(
52: LogDomainConstants.WSS_API_DOMAIN,
53: LogDomainConstants.WSS_API_DOMAIN_BUNDLE);
54:
55: /**
56: * Constructs an attribute element from an existing XML block.
57: *
58: * @param element representing a DOM tree element.
59: * @exception SAMLException if there is an error in the sender or in the
60: * element definition.
61: */
62: public static AttributeType fromElement(Element element)
63: throws SAMLException {
64: try {
65: JAXBContext jc = SAMLJAXBUtil.getJAXBContext();
66:
67: javax.xml.bind.Unmarshaller u = jc.createUnmarshaller();
68: return (AttributeType) u.unmarshal(element);
69: } catch (Exception ex) {
70: throw new SAMLException(ex.getMessage());
71: }
72: }
73:
74: private void setAttributeValue(List values) {
75: this .attributeValue = values;
76: }
77:
78: /**
79: * Constructs an instance of <code>Attribute</code>.
80: *
81: * @param name A String representing <code>AttributeName</code> (the name
82: * of the attribute).
83: * @param nameSpace A String representing the namespace in which
84: * <code>AttributeName</code> elements are interpreted.
85: * @param values A List of DOM element representing the
86: * <code>AttributeValue</code> object.
87: * @exception SAMLException if there is an error in the sender or in the
88: * element definition.
89: */
90: public Attribute(String name, String nameSpace, List values) {
91: setAttributeName(name);
92: setAttributeNamespace(nameSpace);
93: setAttributeValue(values);
94: }
95: }
|