/*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.mobicents.servlet.sip.testsuite;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.sip.Proxy;
import javax.servlet.sip.SipErrorEvent;
import javax.servlet.sip.SipErrorListener;
import javax.servlet.sip.SipFactory;
import javax.servlet.sip.SipServlet;
import javax.servlet.sip.SipServletRequest;
import javax.servlet.sip.SipServletResponse;
import javax.servlet.sip.SipURI;
import org.apache.log4j.Logger;
public class SpeedDialSipServlet extends SipServlet implements SipErrorListener {
private static final long serialVersionUID = 1L;
private static transient Logger logger = Logger.getLogger(SpeedDialSipServlet.class);
private static final String REMOTE_TRANSPORT = "udp";
private static final int REMOTE_PORT = 5080;
private static final String REMOTE_LOCALHOST_ADDR = "127.0.0.1";
private static final String INITIAL_REMOTE_TRANSPORT = "udp";
private static final int INITIAL_REMOTE_PORT = 5090;
private static final String INITIAL_REMOTE_LOCALHOST_ADDR = "127.0.0.1";
private static final String LOCAL_TRANSPORT = "udp";
private static final int LOCAL_PORT = 5070;
private static final String LOCAL_LOCALHOST_ADDR = "127.0.0.1";
private static final String TEST_USER_REMOTE = "remote";
private static boolean isRecordRoute = true;
Map<String, String> dialNumberToSipUriMapping = null;
/** Creates a new instance of SpeedDialSipServlet */
public SpeedDialSipServlet() {}
@Override
public void init(ServletConfig servletConfig) throws ServletException {
logger.info("the speed dial sip servlet has been started");
super.init(servletConfig);
dialNumberToSipUriMapping = new HashMap<String, String>();
dialNumberToSipUriMapping.put("1", "sip:receiver@sip-servlets.com");
dialNumberToSipUriMapping.put("2", "sip:mranga@sip-servlets.com");
dialNumberToSipUriMapping.put("3", "sip:vlad@sip-servlets.com");
dialNumberToSipUriMapping.put("4", "sip:bartek@sip-servlets.com");
dialNumberToSipUriMapping.put("5", "sip:jeand@sip-servlets.com");
dialNumberToSipUriMapping.put("6", "sip:receiver-failover@sip-servlets.com");
dialNumberToSipUriMapping.put("b2bua", "sip:fromProxy@sip-servlets.com");
dialNumberToSipUriMapping.put("9", "sip:receiver@127.0.0.1:5090");
String initParam = servletConfig.getServletContext().getInitParameter("record_route");
if(initParam != null && initParam.equals("false")) {
isRecordRoute = false;
}
logger.info("Speed dial sip servlet is record routing ?" + isRecordRoute);
}
@Override
protected void doInvite(SipServletRequest request) throws ServletException,
IOException {
logger.info("Got request:\n" + request.toString());
logger.info(request.getRequestURI().toString());
if(((SipURI)request.getFrom().getURI()).getUser().equalsIgnoreCase(TEST_USER_REMOTE)) {
if(request.getRemoteAddr().equals(REMOTE_LOCALHOST_ADDR) && request.getRemotePort() == REMOTE_PORT && request.getTransport().equalsIgnoreCase(REMOTE_TRANSPORT)) {
logger.info("remote information is correct");
} else {
logger.error("remote information is incorrect");
logger.error("remote addr " + request.getRemoteAddr());
logger.error("remote port " + request.getRemotePort());
logger.error("remote transport " + request.getTransport());
SipServletResponse sipServletResponse =
request.createResponse(SipServletResponse.SC_SERVER_INTERNAL_ERROR, "Incorrect remote information");
sipServletResponse.send();
return;
}
if(request.getInitialRemoteAddr().equals(REMOTE_LOCALHOST_ADDR) && request.getInitialRemotePort() == REMOTE_PORT && request.getInitialTransport().equalsIgnoreCase(REMOTE_TRANSPORT)) {
logger.info("Initial remote information is correct");
} else {
logger.error("Initial remote information is incorrect");
logger.error("Initial remote addr " + request.getInitialRemoteAddr());
logger.error("Initial remote port " + request.getInitialRemotePort());
logger.error("Initial remote transport " + request.getInitialTransport());
throw new IllegalArgumentException("initial remote information is incorrect");
}
if(request.getLocalAddr().equals(LOCAL_LOCALHOST_ADDR) && request.getLocalPort() == LOCAL_PORT && request.getTransport().equalsIgnoreCase(LOCAL_TRANSPORT)) {
logger.info("local information is correct");
} else {
logger.error("local information is incorrect");
logger.error("local addr " + request.getLocalAddr());
logger.error("local port " + request.getLocalPort());
logger.error("local transport " + request.getTransport());
throw new IllegalArgumentException("local information is incorrect");
}
}
String dialNumber = ((SipURI)request.getRequestURI()).getUser();
String mappedUri = dialNumberToSipUriMapping.get(dialNumber);
if(mappedUri != null) {
SipFactory sipFactory = (SipFactory) getServletContext().getAttribute(SIP_FACTORY);
Proxy proxy = request.getProxy();
proxy.setProxyTimeout(120);
proxy.setRecordRoute(isRecordRoute);
proxy.setParallel(false);
proxy.setSupervised(true);
logger.info("proxying to " + mappedUri);
proxy.proxyTo(sipFactory.createURI(mappedUri));
} else {
SipServletResponse sipServletResponse =
request.createResponse(SipServletResponse.SC_NOT_ACCEPTABLE_HERE, "No mapping for " + dialNumber);
sipServletResponse.send();
}
}
protected void doSuccessResponse(SipServletResponse resp)
throws ServletException, IOException {
logger.info("Got response " + resp);
if(((SipURI)resp.getFrom().getURI()).getUser().equalsIgnoreCase(TEST_USER_REMOTE)) {
if(resp.getRemoteAddr().equals(LOCAL_LOCALHOST_ADDR) && resp.getRemotePort() == LOCAL_PORT && resp.getTransport().equalsIgnoreCase(LOCAL_TRANSPORT)) {
logger.info("remote information is correct");
} else {
logger.error("remote information is incorrect");
logger.error("remote addr " + resp.getRemoteAddr());
logger.error("remote port " + resp.getRemotePort());
logger.error("remote transport " + resp.getTransport());
throw new IllegalArgumentException("remote information is incorrect");
}
if(resp.getInitialRemoteAddr().equals(INITIAL_REMOTE_LOCALHOST_ADDR) && resp.getInitialRemotePort() == INITIAL_REMOTE_PORT && resp.getInitialTransport().equalsIgnoreCase(INITIAL_REMOTE_TRANSPORT)) {
logger.info("Initial remote information is correct");
} else {
logger.error("Initial remote information is incorrect");
logger.error("Initial remote addr " + resp.getInitialRemoteAddr());
logger.error("Initial remote port " + resp.getInitialRemotePort());
logger.error("Initial remote transport " + resp.getInitialTransport());
throw new IllegalArgumentException("initial remote information is incorrect");
}
if(resp.getLocalAddr().equals(LOCAL_LOCALHOST_ADDR) && resp.getLocalPort() == LOCAL_PORT && resp.getTransport().equalsIgnoreCase(LOCAL_TRANSPORT)) {
logger.info("local information is correct");
} else {
logger.error("local information is incorrect");
logger.error("local addr " + resp.getLocalAddr());
logger.error("local port " + resp.getLocalPort());
logger.error("local transport " + resp.getTransport());
throw new IllegalArgumentException("local information is incorrect");
}
}
}
@Override
protected void doCancel(SipServletRequest req) throws ServletException,
IOException {
logger.error("CANCEL seen at proxy " + req);
}
// SipErrorListener methods
/**
* {@inheritDoc}
*/
public void noAckReceived(SipErrorEvent ee) {
logger.error("noAckReceived.");
}
/**
* {@inheritDoc}
*/
public void noPrackReceived(SipErrorEvent ee) {
logger.error("noPrackReceived.");
}
}