From d7955ce24d294fb2014c59d11fca184471056f44 Mon Sep 17 00:00:00 2001 From: Shuyi Chen Date: Wed, 22 May 2013 14:51:55 -0700 Subject: Add android smack source. Change-Id: I49ce97136c17173c4ae3965c694af6e7bc49897d --- .../jivesoftware/smackx/pubsub/Affiliation.java | 111 +++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 src/org/jivesoftware/smackx/pubsub/Affiliation.java (limited to 'src/org/jivesoftware/smackx/pubsub/Affiliation.java') diff --git a/src/org/jivesoftware/smackx/pubsub/Affiliation.java b/src/org/jivesoftware/smackx/pubsub/Affiliation.java new file mode 100644 index 0000000..d55534d --- /dev/null +++ b/src/org/jivesoftware/smackx/pubsub/Affiliation.java @@ -0,0 +1,111 @@ +/** + * 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.smackx.pubsub; + +import org.jivesoftware.smack.Connection; +import org.jivesoftware.smack.packet.PacketExtension; + +/** + * Represents a affiliation between a user and a node, where the {@link #type} defines + * the type of affiliation. + * + * Affiliations are retrieved from the {@link PubSubManager#getAffiliations()} method, which + * gets affiliations for the calling user, based on the identity that is associated with + * the {@link Connection}. + * + * @author Robin Collier + */ +public class Affiliation implements PacketExtension +{ + protected String jid; + protected String node; + protected Type type; + + public enum Type + { + member, none, outcast, owner, publisher + } + + /** + * Constructs an affiliation. + * + * @param jid The JID with affiliation. + * @param affiliation The type of affiliation. + */ + public Affiliation(String jid, Type affiliation) + { + this(jid, null, affiliation); + } + + /** + * Constructs an affiliation. + * + * @param jid The JID with affiliation. + * @param node The node with affiliation. + * @param affiliation The type of affiliation. + */ + public Affiliation(String jid, String node, Type affiliation) + { + this.jid = jid; + this.node = node; + type = affiliation; + } + + public String getJid() + { + return jid; + } + + public String getNode() + { + return node; + } + + public Type getType() + { + return type; + } + + public String getElementName() + { + return "affiliation"; + } + + public String getNamespace() + { + return null; + } + + public String toXML() + { + StringBuilder builder = new StringBuilder("<"); + builder.append(getElementName()); + if (node != null) + appendAttribute(builder, "node", node); + appendAttribute(builder, "jid", jid); + appendAttribute(builder, "affiliation", type.toString()); + + builder.append("/>"); + return builder.toString(); + } + + private void appendAttribute(StringBuilder builder, String att, String value) + { + builder.append(" "); + builder.append(att); + builder.append("='"); + builder.append(value); + builder.append("'"); + } +} -- cgit v1.2.3