/** * * Copyright 2003-2007 Jive Software. * * 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.workgroup.packet; import org.jivesoftware.smack.packet.IQ; /** * A IQ packet used to depart a workgroup queue. There are two cases for issuing a depart * queue request: * * @author loki der quaeler */ public class DepartQueuePacket extends IQ { private String user; private DepartQueuePacket() { super("depart-queue", "http://jabber.org/protocol/workgroup"); } /** * Creates a depart queue request packet to the specified workgroup. * * @param workgroup the workgroup to depart. */ public DepartQueuePacket(String workgroup) { this(workgroup, null); } /** * Creates a depart queue request to the specified workgroup and for the * specified user. * * @param workgroup the workgroup to depart. * @param user the user to make depart from the queue. */ public DepartQueuePacket(String workgroup, String user) { this(); this.user = user; setTo(workgroup); setType(IQ.Type.set); setFrom(user); } @Override protected IQChildElementXmlStringBuilder getIQChildElementBuilder(IQChildElementXmlStringBuilder buf) { buf.rightAngleBracket(); if (this.user != null) { buf.append("").append(this.user).append(""); } return buf; } }