1 package at.ac.tuwien.sbc.valesriegler.waiter;
3 import java.io.Serializable;
5 import javax.jms.Connection;
6 import javax.jms.MessageConsumer;
7 import javax.jms.Session;
9 import org.apache.activemq.ActiveMQConnectionFactory;
10 import org.slf4j.Logger;
11 import org.slf4j.LoggerFactory;
13 import at.ac.tuwien.sbc.valesriegler.waiter.jms.messageListeners.WantToOrder;
14 import at.ac.tuwien.sbc.valesriegler.waiter.jms.messageListeners.WantToSitAtTable;
16 //TODO: needs a WaiterAgent and abstraction to support mzs + jms!
17 // Currently this is jms only!
18 public class Waiter implements Serializable {
19 private static final Logger log = LoggerFactory.getLogger(Waiter.class);
20 private static int nextID = 0;
23 public static void main(String[] args) {
27 public Waiter(int id) {
29 log.info("I AM A WAITER WITH ID {}", id);
34 public String toString() {
35 return "Waiter [id=" + id + "]";
42 public void deliver() {
44 // Connecting to the Broker and to the output queue
45 ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
46 Connection connection = connectionFactory.createConnection();
49 Session sessWantToSit = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
50 MessageConsumer consWantToSit = sessWantToSit.createConsumer(sessWantToSit.createQueue("WantToSitAtTable"));
51 consWantToSit.setMessageListener(new WantToSitAtTable(this));
53 Session sessWantToOrder = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
54 MessageConsumer consWantToOrder = sessWantToOrder.createConsumer(sessWantToOrder.createQueue("WantToOrder"));
55 consWantToOrder.setMessageListener(new WantToOrder(this));
56 } catch (Exception e) {
57 log.error("Caught: ", e);