KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > scalagent > kjoram > jms > ConsumerSetListRequest


1 /*
2  * JORAM: Java(TM) Open Reliable Asynchronous Messaging
3  * Copyright (C) 2001 - ScalAgent Distributed Technologies
4  * Copyright (C) 1996 - Dyade
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19  * USA.
20  *
21  * Initial developer(s): Frederic Maistre (INRIA)
22  * Contributor(s): Nicolas Tachker (ScalAgent)
23  */

24 package com.scalagent.kjoram.jms;
25
26 import java.util.Hashtable JavaDoc;
27 import java.util.Enumeration JavaDoc;
28
29 /**
30  * A <code>ConsumerSetListRequest</code> is sent by a
31  * <code>MessageConsumer</code> on which a message listener is set.
32  */

33 public class ConsumerSetListRequest extends AbstractJmsRequest
34 {
35   /** Selector for filtering messages on a queue. */
36   private String JavaDoc selector;
37   /** <code>true</code> if the request is destinated to a queue. */
38   private boolean queueMode;
39
40   /**
41    * Constructs a <code>ConsumerSetListRequest</code>.
42    *
43    * @param targetName Name of the target queue or subscription.
44    * @param selector Selector for filtering messages.
45    * @param queueMode <code>true</code> if this request is destinated to a
46    * queue.
47    */

48   public ConsumerSetListRequest(String JavaDoc targetName, String JavaDoc selector,
49                                 boolean queueMode)
50   {
51     super(targetName);
52     this.selector = selector;
53     this.queueMode = queueMode;
54   }
55
56   /**
57    * Constructs a <code>ConsumerSetListRequest</code>.
58    */

59   public ConsumerSetListRequest()
60   {}
61
62   /** Sets the selector. */
63   public void setSelector(String JavaDoc selector)
64   {
65     this.selector = selector;
66   }
67
68   /** Sets the target destination type. */
69   public void setQueueMode(boolean queueMode)
70   {
71     this.queueMode = queueMode;
72   }
73
74   /** Returns the selector for filtering messages. */
75   public String JavaDoc getSelector()
76   {
77     return selector;
78   }
79
80   /** Returns <code>true</code> if the request is destinated to a queue. */
81   public boolean getQueueMode()
82   {
83     return queueMode;
84   }
85
86   public Hashtable JavaDoc soapCode() {
87     Hashtable JavaDoc h = super.soapCode();
88     if (selector != null)
89       h.put("selector",selector);
90     h.put("queueMode",new Boolean JavaDoc(queueMode));
91     return h;
92   }
93
94   public static Object JavaDoc soapDecode(Hashtable JavaDoc h) {
95     ConsumerSetListRequest req = new ConsumerSetListRequest();
96     req.setRequestId(((Integer JavaDoc) h.get("requestId")).intValue());
97     req.setTarget((String JavaDoc) h.get("target"));
98     req.setSelector((String JavaDoc) h.get("selector"));
99     req.setQueueMode(((Boolean JavaDoc) h.get("queueMode")).booleanValue());
100     return req;
101   }
102 }
103
Popular Tags