parent
04df10154e
commit
418c87e2d7
@ -0,0 +1,124 @@
|
|||||||
|
|
||||||
|
#import log
|
||||||
|
#import config
|
||||||
|
|
||||||
|
from time import time
|
||||||
|
from random import randint
|
||||||
|
|
||||||
|
from twisted.internet import reactor,task
|
||||||
|
from twisted.internet.defer import Deferred
|
||||||
|
from twisted.internet.protocol import ClientFactory,ReconnectingClientFactory,Protocol
|
||||||
|
from twisted.protocols.basic import LineReceiver
|
||||||
|
|
||||||
|
#from pyrtp import *
|
||||||
|
|
||||||
|
# The module needs logging logging, but handlers, etc. are controlled by the parent
|
||||||
|
#import logging
|
||||||
|
#logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class CCCC():
|
||||||
|
def __init__(self,host,port):
|
||||||
|
self._CCClient = self.CCClient
|
||||||
|
self._rnd_number = randint(0x00, 0xFFFFFFFF)
|
||||||
|
self.hex_id = bytes(hex(self._rnd_number),'utf8')
|
||||||
|
self.bytes_id = self._rnd_number.to_bytes(4,byteorder="big")
|
||||||
|
|
||||||
|
self.CF = reactor.connectTCP(host, port, self.CCClientFactory(self._CCClient,self.hex_id))
|
||||||
|
|
||||||
|
def closeConnection(self):
|
||||||
|
self.transport.loseConnection()
|
||||||
|
|
||||||
|
class CCClient(LineReceiver):
|
||||||
|
|
||||||
|
delimiter = b'\n'
|
||||||
|
|
||||||
|
end = b"Bye-bye!"
|
||||||
|
|
||||||
|
def connectionMade(self):
|
||||||
|
#self.peer = self.transport.getPeer()
|
||||||
|
_hexid = self.hex_id
|
||||||
|
#
|
||||||
|
#CCCC._ssrc_list[_hexid] = self._peer
|
||||||
|
_linkid = b'91 '
|
||||||
|
_channel_name = b'CC outbound link'
|
||||||
|
_local_site_name = b'FreeDMR-Testing'
|
||||||
|
#Generate a random MAC that looks like a real one
|
||||||
|
#We don't really want to share our MAC ;-)
|
||||||
|
_local_mac = bytes(hex(randint(0x00, 0xFFFFFFFFFFFF)),'utf8')
|
||||||
|
#Fake a recent code_rev of CBridge
|
||||||
|
_code_rev = b'9959__December_5_2021__13.25.28'
|
||||||
|
#We'll use artistic licence on this one
|
||||||
|
_os_ver = b'FreeDMR Peer Server'
|
||||||
|
|
||||||
|
self.sendLine(_hexid)
|
||||||
|
self.sendLine(_linkid)
|
||||||
|
self.sendLine(_channel_name)
|
||||||
|
self.sendLine(_local_site_name)
|
||||||
|
self.sendLine(b'Server Inbound')
|
||||||
|
self.sendLine(_local_mac)
|
||||||
|
self.sendLine(_code_rev)
|
||||||
|
self.sendLine(_os_ver)
|
||||||
|
|
||||||
|
def lineReceived(self,line):
|
||||||
|
packet_dict = {}
|
||||||
|
#If we get codec AMBE (that's all we support)
|
||||||
|
if line == b'AMBE' or self._counter != 0:
|
||||||
|
self._counter = 6
|
||||||
|
else:
|
||||||
|
self.transport.loseConnection()
|
||||||
|
|
||||||
|
if self._counter:
|
||||||
|
if self._counter == 6:
|
||||||
|
self._ms_window = line
|
||||||
|
self._counter = 5
|
||||||
|
elif self._counter == 5:
|
||||||
|
self._seconds_microseconds = line
|
||||||
|
self._counter = 4
|
||||||
|
elif self._counter == 4:
|
||||||
|
self._syn_and_safe_ver_date = line
|
||||||
|
self._counter = 3
|
||||||
|
elif self._counter == 3:
|
||||||
|
self._remote_sys_name = line
|
||||||
|
self._counter = 2
|
||||||
|
elif self._counter == 2:
|
||||||
|
self._remote_tos_value = line
|
||||||
|
self._counter = 1
|
||||||
|
elif self._counter == 1:
|
||||||
|
self._remote_os_ver = line
|
||||||
|
self._counter = 0
|
||||||
|
|
||||||
|
line = line.decode("utf8")
|
||||||
|
if line[0:1] == 'B':
|
||||||
|
if line[1:3] == '01':
|
||||||
|
packet_dict['type'] = 'ON'
|
||||||
|
packet_dict['linkid'] = line[3:5]
|
||||||
|
packet_dict['line'] = line
|
||||||
|
else:
|
||||||
|
packet_dict['type'] = 'OFF'
|
||||||
|
packet_dict['linkid'] = line[1:3]
|
||||||
|
packet_dict['line'] = line
|
||||||
|
|
||||||
|
self.controlLine(packet_dict)
|
||||||
|
|
||||||
|
def controlLine(self,packet_dict):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class CCClientFactory(ReconnectingClientFactory):
|
||||||
|
def __init__(self,CCClient,hex_id):
|
||||||
|
self.done = Deferred()
|
||||||
|
self.protocol = CCClient
|
||||||
|
self.protocol.hex_id = hex_id
|
||||||
|
|
||||||
|
|
||||||
|
def clientConnectionFailed(self, connector, reason):
|
||||||
|
print("connection failed:", reason.getErrorMessage())
|
||||||
|
ReconnectingClientFactory.clientConnectionLost(self, connector, reason)
|
||||||
|
|
||||||
|
def clientConnectionLost(self, connector, reason):
|
||||||
|
print("connection lost:", reason.getErrorMessage())
|
||||||
|
ReconnectingClientFactory.clientConnectionLost(self, connector, reason)
|
||||||
|
|
||||||
|
|
||||||
Loading…
Reference in new issue