package at.ac.tuwien.sbc.valesriegler.waiter;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import at.ac.tuwien.sbc.valesriegler.waiter.jms.JMSWaiter;

/**
 * A waiter is a person who does all the stuff and gets lousy tips in return.
 * The WaiterAgent runs the XVSM/JMSWaiter to do all the Waiter stuff.
 * 
 * @author jan
 * 
 */
public class WaiterAgent {
	private static final String USAGE = "This application needs exactly 2 parameters: <\"XVSM\"|\"JMS\"> <XVSM-Space-Identifier|JMS-Server-URL> <ID of type Integer>";
	private static final Logger log = LoggerFactory.getLogger(WaiterAgent.class);
	static public JMSWaiter jmsWaiter;

	public static void main(String[] args) {
		if (args.length != 3) {
			throw new IllegalArgumentException(USAGE);
		}

		String mw = args[0];
		int parsedId = 0;
		try {
			parsedId = Integer.parseInt(args[2]);
		} catch (NumberFormatException e) {
			log.error(USAGE);
			return;
		}

		log.info("Middleware: " + mw + " ID:" + parsedId);
		if ("JMS".equalsIgnoreCase(mw)) {
			jmsWaiter = new JMSWaiter(args[1], parsedId);
		} else if ("XVSM".equalsIgnoreCase(mw)) {
			// TODO: XVSM Waiter?
		} else {
			throw new IllegalArgumentException(USAGE);
		}
	}

	public JMSWaiter getJmsWaiter() {
		return jmsWaiter;
	}

}
