def main_func(): try: opts, args = getopt.getopt(sys.argv[1:], 'fl:p:n:L:') except getopt.GetoptError: print( 'usage: b2bua.py [-l addr] [-p port] [-n addr] [-f] [-L logfile]') sys.exit(1) laddr = None lport = None logfile = '/var/log/sippy.log' global_config = {'nh_addr': ['192.168.0.102', 5060]} foreground = False for o, a in opts: if o == '-f': foreground = True continue if o == '-l': laddr = a continue if o == '-p': lport = int(a) continue if o == '-L': logfile = a if o == '-n': if a.startswith('['): parts = a.split(']', 1) global_config['nh_addr'] = [parts[0] + ']', 5060] parts = parts[1].split(':', 1) else: parts = a.split(':', 1) global_config['nh_addr'] = [parts[0], 5060] if len(parts) == 2: global_config['nh_addr'][1] = int(parts[1]) continue global_config['nh_addr'] = tuple(global_config['nh_addr']) if not foreground: daemonize(logfile) SipConf.my_uaname = 'Sippy B2BUA (Simple)' SipConf.allow_formats = (0, 8, 18, 100, 101) global_config['_sip_address'] = SipConf.my_address global_config['_sip_port'] = SipConf.my_port if laddr != None: global_config['_sip_address'] = laddr if lport != None: global_config['_sip_port'] = lport global_config['_sip_logger'] = SipLogger('b2bua') cmap = CallMap(global_config) global_config['_sip_tm'] = SipTransactionManager(global_config, cmap.recvRequest) reactor.run(installSignalHandlers=True)
def main_func(): try: opts, args = getopt.getopt(sys.argv[1:], 'fl:p:n:L:') except getopt.GetoptError: print('usage: b2bua.py [-l addr] [-p port] [-n addr] [-f] [-L logfile]') sys.exit(1) laddr = None lport = None logfile = '/var/log/sippy.log' global_config = {'nh_addr':['192.168.0.102', 5060]} foreground = False for o, a in opts: if o == '-f': foreground = True continue if o == '-l': laddr = a continue if o == '-p': lport = int(a) continue if o == '-L': logfile = a if o == '-n': if a.startswith('['): parts = a.split(']', 1) global_config['nh_addr'] = [parts[0] + ']', 5060] parts = parts[1].split(':', 1) else: parts = a.split(':', 1) global_config['nh_addr'] = [parts[0], 5060] if len(parts) == 2: global_config['nh_addr'][1] = int(parts[1]) continue global_config['nh_addr'] = tuple(global_config['nh_addr']) if not foreground: daemonize(logfile) SipConf.my_uaname = 'Sippy B2BUA (Simple)' SipConf.allow_formats = (0, 8, 18, 100, 101) global_config['_sip_address'] = SipConf.my_address global_config['_sip_port'] = SipConf.my_port if laddr != None: global_config['_sip_address'] = laddr if lport != None: global_config['_sip_port'] = lport global_config['_sip_logger'] = SipLogger('b2bua') cmap = CallMap(global_config) global_config['_sip_tm'] = SipTransactionManager(global_config, cmap.recvRequest) reactor.run(installSignalHandlers = True)
continue if o == 'c': global_config['conffile'] = a.strip() continue sip_logger.write(' o reading config "%s"...' % \ global_config['conffile']) f = open(global_config['conffile']) config = read_cluster_config(global_config, f.read()) if not foreground: # Shut down the logger and reopen it again to make sure it's worker # thread won't be affected by the fork() sip_logger.shutdown() daemonize(logfile = logfile) file(pidfile, 'w').write(str(os.getpid()) + '\n') sip_logger = SipLogger('rtp_cluster') global_config['sip_logger'] = sip_logger sip_logger.write(' o initializing CLI...') cli = ClusterCLI(global_config) for c in config: #print 'Rtp_cluster', global_config, c['name'], c['address'] sip_logger.write(' o initializing cluster "%s" at <%s>' % (c['name'], c['address'])) rtp_cluster = Rtp_cluster(global_config, c['name'], c['address']) for rtpp_config in c['rtpproxies']: sip_logger.write(' - adding RTPproxy member %s at <%s>' % (rtpp_config['name'], rtpp_config['address']))
def main_func(): global_config = MyConfigParser() global_config['digest_auth'] = True global_config['start_acct_enable'] = False global_config['keepalive_ans'] = 0 global_config['keepalive_orig'] = 0 global_config['auth_enable'] = True global_config['acct_enable'] = True global_config['_pass_headers'] = [] global_config['_orig_argv'] = sys.argv[:] global_config['_orig_cwd'] = os.getcwd() try: opts, args = getopt.getopt( sys.argv[1:], 'fDl:p:d:P:L:s:a:t:T:k:m:A:ur:F:R:h:c:M:HC:W:', global_config.get_longopts()) except getopt.GetoptError: usage(global_config) global_config['foreground'] = False global_config['pidfile'] = '/var/run/b2bua.pid' global_config['logfile'] = '/var/log/b2bua.log' global_config['b2bua_socket'] = '/var/run/b2bua.sock' global_config['_sip_address'] = SipConf.my_address global_config['_sip_port'] = SipConf.my_port global_config['_my_pid'] = os.getpid() rtp_proxy_clients = [] writeconf = None for o, a in opts: if o == '-f': global_config['foreground'] = True continue if o == '-l': global_config.check_and_set('sip_address', a) continue if o == '-p': global_config.check_and_set('sip_port', a) continue if o == '-P': global_config.check_and_set('pidfile', a) continue if o == '-L': global_config.check_and_set('logfile', a) continue if o == '-s': global_config.check_and_set('static_route', a) continue if o == '-a': global_config.check_and_set('accept_ips', a) continue if o == '-D': global_config['digest_auth'] = False continue if o == '-A': acct_level = int(a.strip()) if acct_level == 0: global_config['acct_enable'] = False global_config['start_acct_enable'] = False elif acct_level == 1: global_config['acct_enable'] = True global_config['start_acct_enable'] = False elif acct_level == 2: global_config['acct_enable'] = True global_config['start_acct_enable'] = True else: sys.__stderr__.write( 'ERROR: -A argument not in the range 0-2\n') usage(global_config, True) continue if o == '-t': global_config.check_and_set('static_tr_in', a) continue if o == '-T': global_config.check_and_set('static_tr_out', a) continue if o == '-k': ka_level = int(a.strip()) if ka_level == 0: pass elif ka_level == 1: global_config['keepalive_ans'] = 32 elif ka_level == 2: global_config['keepalive_orig'] = 32 elif ka_level == 3: global_config['keepalive_ans'] = 32 global_config['keepalive_orig'] = 32 else: sys.__stderr__.write( 'ERROR: -k argument not in the range 0-3\n') usage(global_config, True) if o == '-m': global_config.check_and_set('max_credit_time', a) continue if o == '-u': global_config['auth_enable'] = False continue if o == '-r': global_config.check_and_set('rtp_proxy_client', a) continue if o == '-F': global_config.check_and_set('allowed_pts', a) continue if o == '-R': global_config.check_and_set('radiusclient.conf', a) continue if o == '-h': for a in a.split(','): global_config.check_and_set('pass_header', a) continue if o == '-c': global_config.check_and_set('b2bua_socket', a) continue if o == '-M': global_config.check_and_set('max_radiusclients', a) continue if o == '-H': global_config['hide_call_id'] = True continue if o in ('-C', '--config'): global_config.read(a.strip()) continue if o.startswith('--'): global_config.check_and_set(o[2:], a) continue if o == '-W': writeconf = a.strip() continue if '_rtp_proxy_clients' in global_config: for a in global_config['_rtp_proxy_clients']: rtp_proxy_clients.append(a) if 'static_route' in global_config: global_config['_static_route'] = B2BRoute( global_config['static_route']) elif not global_config['auth_enable']: sys.__stderr__.write( 'ERROR: static route should be specified when Radius auth is disabled\n' ) usage(global_config, True) if writeconf != None: global_config.write(open(writeconf, 'w')) if not global_config['foreground']: daemonize(logfile=global_config['logfile']) global_config['_sip_logger'] = SipLogger('b2bua') if len(rtp_proxy_clients) > 0: global_config['_rtp_proxy_clients'] = [] for address in rtp_proxy_clients: global_config['_rtp_proxy_clients'].append( Rtp_proxy_client(global_config, spath=address)) if global_config['auth_enable'] or global_config['acct_enable']: global_config['_radius_client'] = RadiusAuthorisation(global_config) global_config['_uaname'] = 'Sippy B2BUA (RADIUS)' global_config['_cmap'] = CallMap(global_config) if 'sip_proxy' in global_config: host_port = global_config['sip_proxy'].split(':', 1) if len(host_port) == 1: global_config['_sip_proxy'] = (host_port[0], 5060) else: global_config['_sip_proxy'] = (host_port[0], int(host_port[1])) global_config['_cmap'].proxy = StatefulProxy( global_config, global_config['_sip_proxy']) if global_config.getdefault('xmpp_b2bua_id', None) != None: global_config['_xmpp_mode'] = True global_config['_sip_tm'] = SipTransactionManager( global_config, global_config['_cmap'].recvRequest) global_config['_sip_tm'].nat_traversal = global_config.getdefault( 'nat_traversal', False) cmdfile = global_config['b2bua_socket'] if cmdfile.startswith('unix:'): cmdfile = cmdfile[5:] cli_server = CLIConnectionManager(global_config['_cmap'].recvCommand, cmdfile) if not global_config['foreground']: open(global_config['pidfile'], 'w').write(str(os.getpid()) + '\n') Signal(SIGUSR1, reopen, SIGUSR1, global_config['logfile']) ED2.loop()
def main_func(): global_config = MyConfigParser() global_config['digest_auth'] = True global_config['start_acct_enable'] = False global_config['keepalive_ans'] = 0 global_config['keepalive_orig'] = 0 global_config['auth_enable'] = True global_config['acct_enable'] = True global_config['_pass_headers'] = [] global_config['_orig_argv'] = sys.argv[:] global_config['_orig_cwd'] = os.getcwd() try: opts, args = getopt.getopt(sys.argv[1:], 'fDl:p:d:P:L:s:a:t:T:k:m:A:ur:F:R:h:c:M:HC:W:', global_config.get_longopts()) except getopt.GetoptError: usage(global_config) global_config['foreground'] = False global_config['pidfile'] = '/var/run/b2bua.pid' global_config['logfile'] = '/var/log/b2bua.log' global_config['b2bua_socket'] = '/var/run/b2bua.sock' global_config['_sip_address'] = SipConf.my_address global_config['_sip_port'] = SipConf.my_port global_config['_my_pid'] = os.getpid() rtp_proxy_clients = [] writeconf = None for o, a in opts: if o == '-f': global_config['foreground'] = True continue if o == '-l': global_config.check_and_set('sip_address', a) continue if o == '-p': global_config.check_and_set('sip_port', a) continue if o == '-P': global_config.check_and_set('pidfile', a) continue if o == '-L': global_config.check_and_set('logfile', a) continue if o == '-s': global_config.check_and_set('static_route', a) continue if o == '-a': global_config.check_and_set('accept_ips', a) continue if o == '-D': global_config['digest_auth'] = False continue if o == '-A': acct_level = int(a.strip()) if acct_level == 0: global_config['acct_enable'] = False global_config['start_acct_enable'] = False elif acct_level == 1: global_config['acct_enable'] = True global_config['start_acct_enable'] = False elif acct_level == 2: global_config['acct_enable'] = True global_config['start_acct_enable'] = True else: sys.__stderr__.write('ERROR: -A argument not in the range 0-2\n') usage(global_config, True) continue if o == '-t': global_config.check_and_set('static_tr_in', a) continue if o == '-T': global_config.check_and_set('static_tr_out', a) continue if o == '-k': ka_level = int(a.strip()) if ka_level == 0: pass elif ka_level == 1: global_config['keepalive_ans'] = 32 elif ka_level == 2: global_config['keepalive_orig'] = 32 elif ka_level == 3: global_config['keepalive_ans'] = 32 global_config['keepalive_orig'] = 32 else: sys.__stderr__.write('ERROR: -k argument not in the range 0-3\n') usage(global_config, True) if o == '-m': global_config.check_and_set('max_credit_time', a) continue if o == '-u': global_config['auth_enable'] = False continue if o == '-r': global_config.check_and_set('rtp_proxy_client', a) continue if o == '-F': global_config.check_and_set('allowed_pts', a) continue if o == '-R': global_config.check_and_set('radiusclient.conf', a) continue if o == '-h': for a in a.split(','): global_config.check_and_set('pass_header', a) continue if o == '-c': global_config.check_and_set('b2bua_socket', a) continue if o == '-M': global_config.check_and_set('max_radiusclients', a) continue if o == '-H': global_config['hide_call_id'] = True continue if o in ('-C', '--config'): global_config.read(a.strip()) continue if o.startswith('--'): global_config.check_and_set(o[2:], a) continue if o == '-W': writeconf = a.strip() continue if '_rtp_proxy_clients' in global_config: for a in global_config['_rtp_proxy_clients']: rtp_proxy_clients.append(a) if 'static_route' in global_config: global_config['_static_route'] = B2BRoute(global_config['static_route']) elif not global_config['auth_enable']: sys.__stderr__.write('ERROR: static route should be specified when Radius auth is disabled\n') usage(global_config, True) if writeconf != None: global_config.write(open(writeconf, 'w')) if not global_config['foreground']: daemonize(logfile = global_config['logfile']) global_config['_sip_logger'] = SipLogger('b2bua') if len(rtp_proxy_clients) > 0: global_config['_rtp_proxy_clients'] = [] for address in rtp_proxy_clients: global_config['_rtp_proxy_clients'].append(Rtp_proxy_client(global_config, spath = address)) if global_config['auth_enable'] or global_config['acct_enable']: global_config['_radius_client'] = RadiusAuthorisation(global_config) global_config['_uaname'] = 'Sippy B2BUA (RADIUS)' global_config['_cmap'] = CallMap(global_config) if 'sip_proxy' in global_config: host_port = global_config['sip_proxy'].split(':', 1) if len(host_port) == 1: global_config['_sip_proxy'] = (host_port[0], 5060) else: global_config['_sip_proxy'] = (host_port[0], int(host_port[1])) global_config['_cmap'].proxy = StatefulProxy(global_config, global_config['_sip_proxy']) if global_config.getdefault('xmpp_b2bua_id', None) != None: global_config['_xmpp_mode'] = True global_config['_sip_tm'] = SipTransactionManager(global_config, global_config['_cmap'].recvRequest) global_config['_sip_tm'].nat_traversal = global_config.getdefault('nat_traversal', False) cmdfile = global_config['b2bua_socket'] if cmdfile.startswith('unix:'): cmdfile = cmdfile[5:] cli_server = CLIConnectionManager(global_config['_cmap'].recvCommand, cmdfile) if not global_config['foreground']: open(global_config['pidfile'], 'w').write(str(os.getpid()) + '\n') Signal(SIGUSR1, reopen, SIGUSR1, global_config['logfile']) ED2.loop()
if o == '-D': debug_threads = True continue sip_logger.write(' o reading config "%s"...' % \ global_config['conffile']) global_config['_sip_logger'] = sip_logger f = open(global_config['conffile']) config = read_cluster_config(global_config, f.read()) if not foreground: # Shut down the logger and reopen it again to make sure it's worker # thread won't be affected by the fork() sip_logger.shutdown() daemonize(logfile=logfile) file(pidfile, 'w').write(str(os.getpid()) + '\n') sip_logger = SipLogger('rtp_cluster') global_config['_sip_logger'] = sip_logger LogSignal(sip_logger, signal.SIGUSR1, reopen, logfile) LogSignal(sip_logger, signal.SIGTERM, terminate) sip_logger.write(' o initializing CLI...') if not dry_run: cli = Rtp_cluster_cli(global_config, address=csockfile) else: cli = fakecli() for c in config: #print 'Rtp_cluster', global_config, c['name'], c['address']
rtp_proxy_address = (a[1], 22222) else: rtp_proxy_address = (a[1], int(a[2])) rtp_proxy_clients.append(rtp_proxy_address) else: rtp_proxy_clients.append(a) if not global_config['auth_enable'] and not global_config.has_key('static_route'): sys.__stderr__.write('ERROR: static route should be specified when Radius auth is disabled\n') usage(global_config, True) if writeconf != None: global_config.write(open(writeconf, 'w')) if not global_config['foreground']: daemonize(logfile = global_config['logfile']) global_config['_sip_logger'] = SipLogger('b2bua') if len(rtp_proxy_clients) > 0: global_config['_rtp_proxy_clients'] = [] for address in rtp_proxy_clients: global_config['_rtp_proxy_clients'].append(Rtp_proxy_client(global_config, address)) if global_config['auth_enable'] or global_config['acct_enable']: global_config['_radius_client'] = RadiusAuthorisation(global_config) SipConf.my_uaname = 'Sippy B2BUA (RADIUS)' global_config['_cmap'] = CallMap(global_config) if global_config.has_key('sip_proxy'): host_port = global_config['sip_proxy'].split(':', 1)
continue if o == '-n': if a.startswith('['): parts = a.split(']', 1) global_config['nh_addr'] = [parts[0] + ']', 5060] parts = parts[1].split(':', 1) else: parts = a.split(':', 1) global_config['nh_addr'] = [parts[0], 5060] if len(parts) == 2: global_config['nh_addr'][1] = int(parts[1]) continue global_config['nh_addr'] = tuple(global_config['nh_addr']) if not foreground: daemonize(logfile = '/var/log/sippy.log') SipConf.my_uaname = 'Sippy B2BUA (Simple)' SipConf.allow_formats = (0, 8, 18, 100, 101) global_config['sip_address'] = SipConf.my_address global_config['sip_port'] = SipConf.my_port if laddr != None: global_config['sip_address'] = laddr if lport != None: global_config['sip_port'] = lport global_config['sip_logger'] = SipLogger('b2bua') cmap = CallMap(global_config) global_config['sip_tm'] = SipTransactionManager(global_config, cmap.recvRequest)
def main_func(): try: opts, args = getopt.getopt(sys.argv[1:], 'fl:p:n:L:') except getopt.GetoptError: print( 'usage: b2bua.py [-l addr] [-p port] [-n addr] [-f] [-L logfile]') sys.exit(1) laddr = None lport = None logfile = '/var/log/sippy.log' global_config = {'nh_addr': ['127.0.0.1', 5060]} foreground = False for o, a in opts: if o == '-f': foreground = True continue if o == '-l': laddr = a continue if o == '-p': lport = int(a) continue if o == '-L': logfile = a if o == '-n': if a.startswith('['): parts = a.split(']', 1) global_config['nh_addr'] = [parts[0] + ']', 5060] parts = parts[1].split(':', 1) else: parts = a.split(':', 1) global_config['nh_addr'] = [parts[0], 5060] if len(parts) == 2: global_config['nh_addr'][1] = int(parts[1]) continue global_config['nh_addr'] = tuple(global_config['nh_addr']) if not foreground: daemonize(logfile) SipConf.my_uaname = 'vos 2.1.10' SipConf.allow_formats = (0, 8, 18, 100, 101) global_config['_sip_address'] = SipConf.my_address global_config['_sip_port'] = SipConf.my_port if laddr != None: global_config['_sip_address'] = laddr if lport != None: global_config['_sip_port'] = lport global_config['_sip_logger'] = SipLogger('b2bua') # global_config['_invite_session'] = FuturesSession(max_workers=200) global_config['_request_session'] = FuturesSession(max_workers=200) global_config['_sip_logger'].write(global_config['_sip_address'], ":", global_config['_sip_port']) cmap = CallMap(global_config) global_config['_sip_tm'] = SipTransactionManager(global_config, cmap.recvRequest) ED2.loop()