Exemple : Classe SendOnServlet de servlet SIP
La classe SendOnServlet est un servlet SIP simple qui réaliserait la fonction de base qui consiste à être appelé sur chaque INVITE et à transmettre la requête à partir de là.
Classe SendOnServlet
La fonction pourrait être facilement insérée pour consigner cette requête d'invite ou rejeter l'INVITE en fonction de certains critères spécifiques.
package com.example;
import java.io.IOException;
import javax.servlet.sip.*;
import java.servlet.ServletException;
public class SendOnServlet extends SipServlet {
public void doInvite(SipServletRequest req)
throws ServletException, java.io.IOException {
//send on the request
req.getProxy().proxyTo(req.getRequestURI);
}
}
La méthode doInvite pourrait être modifiée pour effectuer des tâches telles que rejeter l'invite simplement d'après certains critères spécifiques. Dans l'exemple ci-dessous, toutes les requêtes issues de domaines hors de example.com seront rejetées avec une réponse Forbidden.
public void doInvite(SipServletRequest req)
throws ServletException, java.io.IOException {
if (req.getFrom().getURI().isSipURI()){
SipURI uri = (SipURI)req.getFrom.getURI();
if (!uri.getHost().equals(“example.com”)) {
//send forbidden response for calls outside domain
req.createResponse(SipServletResponse.SC_FORBIDDEN, “Calls outside example.com not accepted”).send();
return;
}
}
//proxy all other requests on to their original destination
req.getProxy().proxyTo(req.getRequestURI());
}
SendOnServlet deployment descriptor:
<sip-app>
<display-name>Send-on Servlet</display-name>
<servlet>
<servlet-name>SendOnServlet</servlet-name>
<servlet-class>com.example.SendOnServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SendOnServlet</servlet-name>
<pattern>
<equal>
<var>request.method</var>
<value>INVITE</value>
</equal>
</pattern>
</servlet-mapping>
</sip-app>