1 /** 2 * $Revision$ 3 * $Date$ 4 * 5 * Copyright 2003-2007 Jive Software. 6 * 7 * All rights reserved. Licensed under the Apache License, Version 2.0 (the "License"); 8 * you may not use this file except in compliance with the License. 9 * You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, software 14 * distributed under the License is distributed on an "AS IS" BASIS, 15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 16 * See the License for the specific language governing permissions and 17 * limitations under the License. 18 */ 19 20 package org.jivesoftware.smackx.workgroup.packet; 21 22 import org.jivesoftware.smack.packet.PacketExtension; 23 import org.jivesoftware.smack.provider.PacketExtensionProvider; 24 import org.xmlpull.v1.XmlPullParser; 25 26 /** 27 * Packet extension for {@link org.jivesoftware.smackx.workgroup.agent.TransferRequest}. 28 * 29 * @author Gaston Dombiak 30 */ 31 public class RoomTransfer implements PacketExtension { 32 33 /** 34 * Element name of the packet extension. 35 */ 36 public static final String ELEMENT_NAME = "transfer"; 37 38 /** 39 * Namespace of the packet extension. 40 */ 41 public static final String NAMESPACE = "http://jabber.org/protocol/workgroup"; 42 43 /** 44 * Type of entity being invited to a groupchat support session. 45 */ 46 private RoomTransfer.Type type; 47 /** 48 * JID of the entity being invited. The entity could be another agent, user , a queue or a workgroup. In 49 * the case of a queue or a workgroup the server will select the best agent to invite. 50 */ 51 private String invitee; 52 /** 53 * Full JID of the user that sent the invitation. 54 */ 55 private String inviter; 56 /** 57 * ID of the session that originated the initial user request. 58 */ 59 private String sessionID; 60 /** 61 * JID of the room to join if offer is accepted. 62 */ 63 private String room; 64 /** 65 * Text provided by the inviter explaining the reason why the invitee is invited. 66 */ 67 private String reason; 68 69 public RoomTransfer(RoomTransfer.Type type, String invitee, String sessionID, String reason) { 70 this.type = type; 71 this.invitee = invitee; 72 this.sessionID = sessionID; 73 this.reason = reason; 74 } 75 76 private RoomTransfer() { 77 } 78 79 public String getElementName() { 80 return ELEMENT_NAME; 81 } 82 83 public String getNamespace() { 84 return NAMESPACE; 85 } 86 87 public String getInviter() { 88 return inviter; 89 } 90 91 public String getRoom() { 92 return room; 93 } 94 95 public String getReason() { 96 return reason; 97 } 98 99 public String getSessionID() { 100 return sessionID; 101 } 102 103 public String toXML() { 104 StringBuilder buf = new StringBuilder(); 105 106 buf.append("<").append(ELEMENT_NAME).append(" xmlns=\"").append(NAMESPACE); 107 buf.append("\" type=\"").append(type).append("\">"); 108 buf.append("<session xmlns=\"http://jivesoftware.com/protocol/workgroup\" id=\"").append(sessionID).append("\"></session>"); 109 if (invitee != null) { 110 buf.append("<invitee>").append(invitee).append("</invitee>"); 111 } 112 if (inviter != null) { 113 buf.append("<inviter>").append(inviter).append("</inviter>"); 114 } 115 if (reason != null) { 116 buf.append("<reason>").append(reason).append("</reason>"); 117 } 118 // Add packet extensions, if any are defined. 119 buf.append("</").append(ELEMENT_NAME).append("> "); 120 121 return buf.toString(); 122 } 123 124 /** 125 * Type of entity being invited to a groupchat support session. 126 */ 127 public static enum Type { 128 /** 129 * A user is being invited to a groupchat support session. The user could be another agent 130 * or just a regular XMPP user. 131 */ 132 user, 133 /** 134 * Some agent of the specified queue will be invited to the groupchat support session. 135 */ 136 queue, 137 /** 138 * Some agent of the specified workgroup will be invited to the groupchat support session. 139 */ 140 workgroup 141 } 142 143 public static class Provider implements PacketExtensionProvider { 144 145 public PacketExtension parseExtension(XmlPullParser parser) throws Exception { 146 final RoomTransfer invitation = new RoomTransfer(); 147 invitation.type = RoomTransfer.Type.valueOf(parser.getAttributeValue("", "type")); 148 149 boolean done = false; 150 while (!done) { 151 parser.next(); 152 String elementName = parser.getName(); 153 if (parser.getEventType() == XmlPullParser.START_TAG) { 154 if ("session".equals(elementName)) { 155 invitation.sessionID = parser.getAttributeValue("", "id"); 156 } 157 else if ("invitee".equals(elementName)) { 158 invitation.invitee = parser.nextText(); 159 } 160 else if ("inviter".equals(elementName)) { 161 invitation.inviter = parser.nextText(); 162 } 163 else if ("reason".equals(elementName)) { 164 invitation.reason = parser.nextText(); 165 } 166 else if ("room".equals(elementName)) { 167 invitation.room = parser.nextText(); 168 } 169 } 170 else if (parser.getEventType() == XmlPullParser.END_TAG && ELEMENT_NAME.equals(elementName)) { 171 done = true; 172 } 173 } 174 return invitation; 175 } 176 } 177 } 178