a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Copyright (c) 2006 Sun Microsystems Inc. All Rights Reserved
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * The contents of this file are subject to the terms
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * of the Common Development and Distribution License
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * (the License). You may not use this file except in
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * compliance with the License.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * You can obtain a copy of the License at
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * https://opensso.dev.java.net/public/CDDLv1.0.html or
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * See the License for the specific language governing
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * permission and limitations under the License.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * When distributing Covered Code, include this CDDL
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Header Notice in each file and include the License file
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * If applicable, add the following below the CDDL Header,
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * with the fields enclosed by brackets [] replaced by
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * your own identifying information:
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * "Portions Copyrighted [year] [name of copyright owner]"
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * $Id: Modify.java,v 1.2 2008/06/25 05:47:10 qcheng Exp $
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Fosterimport com.sun.identity.liberty.ws.disco.common.DiscoConstants;
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Fosterimport com.sun.identity.liberty.ws.disco.common.DiscoUtils;
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * This class represents a discovery modify request.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * The following schema fragment specifies the expected content within
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * the <code>Modify</code> object.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <xs:element name="Modify" type="ModifyType"/>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <complexType name="ModifyType">
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <complexContent>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <sequence>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <group ref="{urn:liberty:disco:2003-08}ResourceIDGroup"/>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <element name="InsertEntry" type="{urn:liberty:disco:2003-08}InsertEntryType" maxOccurs="unbounded" minOccurs="0"/>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <element name="RemoveEntry" type="{urn:liberty:disco:2003-08}RemoveEntryType" maxOccurs="unbounded" minOccurs="0"/>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * </sequence>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * <attribute name="id" type="{http://www.w3.org/2001/XMLSchema}ID" />
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * </restriction>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * </complexContent>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * </complexType>
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @supported.all.api
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster private EncryptedResourceID encryptResID = null;
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Constructor.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param resourceID ID for the discovery resource to be modified
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param insertEntry List of insert entries
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param removeEntry List of remove entries
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Constructor.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param resourceID Encrypted Discovery Resource ID to be modified
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param insertEntry List of insert entries
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param removeEntry List of remove entries
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Default constructor.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Constructor.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param root Modify DOM element
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @exception DiscoveryException if error occurs
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster public Modify(Element root) throws DiscoveryException {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): null input.");
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster if (((nodeName = root.getLocalName()) == null) ||
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster ((nameSpaceURI = root.getNamespaceURI()) == null) ||
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster (!nameSpaceURI.equals(DiscoConstants.DISCO_NS)))
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): wrong input");
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster for (int i = 0, length = contentnl.getLength(); i < length; i++) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster if ((nodeName = child.getLocalName()) != null) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster nameSpaceURI = ((Element) child).getNamespaceURI();
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster (!nameSpaceURI.equals(DiscoConstants.DISCO_NS)))
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster if ((resourceID != null) || (encryptResID != null)) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): Included"
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster + " more than one ResourceIDGroup element.");
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.bundle.getString("moreResourceIDGroup"));
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster } else if (nodeName.equals("EncryptedResourceID")) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster if ((resourceID != null) || (encryptResID != null)) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): Included"
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster + " more than one ResourceIDGroup element.");
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.bundle.getString("moreResourceIDGroup"));
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster encryptResID = new EncryptedResourceID((Element) child);
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): invalid"
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster } // if nodeName != null
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster } // done for the nl loop
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster // make sure there is a ResourceID or EncryptedResourceID
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster if ((resourceID == null) && (encryptResID == null)) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.debug.message("Modify(Element): missing ResourceID "
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster + "or EncryptedResourceID element.");
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster DiscoUtils.bundle.getString("missingResourceIDGroup"));
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets the encrypted resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return the encrypted resource ID.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #setEncryptedResourceID(EncryptedResourceID)
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster public EncryptedResourceID getEncryptedResourceID() {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Sets the encrypted resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param value the encrypted resource ID.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #getEncryptedResourceID()
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster public void setEncryptedResourceID(EncryptedResourceID value) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets the resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #setResourceID(ResourceID)
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Sets resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param resourceID resource ID for the discovery resource to be modified.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #getResourceID()
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster public void setResourceID(ResourceID resourceID) {
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets id attribute.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return id attribute.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets the value of the <code>RemoveEntry</code> property.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return List of <code>RemoveEntry</code> objects
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #setRemoveEntry(List)
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Sets the value of the <code>RemoveEntry</code> property.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param removes List of <code>RemoveEntry</code> object.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #getRemoveEntry()
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets the value of the <code>InsertEntry</code> property.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return List of <code>InsertEntry</code> object
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #setInsertEntry(List)
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Sets the value of the <code>InsertEntry</code> property.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @param inserts List of <code>InsertEntry</code> object.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @see #getInsertEntry()
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * Gets string format.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster * @return formatted String.
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster sb.append("<Modify xmlns=\"").append(DiscoConstants.DISCO_NS).
a688bcbb4bcff5398fdd29b86f83450257dc0df4Allan Foster sb.append(((InsertEntry) iter.next()).toString());