summaryrefslogtreecommitdiffstats
path: root/Handler
diff options
context:
space:
mode:
authorMac-Linux2011-07-27 18:30:10 +0200
committerMac-Linux2011-07-27 18:30:10 +0200
commit20ae34a577fdba1f28a35f2ef771f0ecfecdf6b1 (patch)
treeb01d033bc0da8676e5655108ac294ac0d3d69285 /Handler
parentchanging test (diff)
downloadgsm-selftest-20ae34a577fdba1f28a35f2ef771f0ecfecdf6b1.tar.gz
gsm-selftest-20ae34a577fdba1f28a35f2ef771f0ecfecdf6b1.tar.xz
gsm-selftest-20ae34a577fdba1f28a35f2ef771f0ecfecdf6b1.zip
take gsm handler from refik folder to being part of the test
Diffstat (limited to 'Handler')
-rw-r--r--Handler/sipHandler.py131
1 files changed, 89 insertions, 42 deletions
diff --git a/Handler/sipHandler.py b/Handler/sipHandler.py
index 91e3f62..e404e03 100644
--- a/Handler/sipHandler.py
+++ b/Handler/sipHandler.py
@@ -1,7 +1,7 @@
import sys
import string
import pjsua as pj
-import classServer
+import ServerClass
import LogFileClass
from time import sleep
@@ -30,7 +30,7 @@ class Account(pj.AccountCallback):
logger.logEvent("Hangup call")
call.hangup()
- logger.logEvent('200')
+ logger.logEvent('CALL OK')
class Calling(pj.CallCallback):
@@ -44,12 +44,12 @@ class Calling(pj.CallCallback):
if self.call.info().state_text == "CONNECTING":
logger.logEvent("Call Connecting")
logger.logEvent('200')
- server.sendData('200')
+ server.sendData('CALL OK')
if self.call.info().last_reason == "Busy Here":
logger.logEvent('Number busy or Offline')
- server.sendData('486')
- logger.logEvent('486')
+ server.sendData('CALL NOT OK')
+ logger.logEvent('CALL NOT OK')
if self.call.info().state == pj.CallState.DISCONNECTED:
logger.logEvent('Call Disconnected')
@@ -68,47 +68,66 @@ def make_call(uri):
logger.logEvent('408')
return None
-global acc_cfg
-global handler
-global state
+def greeting():
+ global server
+ global status
+ global port
-handler = sys.argv[1]
-port = sys.argv[2]
+ port = sys.argv[2]
+ server = None
+ status = None
-lib = pj.Lib()
-stop = False
+ server = ServerClass.ServerHandler(port)
+ logger.logEvent('try to Connect to Controller')
+ conn = server.openSocket()
-logger = LogFileClass.Logging('sipHandler.log')
-logger.logEvent('')
+ if server.connected == 1:
+ if server.receiveData(30) == 'HELLO HANDLER':
+ server.sendData('HELLO CONTROLLER')
+ status = 'OK'
+ else:
+ status = 'NOT OK'
+ logger.logEvent('cant connect to Controller')
+ sys.exit(1)
-while stop <> True:
-
- acc_cfg = None
+def initState():
+ global message
+ global state
+ global num
- lib.init(log_cfg = pj.LogConfig(level=1, callback=log_cb))
- transport = lib.create_transport(pj.TransportType.UDP, pj.TransportConfig(0))
+ logger.logEvent('init state')
+ message = server.receiveData(30)
- lib.start()
- lib.set_null_snd_dev()
+ if message == 'RECEIVER':
+ state = 'RECEIVER'
+
+ elif message[0:6] == 'CALLER':
+ state = 'CALLER'
+ num = message[7:]
+
+def initHandler():
+ global acc_cfg
+ global handler
+ global sipServer
- server = classServer.ServerHandler(port)
- logger.logEvent('Connect to Controller')
- conn = server.openSocket()
- message = server.receiveData(30)
- num = message[7:]
+ handler = sys.argv[1]
+
if handler == 'sip':
logger.logEvent('Beeing SIP')
acc_cfg = pj.AccountConfig("132.230.4.8","mpselftest1","1mpselftest")
+ sipServer = '132.230.4.8'
- elif handler == 'landline':
+ elif handler == 'landline':
logger.logEvent('Beeing Landline')
acc_cfg = pj.AccountConfig("sipgate.de","1289459","MMW9AX")
+ sipServer = 'sipgate.de'
elif handler == 'unisip':
logger.logEvent('Beeing University SIP')
acc_cfg = pj.AccountConfig("132.230.252.228", "4976120397897", "hB8M3WyFt61C")
+ sipServer = '132.230.252.228'
else:
logger.logEvent('Unknown Message')
@@ -116,45 +135,73 @@ while stop <> True:
server.closeConnection()
sys.exit(1)
- try:
+
+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()
+
+ greeting()
+ initHandler()
+
+ try:
+ initState()
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:
+ if state =='RECEIVER':
logger.logEvent(acc.info().reg_status)
- server.sendData('ready')
+ server.sendData('RECEIVER READY')
logger.logEvent('Receiver Handler Ready')
while 1:
data = server.receiveData(3)
- if data == "487":
+ if data == 'RECEIVE START':
+ logger.logEvent(data)
+
+ if data == 'TERMINATE CONNECTION':
logger.logEvent('Terminate')
stop = True
break
- elif message.find('CALLER') <> -1:
+ elif state =='CALLER':
logger.logEvent(acc.info().reg_status)
- server.sendData('ready')
+ server.sendData('CALLER 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":
+ if data == 'CALL START':
+ if num <> '':
+ sleep(5)
+ logger.logEvent(data)
+ logger.logEvent('Make a call to: ' + num)
+ number = "sip:"+num+"@"+sipServer
+ make_call(number)
+ else:
+ logger.logEvent('No number to call')
+ logger.logEvent('CALL NOT OK')
+
+ if data == 'TERMINATE CONNECTION':
stop = True
logger.logEvent('Terminate')
break
@@ -163,7 +210,7 @@ while stop <> True:
logger.logEvent('Unknow Message')
server.sendData('Unknow Message')
server.closeConnection()
- sys.exit(1)
+ sys.exit(0.5)
else:
logger.logEvent("488 Not Acceptable Here")