SDP ergänzt, sinnvoll wär es jetzt geeignete Funktionen zu erstellen + RTP zu ergänzen
This commit is contained in:
parent
4777785ad4
commit
8fbb5a96c8
@ -12,6 +12,9 @@ import java.text.ParseException;
|
|||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
import javax.sdp.SdpException;
|
||||||
|
import javax.sdp.SdpFactory;
|
||||||
|
import javax.sdp.SessionDescription;
|
||||||
import javax.sip.DialogTerminatedEvent;
|
import javax.sip.DialogTerminatedEvent;
|
||||||
import javax.sip.IOExceptionEvent;
|
import javax.sip.IOExceptionEvent;
|
||||||
import javax.sip.InvalidArgumentException;
|
import javax.sip.InvalidArgumentException;
|
||||||
@ -54,7 +57,6 @@ public class VoIP implements SipListenerExt
|
|||||||
Address contactAddress;
|
Address contactAddress;
|
||||||
private ContactHeader contactHeader;
|
private ContactHeader contactHeader;
|
||||||
|
|
||||||
|
|
||||||
public VoIP() //Konstruktor für eigene Daten
|
public VoIP() //Konstruktor für eigene Daten
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -84,6 +86,7 @@ public class VoIP implements SipListenerExt
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int hashCode()
|
public int hashCode()
|
||||||
{
|
{
|
||||||
int temp = tag * (new Random(100)).nextInt();
|
int temp = tag * (new Random(100)).nextInt();
|
||||||
@ -95,15 +98,10 @@ public class VoIP implements SipListenerExt
|
|||||||
System.out.println("-----------SendRegister-----------");
|
System.out.println("-----------SendRegister-----------");
|
||||||
Address addressto = this.addressFactory.createAddress("sip:192.168.100.11"); //evtl. mit Port: sip:192.168.100.11:5060
|
Address addressto = this.addressFactory.createAddress("sip:192.168.100.11"); //evtl. mit Port: sip:192.168.100.11:5060
|
||||||
Address addresstob = this.addressFactory.createAddress("sip:192.168.100.11"); //to get example maybe needed
|
Address addresstob = this.addressFactory.createAddress("sip:192.168.100.11"); //to get example maybe needed
|
||||||
|
|
||||||
ToHeader to = this.headerFactory.createToHeader(addresstob, null); // Integer.toString(tag) address + tag
|
ToHeader to = this.headerFactory.createToHeader(addresstob, null); // Integer.toString(tag) address + tag
|
||||||
|
|
||||||
URI requestURI = addressto.getURI();
|
URI requestURI = addressto.getURI();
|
||||||
|
|
||||||
CallIdHeader callId = this.sipProvider.getNewCallId();
|
CallIdHeader callId = this.sipProvider.getNewCallId();
|
||||||
|
|
||||||
FromHeader from = this.headerFactory.createFromHeader(addresstob, String.valueOf(this.tag)); //this.contactAddress
|
FromHeader from = this.headerFactory.createFromHeader(addresstob, String.valueOf(this.tag)); //this.contactAddress
|
||||||
|
|
||||||
ArrayList via = new ArrayList(); //Via needs a List as input
|
ArrayList via = new ArrayList(); //Via needs a List as input
|
||||||
ViaHeader viaheader = this.headerFactory.createViaHeader(this.myIPAddress, this.myPort, "UDP", String.valueOf(branch));
|
ViaHeader viaheader = this.headerFactory.createViaHeader(this.myIPAddress, this.myPort, "UDP", String.valueOf(branch));
|
||||||
via.add(viaheader);
|
via.add(viaheader);
|
||||||
@ -114,13 +112,11 @@ public class VoIP implements SipListenerExt
|
|||||||
//Create Request Header
|
//Create Request Header
|
||||||
System.out.println("----REQUEST HEADER----");
|
System.out.println("----REQUEST HEADER----");
|
||||||
Request request = this.messageFactory.createRequest(requestURI, "REGISTER", callId, cSeq, from, to, via, maxForwards);
|
Request request = this.messageFactory.createRequest(requestURI, "REGISTER", callId, cSeq, from, to, via, maxForwards);
|
||||||
|
|
||||||
request.addHeader(contactHeader);
|
request.addHeader(contactHeader);
|
||||||
request.addHeader(allow);
|
request.addHeader(allow);
|
||||||
request.addHeader(expire);
|
request.addHeader(expire);
|
||||||
System.out.println(request);
|
System.out.println(request);
|
||||||
this.sipProvider.sendRequest(request);
|
this.sipProvider.sendRequest(request);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -132,7 +128,8 @@ public class VoIP implements SipListenerExt
|
|||||||
public void processRequest(RequestEvent requestEvent)
|
public void processRequest(RequestEvent requestEvent)
|
||||||
{
|
{
|
||||||
System.out.println("----Bekomme Anfrage----");
|
System.out.println("----Bekomme Anfrage----");
|
||||||
if ((Request.OPTIONS).equals(requestEvent.getRequest().getMethod()))
|
//Kommunikation mit Server das man zur Verfügung steht
|
||||||
|
if ((Request.OPTIONS).equals(requestEvent.getRequest().getMethod())) //Options Anfrage von Server nach erfolgreicher Registrierung
|
||||||
{
|
{
|
||||||
System.out.println("200 OK zu Server");
|
System.out.println("200 OK zu Server");
|
||||||
try
|
try
|
||||||
@ -158,13 +155,15 @@ public class VoIP implements SipListenerExt
|
|||||||
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ((Request.INVITE).equals(requestEvent.getRequest().getMethod()))
|
//Aktive Kommunikation
|
||||||
|
else if ((Request.INVITE).equals(requestEvent.getRequest().getMethod())) // Invite von anderem Benutzer
|
||||||
{
|
{
|
||||||
System.out.println("Hab invitation bekommen");
|
System.out.println("Hab invitation bekommen");
|
||||||
System.out.println("Gleich antworte ich");
|
System.out.println("Gleich antworte ich");
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
//Trying
|
//Trying Message to Server (Response Trying)
|
||||||
|
System.out.println("----REquest HEader----");
|
||||||
Response responsetry = this.messageFactory.createResponse(100, requestEvent.getRequest());
|
Response responsetry = this.messageFactory.createResponse(100, requestEvent.getRequest());
|
||||||
|
|
||||||
responsetry.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
|
responsetry.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
|
||||||
@ -180,13 +179,15 @@ public class VoIP implements SipListenerExt
|
|||||||
responsetry.addHeader(allow);
|
responsetry.addHeader(allow);
|
||||||
this.sipProvider.sendResponse(responsetry);
|
this.sipProvider.sendResponse(responsetry);
|
||||||
System.out.println("Trying ist raus");
|
System.out.println("Trying ist raus");
|
||||||
//Ringing
|
|
||||||
|
//Ringing Message to Server (Responste Ringing)
|
||||||
Response responsering = this.messageFactory.createResponse(180, requestEvent.getRequest());
|
Response responsering = this.messageFactory.createResponse(180, requestEvent.getRequest());
|
||||||
responsering.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
|
responsering.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
|
||||||
responsering.addHeader((FromHeader) requestEvent.getRequest().getHeader("From"));
|
responsering.addHeader((FromHeader) requestEvent.getRequest().getHeader("From"));
|
||||||
|
|
||||||
ToHeader temptoring = (ToHeader) requestEvent.getRequest().getHeader("To");
|
ToHeader temptoring = (ToHeader) requestEvent.getRequest().getHeader("To");
|
||||||
temptoring.setTag(String.valueOf(this.tag+Math.random())); //evtl. besseren Tag
|
String tempTag = String.valueOf(this.tag + Math.random());
|
||||||
|
temptoring.setTag(tempTag); //evtl. besseren Tag
|
||||||
responsering.addHeader(temptoring);
|
responsering.addHeader(temptoring);
|
||||||
|
|
||||||
responsering.addHeader((CSeqHeader) requestEvent.getRequest().getHeader("Cseq"));
|
responsering.addHeader((CSeqHeader) requestEvent.getRequest().getHeader("Cseq"));
|
||||||
@ -196,26 +197,75 @@ public class VoIP implements SipListenerExt
|
|||||||
|
|
||||||
AllowEventsHeader allowevent = this.headerFactory.createAllowEventsHeader("talk,hold");// für was gebraucht
|
AllowEventsHeader allowevent = this.headerFactory.createAllowEventsHeader("talk,hold");// für was gebraucht
|
||||||
responsering.addHeader(allowevent);
|
responsering.addHeader(allowevent);
|
||||||
|
|
||||||
this.sipProvider.sendResponse(responsering);
|
this.sipProvider.sendResponse(responsering);
|
||||||
System.out.println("Response ist raus");
|
System.out.println("Response ist raus");
|
||||||
|
|
||||||
|
System.out.println("Erstelle 200 Ok + SDP Header(contentHeader)");
|
||||||
//Jetzt kommt 200 Ok SIP Header + SDP (SIP/SDP)
|
//Jetzt kommt 200 Ok SIP Header + SDP (SIP/SDP)
|
||||||
//Sdp Header erstellen nächster Schritt
|
//Sdp Header erstellen nächster Schritt
|
||||||
|
System.out.println(requestEvent.getDialog());
|
||||||
|
Response okandSDP = this.messageFactory.createResponse(Response.OK, requestEvent.getRequest());
|
||||||
|
//okandSDP.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
|
||||||
|
okandSDP.addHeader((FromHeader) requestEvent.getRequest().getHeader("From"));
|
||||||
|
|
||||||
|
okandSDP.addHeader(temptoring); //evtl noch Ergänzungen
|
||||||
|
|
||||||
|
okandSDP.addHeader((CSeqHeader) requestEvent.getRequest().getHeader("Cseq"));
|
||||||
|
okandSDP.addHeader(contactHeader);
|
||||||
|
okandSDP.addHeader(supp);
|
||||||
|
okandSDP.addHeader(allow);
|
||||||
|
okandSDP.addHeader(allowevent);
|
||||||
ContentTypeHeader content = headerFactory.createContentTypeHeader("application", "sdp");
|
ContentTypeHeader content = headerFactory.createContentTypeHeader("application", "sdp");
|
||||||
|
|
||||||
|
//Create Session Description Body
|
||||||
|
SdpFactory sdpFactory = SdpFactory.getInstance();
|
||||||
|
SessionDescription sessionDescription = sdpFactory.createSessionDescription();
|
||||||
|
sessionDescription.setOrigin(sdpFactory.createOrigin(myName, 8000, 8000, "IN", "IP4", myIPAddress));
|
||||||
|
sessionDescription.setSessionName(sdpFactory.createSessionName("SIP Call"));
|
||||||
|
sessionDescription.setConnection(sdpFactory.createConnection("IN", "IP4", myIPAddress));
|
||||||
|
|
||||||
|
//Media Body
|
||||||
|
String sdpformat[] =
|
||||||
|
{
|
||||||
|
"0", "4", "18",
|
||||||
|
};
|
||||||
|
Vector mediavec = new Vector();
|
||||||
|
mediavec.add(sdpFactory.createMediaDescription("audio", 6022, 1, "RTP/AVP", sdpformat));
|
||||||
|
|
||||||
|
//Media Attribute
|
||||||
|
mediavec.add(sdpFactory.createAttribute("sendrecv", null));
|
||||||
|
mediavec.add(sdpFactory.createAttribute("rtpmap", "0 PCMU/8000"));
|
||||||
|
mediavec.add(sdpFactory.createAttribute("rtpmap", "4 G723/8000"));
|
||||||
|
mediavec.add(sdpFactory.createAttribute("rtpmap", "18 G729A/8000"));
|
||||||
|
mediavec.add(sdpFactory.createAttribute("ptime", "20"));
|
||||||
|
|
||||||
|
sessionDescription.setAttributes(mediavec);
|
||||||
|
|
||||||
|
|
||||||
|
System.out.println("---Beispiel Header---");
|
||||||
|
/*
|
||||||
|
String contentparam = "v=0\r\n" + "o=129 1202 1202" + " IN IP4 192.168.100.247\r\n" + "s=SIP Call\r\n"
|
||||||
|
+ "c=192.168.100.247\r\n" + "t=0 0\r\n" + "m=audio 6022 RTP/AVP 0 4 18\r\n"
|
||||||
|
+ "a=rtpmap:0 PCMU/8000\r\n" + "a=rtpmap:4 G723/8000\r\n" + "a=rtpmap:18 G729A/8000\r\n" +
|
||||||
|
"a=ptime:20\r\n";
|
||||||
|
*/
|
||||||
|
okandSDP.addHeader(content);
|
||||||
|
okandSDP.setContent(sessionDescription, content);
|
||||||
|
System.out.println(okandSDP);
|
||||||
|
this.sipProvider.sendResponse(okandSDP);
|
||||||
}
|
}
|
||||||
catch (ParseException | SipException ex)
|
catch (ParseException | SipException | SdpException ex)
|
||||||
{
|
{
|
||||||
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else if ((Request.ACK).equals(requestEvent.getRequest().getMethod()))
|
else if ((Request.ACK).equals(requestEvent.getRequest().getMethod()))
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -227,11 +277,11 @@ public class VoIP implements SipListenerExt
|
|||||||
if (responseEvent.getResponse().getStatusCode() == Response.UNAUTHORIZED)
|
if (responseEvent.getResponse().getStatusCode() == Response.UNAUTHORIZED)
|
||||||
{
|
{
|
||||||
|
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
Address addresstob = this.addressFactory.createAddress("sip:129@192.168.100.11"); //"sip:Jan@192.168.100.11"
|
Address addresstob = this.addressFactory.createAddress("sip:129@192.168.100.11"); //"sip:Jan@192.168.100.11"
|
||||||
ToHeader temp = (ToHeader) responseEvent.getResponse().getHeader("To");
|
ToHeader temp = (ToHeader) responseEvent.getResponse().getHeader("To");
|
||||||
|
|
||||||
|
|
||||||
ToHeader to = this.headerFactory.createToHeader(addresstob, temp.getTag()); // Integer.toString(tag) address + tag
|
ToHeader to = this.headerFactory.createToHeader(addresstob, temp.getTag()); // Integer.toString(tag) address + tag
|
||||||
URI requestURI = addresstob.getURI();
|
URI requestURI = addresstob.getURI();
|
||||||
|
|
||||||
@ -249,8 +299,6 @@ public class VoIP implements SipListenerExt
|
|||||||
auth.setURI(addresstest.getURI());
|
auth.setURI(addresstest.getURI());
|
||||||
auth.setUsername(myName);
|
auth.setUsername(myName);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ArrayList via = new ArrayList(); //Via needs a List as input
|
ArrayList via = new ArrayList(); //Via needs a List as input
|
||||||
ViaHeader viaheader = this.headerFactory.createViaHeader(this.myIPAddress, this.myPort, "UDP", String.valueOf(branch + 2));// String.valueOf(hashCode())string branch
|
ViaHeader viaheader = this.headerFactory.createViaHeader(this.myIPAddress, this.myPort, "UDP", String.valueOf(branch + 2));// String.valueOf(hashCode())string branch
|
||||||
via.add(viaheader);
|
via.add(viaheader);
|
||||||
@ -261,7 +309,6 @@ public class VoIP implements SipListenerExt
|
|||||||
ExpiresHeader expire = this.headerFactory.createExpiresHeader(3600); //int value
|
ExpiresHeader expire = this.headerFactory.createExpiresHeader(3600); //int value
|
||||||
|
|
||||||
//Zusätzliche Register Header nach Unauthorzied
|
//Zusätzliche Register Header nach Unauthorzied
|
||||||
|
|
||||||
//Create Request Header
|
//Create Request Header
|
||||||
System.out.println("----REQUEST HEADER2----");
|
System.out.println("----REQUEST HEADER2----");
|
||||||
Request request = this.messageFactory.createRequest(requestURI, "REGISTER", callId, cSeq, from, to, via, maxForwards);
|
Request request = this.messageFactory.createRequest(requestURI, "REGISTER", callId, cSeq, from, to, via, maxForwards);
|
||||||
@ -272,7 +319,8 @@ public class VoIP implements SipListenerExt
|
|||||||
//System.out.println(request);
|
//System.out.println(request);
|
||||||
this.sipProvider.sendRequest(request);
|
this.sipProvider.sendRequest(request);
|
||||||
}
|
}
|
||||||
catch (ParseException | SipException |InvalidArgumentException ex) {
|
catch (ParseException | SipException | InvalidArgumentException ex)
|
||||||
|
{
|
||||||
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(VoIP.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user