You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SIPmodel.java 16KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. /*
  2. * To change this license header, choose License Headers in Project Properties.
  3. * To change this template file, choose Tools | Templates
  4. * and open the template in the editor.
  5. */
  6. package model;
  7. import gov.nist.javax.sip.DialogTimeoutEvent;
  8. import gov.nist.javax.sip.SipListenerExt;
  9. import gui.Hauptfenster;
  10. import java.net.InetAddress;
  11. import java.text.ParseException;
  12. import java.util.*;
  13. import java.util.logging.Level;
  14. import java.util.logging.Logger;
  15. import javax.sip.DialogTerminatedEvent;
  16. import javax.sip.IOExceptionEvent;
  17. import javax.sip.InvalidArgumentException;
  18. import javax.sip.ListeningPoint;
  19. import javax.sip.RequestEvent;
  20. import javax.sip.ResponseEvent;
  21. import javax.sip.SipException;
  22. import javax.sip.SipFactory;
  23. import javax.sip.SipProvider;
  24. import javax.sip.SipStack;
  25. import javax.sip.TimeoutEvent;
  26. import javax.sip.TransactionTerminatedEvent;
  27. import javax.sip.address.*;
  28. import javax.sip.header.*;
  29. import javax.sip.message.*;
  30. import logger.OhmLogger;
  31. /**
  32. *
  33. * @author Jan komplettes Model für SIPmodel evtl. Vererbung und für jeden SIP
  34. * Response/Request eigene Klasse oder Interface da es langsam unübersichtlich
  35. * wird :( ACK schicken muss noch ergänzt werden BYE muss noch ergänzt werden.
  36. */
  37. public class SIPmodel implements SipListenerExt
  38. {
  39. Hauptfenster view; //später entfernen wegen Zugriff
  40. public static final Logger lg = OhmLogger.getLogger();
  41. public SipFactory sipFactory; // Used to access the SIP API.
  42. public SipStack sipStack; // The SIP stack.
  43. public SipProvider sipProvider; // Used to send SIP messages.
  44. public MessageFactory messageFactory; // Used to create SIP message factory.
  45. public HeaderFactory headerFactory; // Used to create SIP headers.
  46. public AddressFactory addressFactory; // Used to create SIP URIs.
  47. public ListeningPoint listeningPoint; // SIP listening IP address/port.
  48. public Properties properties; // Other properties.
  49. private int myPort = 5060;
  50. private String myName = "129";
  51. public String protocolTyp = "UDP";
  52. public String myIPAddress;
  53. public String proxyAddress;
  54. public CallIdHeader callID;
  55. Boolean invite; //Bool für SDP falls ich anrufe
  56. //Hilfsvariablen wenn ich angerufen werde. evtl. noch optimieren
  57. RequestEvent evtWerdeAngerufen;
  58. Boolean werdeAngerufen;
  59. private int countWerdeAngerufen;
  60. private long cSequenz = 1;
  61. private String proxyTag;
  62. private String myTag = String.valueOf(new Random().nextInt());
  63. private int branch = Integer.valueOf(hashCode());
  64. private Address contactAddress;
  65. private ContactHeader contactHeader;
  66. public SIPmodel(Hauptfenster view) //Konstruktor für eigene Daten
  67. {
  68. this.view = view;
  69. invite = true;
  70. proxyAddress = "";
  71. countWerdeAngerufen = 0;
  72. evtWerdeAngerufen = null;
  73. werdeAngerufen = false;
  74. try
  75. {
  76. //wird an sich erstmal nicht gebraucht aber später sinnvoll um eigene Daten zu initialisieren
  77. String abc = InetAddress.getLocalHost().getHostAddress();
  78. this.myIPAddress = InetAddress.getLocalHost().getHostAddress();
  79. this.sipFactory = SipFactory.getInstance();
  80. this.sipFactory.setPathName("gov.nist");
  81. this.properties = new Properties();
  82. this.properties.setProperty("javax.sip.STACK_NAME", "stack");
  83. this.sipStack = this.sipFactory.createSipStack(this.properties);
  84. this.messageFactory = this.sipFactory.createMessageFactory();
  85. this.headerFactory = this.sipFactory.createHeaderFactory();
  86. this.addressFactory = this.sipFactory.createAddressFactory();
  87. this.listeningPoint = this.sipStack.createListeningPoint(this.myIPAddress, this.myPort, this.protocolTyp);
  88. this.sipProvider = this.sipStack.createSipProvider(this.listeningPoint);
  89. this.sipProvider.addSipListener(this);
  90. this.contactAddress = this.addressFactory.createAddress("sip:" + myName + "@" + this.myIPAddress + ":" + this.myPort);
  91. this.contactHeader = this.headerFactory.createContactHeader(contactAddress);
  92. }
  93. catch (Exception e)
  94. {
  95. System.out.println("Fehler bei Initialisierung eigener Addresse");
  96. System.exit(-1);
  97. }
  98. }
  99. public int hashCode()
  100. {
  101. int temp = Integer.valueOf(myTag)* (new Random(100)).nextInt();
  102. return temp;
  103. }
  104. public void sendRegister(String serverIP, int serverPort) throws ParseException, InvalidArgumentException, SipException
  105. {
  106. proxyAddress = serverIP + ":" + serverPort;
  107. SIPRegister register = new SIPRegister(proxyAddress, myTag, myIPAddress, myPort, branch, addressFactory, headerFactory, messageFactory, contactHeader, sipProvider.getNewCallId());
  108. this.sipProvider.sendRequest(register.getRequest());
  109. lg.info("Erfolgreiches Senden der Registrierung");
  110. }
  111. public void sendInvitation(String sipaddresse, String proxyaddresse,
  112. int serverPort) throws SipException
  113. { //ServerPort wird nicht verwendet?
  114. invite = true;
  115. callID = this.sipProvider.getNewCallId();
  116. SIPSessionDescription sdp = new SIPSessionDescription(myName, myIPAddress, evtWerdeAngerufen, true);
  117. SIPInvite sipinvite = new SIPInvite(sipaddresse, proxyaddresse, myIPAddress, myPort, myTag, branch, callID, cSequenz, addressFactory, sdp.getSessionDescription(), headerFactory, messageFactory, contactHeader);
  118. this.sipProvider.sendRequest(sipinvite.getInviterequest());
  119. lg.info("Erfolgreiches Senden der Invitation");
  120. }
  121. @Override
  122. public void processRequest(RequestEvent requestEvent)
  123. {
  124. lg.info("Bekomme Anfrage");
  125. if ((Request.OPTIONS).equals(requestEvent.getRequest().getMethod())) //Options Anfrage von Server nach erfolgreicher Registrierung
  126. {
  127. lg.info("Option Request von Server, erstellen 200 OK zu Server");
  128. try
  129. {
  130. SIP200Ok tempOk = new SIP200Ok(messageFactory, requestEvent, contactHeader, headerFactory);
  131. this.sipProvider.sendResponse(tempOk.getResponse());
  132. view.getTxtArea().append("Server Option Request erfolgreich beantwortet\n");
  133. lg.info("Erfolgreiches senden des 200Ok-Headers");
  134. }
  135. catch (SipException ex)
  136. {
  137. lg.getLogger(SIPmodel.class.getName()).log(Level.SEVERE, null, ex);
  138. }
  139. }
  140. //Aktive Kommunikation
  141. else if ((Request.INVITE).equals(requestEvent.getRequest().getMethod())) // Invite von anderem Benutzer
  142. {
  143. try
  144. {
  145. this.sipProvider.sendResponse(create180Ringing(requestEvent));
  146. view.getTxtArea().append("Ringing geschickt\n");
  147. }
  148. catch (Exception ex)//Exceptions evtl. genauer definieren
  149. {
  150. lg.getLogger(SIPmodel.class.getName()).log(Level.SEVERE, null, ex);
  151. }
  152. countWerdeAngerufen++; //bessere Lösung muss her!!, was schickt andere User oder Proxy bei nicht erreichen
  153. FromHeader abc = (FromHeader) requestEvent.getRequest().getHeader("From");
  154. evtWerdeAngerufen = requestEvent;
  155. System.out.println(countWerdeAngerufen);
  156. if (countWerdeAngerufen < 7)
  157. {
  158. werdeAngerufen = true;
  159. lg.info("Hab Invitation bekommen");
  160. view.getTxtArea().append("Werde von " + abc.getAddress() + " angerufen\n");
  161. }
  162. else
  163. {
  164. werdeAngerufen = false;
  165. lg.info("Leider waren Sie nicht erreichbar");
  166. view.getTxtArea().append("Sie waren nicht erreichbar\n");
  167. countWerdeAngerufen = 0;
  168. }
  169. }
  170. else if ((Request.ACK).equals(requestEvent.getRequest().getMethod()))
  171. {
  172. }
  173. else if ((Request.CANCEL).equals(requestEvent.getRequest().getMethod()))
  174. {
  175. view.getTxtArea().append("Anruf wurde gecancelt");
  176. try
  177. {
  178. //Cancel Request -> Response 200 Ok + Response 487 Request Terminated
  179. //200 Ok
  180. werdeAngerufen = false;
  181. evtWerdeAngerufen = null; // sicher ist sicher
  182. SIP200Ok tempOk = new SIP200Ok(messageFactory, requestEvent, contactHeader, headerFactory);
  183. this.sipProvider.sendResponse(tempOk.getResponse());
  184. view.getTxtArea().append("Anrufender canceld Anfrage\n");
  185. lg.info("Erfolgreiches senden des 200 OkHeaders auf CancelAnfrage");
  186. //487 Request Terminated
  187. }
  188. catch (SipException ex)
  189. {
  190. Logger.getLogger(SIPmodel.class.getName()).log(Level.SEVERE, null, ex);
  191. }
  192. }
  193. else if ((Request.BYE).equals(requestEvent.getRequest().getMethod()))
  194. {
  195. try
  196. {
  197. SIP200Ok tempOk = new SIP200Ok(messageFactory, requestEvent, contactHeader, headerFactory);
  198. this.sipProvider.sendResponse(tempOk.getResponse());
  199. }
  200. catch (Exception ex)
  201. {
  202. }
  203. }
  204. }
  205. @Override
  206. public void processResponse(ResponseEvent responseEvent)
  207. {
  208. if (responseEvent.getResponse().getStatusCode() == Response.UNAUTHORIZED)
  209. {
  210. try
  211. {
  212. cSequenz += 1L;
  213. branch += 10;
  214. SIPUnauthReq req2 = new SIPUnauthReq(myName, proxyAddress, myTag, myIPAddress, branch, cSequenz, myPort, contactHeader, addressFactory, headerFactory, responseEvent, messageFactory);
  215. sipProvider.sendRequest(req2.getUnauthReq());
  216. view.getTxtArea().append("Erfolgreich registriert\n");
  217. }
  218. catch (SipException ex)
  219. {
  220. lg.getLogger(SIPmodel.class.getName()).log(Level.SEVERE, null, ex);
  221. }
  222. }
  223. else if (responseEvent.getResponse().getStatusCode() == Response.OK)
  224. {
  225. lg.info("Erfolgreichen Response (200 OK) bekommen");
  226. }
  227. else if (responseEvent.getResponse().getStatusCode() == Response.RINGING)
  228. {
  229. ToHeader temp = (ToHeader) responseEvent.getResponse().getHeader("To");
  230. proxyTag = temp.getTag();
  231. }
  232. }
  233. public Response create180Ringing(RequestEvent requestEvent) throws ParseException, SipException
  234. {
  235. Response responsering = this.messageFactory.createResponse(180, requestEvent.getRequest());
  236. responsering.addHeader((ViaHeader) requestEvent.getRequest().getHeader("Via"));
  237. responsering.addHeader((FromHeader) requestEvent.getRequest().getHeader("From"));
  238. AllowHeader allow = this.headerFactory.createAllowHeader("NOTIFY,INVITE,ACK,CANCEL,BYE,REFER,INFO,OPTIONS,MESSAGE");
  239. //Bei Ringing muss persönlicher Tag ergänzt werden
  240. ToHeader temptoring = (ToHeader) requestEvent.getRequest().getHeader("To");
  241. proxyTag = temptoring.getTag();
  242. temptoring.setTag(this.myTag);
  243. responsering.addHeader(temptoring);
  244. cSequenz = ((CSeqHeader) requestEvent.getRequest().getHeader("Cseq")).getSeqNumber();
  245. responsering.addHeader((CSeqHeader) requestEvent.getRequest().getHeader("Cseq"));
  246. responsering.addHeader(contactHeader);
  247. responsering.addHeader(allow);
  248. AllowEventsHeader allowevent = this.headerFactory.createAllowEventsHeader("talk,hold,refer,call-info");// für was gebraucht
  249. responsering.addHeader(allowevent);
  250. return responsering;
  251. }
  252. public void annehmen() //Fehlende Bedingung
  253. {
  254. RequestEvent requestEvent;
  255. if ((requestEvent = evtWerdeAngerufen) != null && werdeAngerufen == true)
  256. {
  257. countWerdeAngerufen = 0;
  258. try
  259. {
  260. //Werte für weitere Kommunikation abspeichern
  261. callID = (CallIdHeader) requestEvent.getRequest().getHeader("Call-ID");
  262. CSeqHeader tempCs = (CSeqHeader) requestEvent.getRequest().getHeader("Cseq");
  263. cSequenz = tempCs.getSeqNumber();
  264. FromHeader tempFrom = (FromHeader) requestEvent.getRequest().getHeader("From");
  265. proxyTag = tempFrom.getTag();
  266. //Trying Header erzeugen und abschicken
  267. SIP100Trying tempTrying = new SIP100Trying(messageFactory, requestEvent, headerFactory);
  268. this.sipProvider.sendResponse(tempTrying.getTryResponse());
  269. view.getTxtArea().append("Trying geschickt\n");
  270. lg.info("Trying ist raus");
  271. //Ringing Header erzeugen und abschicken From tag: proxyTag; To Tag: persönlicher Tag
  272. SIP180Ringing tempRinging = new SIP180Ringing(requestEvent, myTag, proxyTag, contactHeader, headerFactory);
  273. sipProvider.sendResponse(tempRinging.getResponseRing());
  274. view.getTxtArea().append("Ringing geschickt\n");
  275. //200OK Header mit Session Description erstellen
  276. invite = false;
  277. SIP200Ok respcall = new SIP200Ok(messageFactory, requestEvent, contactHeader, headerFactory);
  278. SIPSessionDescription sdp = new SIPSessionDescription(myName, myIPAddress, requestEvent, false);
  279. respcall.addSDP(sdp.getSessionDescription(), myTag);
  280. System.out.println(respcall.getResponse());
  281. this.sipProvider.sendResponse(respcall.getResponse());
  282. view.getTxtArea().append("Telefonat beginnt\n");
  283. evtWerdeAngerufen = null;
  284. }
  285. catch (SipException ex)
  286. {
  287. Logger.getLogger(SIPmodel.class.getName()).log(Level.SEVERE, null, ex);
  288. }
  289. }
  290. else
  291. {
  292. view.getTxtArea().append("Zur Zeit gibt es keinen Anruf\n");
  293. }
  294. }
  295. public void byecall(String calluser) throws ParseException, InvalidArgumentException, SipException
  296. {
  297. invite = false;
  298. Address addressLine = this.addressFactory.createAddress("sip:" + calluser + "@" + proxyAddress);
  299. URI requestURI = addressLine.getURI();
  300. Address addressfrom = this.addressFactory.createAddress("sip:" + myName + "@" + myIPAddress);
  301. FromHeader from = this.headerFactory.createFromHeader(addressfrom, String.valueOf(this.myTag));
  302. Address addressTo = this.addressFactory.createAddress("sip:" + myName + "@" + proxyAddress);
  303. ToHeader to = this.headerFactory.createToHeader(addressTo, proxyTag); // Ergänzung TAG!!
  304. ArrayList via = new ArrayList(); //Via needs a List as input
  305. ViaHeader viaheader = this.headerFactory.createViaHeader(this.myIPAddress, this.myPort, "UDP", String.valueOf(branch));
  306. via.add(viaheader);
  307. cSequenz++;
  308. CSeqHeader cSeq = this.headerFactory.createCSeqHeader(cSequenz, "BYE");
  309. MaxForwardsHeader maxForwards = this.headerFactory.createMaxForwardsHeader(70);
  310. AllowHeader allow = this.headerFactory.createAllowHeader("NOTIFY,INVITE,ACK,CANCEL,BYE,REFER,INFO,OPTIONS,MESSAGE");
  311. ExpiresHeader expire = this.headerFactory.createExpiresHeader(3600); //int value
  312. Request request = this.messageFactory.createRequest(requestURI, "BYE", callID, cSeq, from, to, via, maxForwards);
  313. request.addHeader(contactHeader);
  314. request.addHeader(allow);
  315. request.addHeader(expire);
  316. this.sipProvider.sendRequest(request);
  317. invite = false;
  318. lg.info("Erfolgreiches Senden des BYE Headers");
  319. }
  320. //Get Methoden falls man mal die Parameter braucht
  321. public String getmyName()
  322. {
  323. return myName;
  324. }
  325. public Integer getMyPort()
  326. {
  327. return myPort;
  328. }
  329. public String getMyIPAdress()
  330. {
  331. return myIPAddress;
  332. }
  333. // Herausfinden bei welchen Events die unteren Funktionen aufgerufen werden -> evtl brauchbar
  334. @Override
  335. public void processTimeout(TimeoutEvent timeoutEvent)
  336. {
  337. //view.getTxtArea().append("processTimeout\n");
  338. }
  339. @Override
  340. public void processIOException(IOExceptionEvent exceptionEvent)
  341. {
  342. //view.getTxtArea().append("processIOException\n");
  343. }
  344. @Override
  345. public void processTransactionTerminated(
  346. TransactionTerminatedEvent transactionTerminatedEvent)
  347. {
  348. //view.getTxtArea().append("processTransactionTerminated\n");
  349. }
  350. @Override
  351. public void processDialogTerminated(
  352. DialogTerminatedEvent dialogTerminatedEvent)
  353. {
  354. //view.getTxtArea().append("processDialogTerminated\n");
  355. }
  356. @Override
  357. public void processDialogTimeout(DialogTimeoutEvent timeoutEvent)
  358. {
  359. //view.getTxtArea().append("processDialogTerminated\n");
  360. }
  361. /**
  362. * @param myPort the myPort to set
  363. */
  364. public void setMyPort(int myPort)
  365. {
  366. this.myPort = myPort;
  367. }
  368. /**
  369. * @return the myName
  370. */
  371. public String getMyName()
  372. {
  373. return myName;
  374. }
  375. /**
  376. * @return the proxyTag
  377. */
  378. public String getProxyTag()
  379. {
  380. return proxyTag;
  381. }
  382. /**
  383. * @param proxyTag the proxyTag to set
  384. */
  385. public void setProxyTag(String proxyTag)
  386. {
  387. this.proxyTag = proxyTag;
  388. }
  389. /**
  390. * @return the myTag
  391. */
  392. public String getMyTag()
  393. {
  394. return myTag;
  395. }
  396. /**
  397. * @param myTag the myTag to set
  398. */
  399. public void setMyTag(String myTag)
  400. {
  401. this.myTag = myTag;
  402. }
  403. /**
  404. * @return the branch
  405. */
  406. public int getBranch()
  407. {
  408. return branch;
  409. }
  410. }