summaryrefslogtreecommitdiffstats
path: root/Handler
diff options
context:
space:
mode:
authortt412011-07-23 02:58:02 +0200
committertt412011-07-23 02:58:02 +0200
commit7dad14ada675d92ac7bb94f7ea809d96374c1741 (patch)
tree9576b52798cace1dccbd7b999633e4a9b7fa94e2 /Handler
parentadd new file. (diff)
downloadgsm-selftest-7dad14ada675d92ac7bb94f7ea809d96374c1741.tar.gz
gsm-selftest-7dad14ada675d92ac7bb94f7ea809d96374c1741.tar.xz
gsm-selftest-7dad14ada675d92ac7bb94f7ea809d96374c1741.zip
managing files.
Diffstat (limited to 'Handler')
-rw-r--r--Handler/landlineCall.py135
-rw-r--r--Handler/landlineReceiver.py111
-rw-r--r--Handler/localsipReceiver.py112
-rw-r--r--Handler/sipCall.py135
-rw-r--r--Handler/sipHandler.py182
-rw-r--r--Handler/sipReceiver.py111
6 files changed, 182 insertions, 604 deletions
diff --git a/Handler/landlineCall.py b/Handler/landlineCall.py
deleted file mode 100644
index fcdf4fe..0000000
--- a/Handler/landlineCall.py
+++ /dev/null
@@ -1,135 +0,0 @@
-import sys
-import pjsua as pj
-import classServer
-import LogFileClass
-logger = LogFileClass.Logging('landlineCallHandler.log')
-from time import sleep
-
-
-def log_cb(level, str, len):
- print str, "landline log"
-
-# Receive events from Call
-class MyCallCallback(pj.CallCallback):
-
- def on_state(self):
- global current_call
-
- if self.call.info().state <> pj.CallState.DISCONNECTED:
- if self.call.info().state_text == "CONNECTING":
- logger.logEvent("Call Connecting")
- sleep(1)
- if self.call.info().state <> pj.CallState.DISCONNECTED:
- logger.logEvent("will Hangup call")
- current_call.hangup()
-
- logger.logEvent('200')
- server.sendData('200')
- else:
- sleep(0.5)
-
- if self.call.info().last_reason == "Busy Here":
- logger.logEvent('Number busy or Offline')
- server.sendData('486')
- logger.logEvent('486')
-
- if self.call.info().state == pj.CallState.DISCONNECTED:
- logger.logEvent('Call Disconnected')
- current_call = None
-
-
-def make_call(uri):
-
- try:
-
- cb=MyCallCallback()
- return acc.make_call(uri, cb)
-
- except pj.Error, e:
- print "408 " + str(e)
- logger.logEvent('408')
- return None
-
-
-lib = pj.Lib()
-stop =False
-current_call = None
-logger.logEvent('')
-
-while stop <> True:
-
-
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
-
- lib.start()
- lib.set_null_snd_dev()
-
-
- server = classServer.ServerHandler(50099)
- logger.logEvent('Connect to Controller via port 50099')
- conn = server.openSocket()
-
- try:
- logger.logEvent('Register Account to sipgate.de server')
- acc_cfg = pj.AccountConfig("sipgate.de","1289459","MMW9AX")
- acc = lib.create_account(acc_cfg, cb=pj.AccountCallback())
-
-
- if acc.info().reg_status < 700:
-
- server.sendData('ready')
- logger.logEvent('Handler Ready')
-
- while 1:
- try:
- data = server.receiveData(0)
- event = data[0:5]
- num = data[6:]
-
- if event == "start" and num <> "":
-
- logger.logEvent(event)
- logger.logEvent('Make a call to: ' + num)
- number = "sip:"+num+"@sipgate.de"
- current_call = make_call(number)
-
- if data == "487":
- stop = True
- logger.logEvent('Terminate')
- break
-
- except ValueError:
- logger.logEvent("error: Failed retrive message from Controller")
- logger.logEvent('999')
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
- else:
- logger.logEvent("488 Not Acceptable Here")
-
- lib.destroy()
- lib = None
- acc = None
-
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
- except ValueError:
- print "401 Unauthorized " + str(e)
- logger.logEvent("401 Unauthorized ")
-
-logger.logEvent("Goodbye")
-sleep(3)
-acc.delete()
-logger.logEvent('Un-Rigester SIP Account')
-lib.destroy()
-server.closeConnection()
-logger.logEvent('Close Connection to the Controller')
-lib = None
-acc = None
-
diff --git a/Handler/landlineReceiver.py b/Handler/landlineReceiver.py
deleted file mode 100644
index ba02562..0000000
--- a/Handler/landlineReceiver.py
+++ /dev/null
@@ -1,111 +0,0 @@
-import sys
-import pjsua as pj
-import classServer
-import LogFileClass
-
-from time import sleep
-
-logger = LogFileClass.Logging('LandlineRecHandler.log')
-
-def log_cb(level, str, len):
- print str, "landline Handler Receiver Log"
-
-
-class MyAccountCallback(pj.AccountCallback):
-
- def on_incoming_call(self, call):
-
- current_call = call
- logger.logEvent(current_call)
- sleep(0.5)
-
- call.answer(200)
- logger.logEvent("Answer call")
- sleep(0.5)
-
- if current_call <> None:
- logger.logEvent("Hangup call")
- call.hangup()
-
- server.sendData('200')
- logger.logEvent('200')
-lib = pj.Lib()
-stop = False
-logger.logEvent('')
-
-try:
-
- server = classServer.ServerHandler(50106)
- logger.logEvent('Connect to Controller via port 50106')
- conn = server.openSocket()
-
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
-
- lib.start()
- lib.set_null_snd_dev()
-
- try:
- logger.logEvent('Register Account to sipgate.de server')
- acc_cfg = pj.AccountConfig("sipgate.de","1289459","MMW9AX")
- acc = lib.create_account(acc_cfg, cb=MyAccountCallback())
-
- if acc.info().reg_status < 700:
-
- logger.logEvent(acc.info().reg_status)
- server.sendData('ready')
- logger.logEvent('Handler Ready')
-
- while stop <> True:
-
- data = server.receiveData(0)
-
- if data == "487":
- logger.logEvent('Terminate')
- stop = True
- break
-
- transport = None
- acc.delete()
- logger.logEvent('Un-Rigester SIP Account')
- acc = None
- lib.destroy()
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
- else:
- logger.logEvent("488 Not Acceptable Here")
- lib.destroy()
-
- lib = None
- acc = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
- except pj.Error, e:
- print "401 Unauthorized " +str(e)
- logger.logEvent("401 Unauthorized ")
-
- lib.destroy()
- lib = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-except pj.Error, e:
- print "Exception: " + str(e)
- logger.logEvent(str(e))
-
- lib.destroy()
-
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
-
-
-
diff --git a/Handler/localsipReceiver.py b/Handler/localsipReceiver.py
deleted file mode 100644
index eb95ce0..0000000
--- a/Handler/localsipReceiver.py
+++ /dev/null
@@ -1,112 +0,0 @@
-import sys
-import pjsua as pj
-import classServer
-import LogFileClass
-
-from time import sleep
-
-logger = LogFileClass.Logging('UniSIPRecHandler.log')
-
-def log_cb(level, str, len):
- print str, "SIP University account Handler Receiver Log"
-
-
-class MyAccountCallback(pj.AccountCallback):
-
- def on_incoming_call(self, call):
-
- current_call = call
- logger.logEvent(current_call)
- sleep(0.5)
-
- call.answer(200)
- logger.logEvent("Answer call")
- sleep(0.5)
-
- if current_call <> None:
- logger.logEvent("Hangup call")
- call.hangup()
-
- server.sendData('200')
- logger.logEvent('200')
-lib = pj.Lib()
-stop = False
-logger.logEvent('')
-
-try:
-
- server = classServer.ServerHandler(50107)
- logger.logEvent('Connect to Controller via port 50107')
- conn = server.openSocket()
-
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
-
- lib.start()
- lib.set_null_snd_dev()
-
- try:
- logger.logEvent('Register Account to University SIP server')
- acc_cfg = pj.AccountConfig("132.230.252.228", "4976120397897", "hB8M3WyFt61C")
- acc = lib.create_account(acc_cfg, cb=MyAccountCallback())
-
- if acc.info().reg_status < 700:
-
- logger.logEvent(acc.info().reg_status)
- sleep(5)
- server.sendData('ready')
- logger.logEvent('Handler Ready')
-
- while stop <> True:
-
- data = server.receiveData(0)
-
- if data == "487":
- logger.logEvent('Terminate')
- stop = True
- break
-
- transport = None
- acc.delete()
- logger.logEvent('Un-Rigester SIP Account')
- acc = None
- lib.destroy()
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
- else:
- logger.logEvent("488 Not Acceptable Here")
- lib.destroy()
-
- lib = None
- acc = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
- except pj.Error, e:
- print "401 Unauthorized " +str(e)
- logger.logEvent("401 Unauthorized ")
-
- lib.destroy()
- lib = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-except pj.Error, e:
- print "Exception: " + str(e)
- logger.logEvent(str(e))
-
- lib.destroy()
-
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
-
-
-
diff --git a/Handler/sipCall.py b/Handler/sipCall.py
deleted file mode 100644
index 51ae240..0000000
--- a/Handler/sipCall.py
+++ /dev/null
@@ -1,135 +0,0 @@
-import sys
-import pjsua as pj
-import classServer
-import LogFileClass
-logger = LogFileClass.Logging('sipCallHandler.log')
-from time import sleep
-
-
-def log_cb(level, str, len):
- print str, "SIP log"
-
-# Receive events from Call
-class MyCallCallback(pj.CallCallback):
-
- def on_state(self):
- global current_call
-
- if self.call.info().state <> pj.CallState.DISCONNECTED:
- if self.call.info().state_text == "CONNECTING":
- logger.logEvent("Call Connecting")
- sleep(1)
- if self.call.info().state <> pj.CallState.DISCONNECTED:
- logger.logEvent("will Hangup call")
- current_call.hangup()
-
- logger.logEvent('200')
- server.sendData('200')
- else:
- sleep(0.5)
-
- if self.call.info().last_reason == "Busy Here":
- logger.logEvent('Number busy or Offline')
- server.sendData('486')
- logger.logEvent('486')
-
- if self.call.info().state == pj.CallState.DISCONNECTED:
- logger.logEvent('Call Disconnected')
- current_call = None
-
-
-def make_call(uri):
-
- try:
-
- cb=MyCallCallback()
- return acc.make_call(uri, cb)
-
- except pj.Error, e:
- print "408 " + str(e)
- logger.logEvent('408')
- return None
-
-
-lib = pj.Lib()
-stop =False
-current_call = None
-logger.logEvent('')
-
-while stop <> True:
-
-
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
-
- lib.start()
- lib.set_null_snd_dev()
-
-
- server = classServer.ServerHandler(50097)
- logger.logEvent('Connect to Controller via port 50097')
- conn = server.openSocket()
-
- try:
- logger.logEvent('Register Account to SIP server')
- acc_cfg = pj.AccountConfig("132.230.4.8","mpselftest1","1mpselftest")
- acc = lib.create_account(acc_cfg, cb=pj.AccountCallback())
-
-
- if acc.info().reg_status < 700:
-
- server.sendData('ready')
- logger.logEvent('Handler Ready')
-
- while 1:
- try:
- data = server.receiveData(0)
- event = data[0:5]
- num = data[6:]
-
- if event == "start" and num <> "":
-
- logger.logEvent(event)
- logger.logEvent('Make a call to: ' + num)
- number = "sip:"+num+"@132.230.4.8"
- current_call = make_call(number)
-
- if data == "487":
- stop = True
- logger.logEvent('Terminate')
- break
-
- except ValueError:
- logger.logEvent("error: Failed retrive message from Controller")
- logger.logEvent('999')
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
- else:
- logger.logEvent("488 Not Acceptable Here")
-
- lib.destroy()
- lib = None
- acc = None
-
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
- except ValueError:
- print "401 Unauthorized " + str(e)
- logger.logEvent("401 Unauthorized ")
-
-logger.logEvent("Goodbye")
-sleep(3)
-acc.delete()
-logger.logEvent('Un-Rigester SIP Account')
-lib.destroy()
-server.closeConnection()
-logger.logEvent('Close Connection to the Controller')
-lib = None
-acc = None
-
diff --git a/Handler/sipHandler.py b/Handler/sipHandler.py
new file mode 100644
index 0000000..91e3f62
--- /dev/null
+++ b/Handler/sipHandler.py
@@ -0,0 +1,182 @@
+import sys
+import string
+import pjsua as pj
+import classServer
+import LogFileClass
+
+from time import sleep
+
+def log_cb(level, str, len):
+ print "--------starting Handler--------"
+
+# Receive events from incoming Call
+class Account(pj.AccountCallback):
+
+ def on_incoming_call(self, call):
+ global current_call
+
+ current_call = call
+ call_cb = Calling(current_call)
+ current_call.set_callback(call_cb)
+
+ logger.logEvent(current_call)
+ sleep(0.5)
+
+ call.answer(200)
+ logger.logEvent("Answer call")
+ sleep(0.5)
+
+ if current_call <> None:
+ logger.logEvent("Hangup call")
+ call.hangup()
+
+ logger.logEvent('200')
+
+class Calling(pj.CallCallback):
+
+ def __init__(self, call=None):
+ pj.CallCallback.__init__(self, call)
+
+ def on_state(self):
+ global current_call
+
+ if self.call.info().state <> pj.CallState.DISCONNECTED:
+ if self.call.info().state_text == "CONNECTING":
+ logger.logEvent("Call Connecting")
+ logger.logEvent('200')
+ server.sendData('200')
+
+ if self.call.info().last_reason == "Busy Here":
+ logger.logEvent('Number busy or Offline')
+ server.sendData('486')
+ logger.logEvent('486')
+
+ if self.call.info().state == pj.CallState.DISCONNECTED:
+ logger.logEvent('Call Disconnected')
+ current_call = None
+
+
+def make_call(uri):
+
+ try:
+
+ cb=Calling()
+ return acc.make_call(uri, cb)
+
+ except pj.Error, e:
+ print "408 " + str(e)
+ logger.logEvent('408')
+ return None
+
+global acc_cfg
+global handler
+global state
+
+handler = sys.argv[1]
+port = sys.argv[2]
+
+lib = pj.Lib()
+stop = False
+
+logger = LogFileClass.Logging('sipHandler.log')
+logger.logEvent('')
+
+while stop <> True:
+
+ acc_cfg = None
+
+ lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
+ transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
+
+ lib.start()
+ lib.set_null_snd_dev()
+
+ server = classServer.ServerHandler(port)
+ logger.logEvent('Connect to Controller')
+ conn = server.openSocket()
+
+ message = server.receiveData(30)
+ num = message[7:]
+
+ if handler == 'sip':
+ logger.logEvent('Beeing SIP')
+ acc_cfg = pj.AccountConfig("132.230.4.8","mpselftest1","1mpselftest")
+
+ elif handler == 'landline':
+ logger.logEvent('Beeing Landline')
+ acc_cfg = pj.AccountConfig("sipgate.de","1289459","MMW9AX")
+
+ elif handler == 'unisip':
+ logger.logEvent('Beeing University SIP')
+ acc_cfg = pj.AccountConfig("132.230.252.228", "4976120397897", "hB8M3WyFt61C")
+
+ else:
+ logger.logEvent('Unknown Message')
+ server.sendData('Unknown Message')
+ server.closeConnection()
+ sys.exit(1)
+
+ try:
+
+ logger.logEvent('Register Account to SIP server')
+ acc = lib.create_account(acc_cfg, cb=Account())
+
+
+ if acc.info().reg_status < 700:
+
+ if message.find('RECEIVER') <> -1:
+ logger.logEvent(acc.info().reg_status)
+ server.sendData('ready')
+ logger.logEvent('Receiver Handler Ready')
+
+ while 1:
+
+ data = server.receiveData(3)
+
+ if data == "487":
+ logger.logEvent('Terminate')
+ stop = True
+ break
+
+ elif message.find('CALLER') <> -1:
+ logger.logEvent(acc.info().reg_status)
+ server.sendData('ready')
+ logger.logEvent('Caller Handler Ready')
+
+ while 1:
+
+ data = server.receiveData(3)
+
+ if event == "start" and num <> "":
+
+ logger.logEvent(event)
+ logger.logEvent('Make a call to: ' + num)
+ number = "sip:"+num+"@132.230.4.8"
+ make_call(number)
+
+ if data == "487":
+ stop = True
+ logger.logEvent('Terminate')
+ break
+
+ else:
+ logger.logEvent('Unknow Message')
+ server.sendData('Unknow Message')
+ server.closeConnection()
+ sys.exit(1)
+
+ else:
+ logger.logEvent("488 Not Acceptable Here")
+ lib.destroy()
+
+ except ValueError:
+ print "401 Unauthorized " + str(e)
+ logger.logEvent("401 Unauthorized ")
+
+logger.logEvent("Goodbye")
+acc.delete()
+lib.destroy()
+server.closeConnection()
+lib = None
+acc = None
+
diff --git a/Handler/sipReceiver.py b/Handler/sipReceiver.py
deleted file mode 100644
index 62f9a49..0000000
--- a/Handler/sipReceiver.py
+++ /dev/null
@@ -1,111 +0,0 @@
-import sys
-import pjsua as pj
-import classServer
-import LogFileClass
-
-from time import sleep
-
-logger = LogFileClass.Logging('sipRecHandler.log')
-
-def log_cb(level, str, len):
- print str, "sip Handler Receiver Log"
-
-
-class MyAccountCallback(pj.AccountCallback):
-
- def on_incoming_call(self, call):
-
- current_call = call
- logger.logEvent(current_call)
- sleep(0.5)
-
- call.answer(200)
- logger.logEvent("Answer call")
- sleep(0.5)
-
- if current_call <> None:
- logger.logEvent("Hangup call")
- call.hangup()
-
- server.sendData('200')
- logger.logEvent('200')
-lib = pj.Lib()
-stop = False
-logger.logEvent('')
-
-try:
-
- server = classServer.ServerHandler(50104)
- logger.logEvent('Connect to Controller via port 50104')
- conn = server.openSocket()
-
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
-
- lib.start()
- lib.set_null_snd_dev()
-
- try:
- logger.logEvent('Register Account to SIP Asterik server')
- acc_cfg = pj.AccountConfig("132.230.4.8", "mpselftest2", "2mpselftest")
- acc = lib.create_account(acc_cfg, cb=MyAccountCallback())
-
- if acc.info().reg_status < 700:
-
- logger.logEvent(acc.info().reg_status)
- server.sendData('ready')
- logger.logEvent('Handler Ready')
-
- while stop <> True:
-
- data = server.receiveData(0)
-
- if data == "487":
- logger.logEvent('Terminate')
- stop = True
- break
-
- transport = None
- acc.delete()
- logger.logEvent('Un-Rigester SIP Account')
- acc = None
- lib.destroy()
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
- else:
- logger.logEvent("488 Not Acceptable Here")
- lib.destroy()
-
- lib = None
- acc = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
- except pj.Error, e:
- print "401 Unauthorized " +str(e)
- logger.logEvent("401 Unauthorized ")
-
- lib.destroy()
- lib = None
-
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-except pj.Error, e:
- print "Exception: " + str(e)
- logger.logEvent(str(e))
-
- lib.destroy()
-
- lib = None
- server.closeConnection()
- logger.logEvent('Close Connection to the Controller')
-
-
-
-
-