org.jivesoftware.smack.packet.DefaultPacketExtension Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jamppa Show documentation
Show all versions of jamppa Show documentation
jamppa is a XMPP client/component library
The newest version!
/**
*
* Copyright 2003-2007 Jive Software.
*
* All rights reserved. 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.jivesoftware.smack.packet;
import java.util.*;
/**
* Default implementation of the PacketExtension interface. Unless a
* PacketExtensionProvider is registered with
* {@link org.jivesoftware.smack.provider.ProviderManager ProviderManager},
* instances of this class will be returned when getting packet extensions.
*
*
* This class provides a very simple representation of an XML sub-document. Each
* element is a key in a Map with its CDATA being the value. For example, given
* the following XML sub-document:
*
*
* <foo xmlns="http://bar.com">
* <color>blue</color>
* <food>pizza</food>
* </foo>
*
*
* In this case, getValue("color") would return "blue", and getValue("food")
* would return "pizza". This parsing mechanism mechanism is very simplistic and
* will not work as desired in all cases (for example, if some of the elements
* have attributes. In those cases, a custom PacketExtensionProvider should be
* used.
*
* @author Matt Tucker
*/
public class DefaultPacketExtension implements PacketExtension {
private String elementName;
private String namespace;
private Map map;
/**
* Creates a new generic packet extension.
*
* @param elementName
* the name of the element of the XML sub-document.
* @param namespace
* the namespace of the element.
*/
public DefaultPacketExtension(String elementName, String namespace) {
this.elementName = elementName;
this.namespace = namespace;
}
/**
* Returns the XML element name of the extension sub-packet root element.
*
* @return the XML element name of the packet extension.
*/
public String getElementName() {
return elementName;
}
/**
* Returns the XML namespace of the extension sub-packet root element.
*
* @return the XML namespace of the packet extension.
*/
public String getNamespace() {
return namespace;
}
public String toXML() {
StringBuilder buf = new StringBuilder();
buf.append("<").append(elementName).append(" xmlns=\"")
.append(namespace).append("\">");
for (String name : getNames()) {
String value = getValue(name);
buf.append("<").append(name).append(">");
buf.append(value);
buf.append("").append(name).append(">");
}
buf.append("").append(elementName).append(">");
return buf.toString();
}
/**
* Returns an unmodifiable collection of the names that can be used to get
* values of the packet extension.
*
* @return the names.
*/
public synchronized Collection getNames() {
if (map == null) {
return Collections.emptySet();
}
return Collections.unmodifiableSet(new HashMap(map)
.keySet());
}
/**
* Returns a packet extension value given a name.
*
* @param name
* the name.
* @return the value.
*/
public synchronized String getValue(String name) {
if (map == null) {
return null;
}
return map.get(name);
}
/**
* Sets a packet extension value using the given name.
*
* @param name
* the name.
* @param value
* the value.
*/
public synchronized void setValue(String name, String value) {
if (map == null) {
map = new HashMap();
}
map.put(name, value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy