2019-12-21 19:58:28 +00:00
|
|
|
from . import SdrSource
|
|
|
|
from owrx.socket import getAvailablePort
|
|
|
|
import socket
|
2019-12-27 23:26:45 +00:00
|
|
|
from owrx.command import CommandMapper, Flag, Option
|
2019-12-21 19:58:28 +00:00
|
|
|
|
|
|
|
import logging
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectorSource(SdrSource):
|
|
|
|
def __init__(self, id, props, port):
|
|
|
|
super().__init__(id, props, port)
|
|
|
|
self.controlSocket = None
|
|
|
|
self.controlPort = getAvailablePort()
|
2019-12-28 00:24:07 +00:00
|
|
|
self.getCommandMapper().setMappings(
|
|
|
|
{
|
|
|
|
"samp_rate": Option("-s"),
|
|
|
|
"tuner_freq": Option("-f"),
|
|
|
|
"port": Option("-p"),
|
|
|
|
"controlPort": Option("-c"),
|
|
|
|
"device": Option("-d"),
|
|
|
|
"iqswap": Flag("-i"),
|
|
|
|
"rtltcp_compat": Flag("-r"),
|
2019-12-28 22:05:59 +00:00
|
|
|
"ppm": Option("-P"),
|
2019-12-28 00:24:07 +00:00
|
|
|
"rf_gain": Option("-g"),
|
|
|
|
}
|
|
|
|
)
|
2019-12-21 19:58:28 +00:00
|
|
|
|
|
|
|
def getEventNames(self):
|
2019-12-27 23:26:45 +00:00
|
|
|
return super().getEventNames() + [
|
2019-12-21 19:58:28 +00:00
|
|
|
"device",
|
|
|
|
"iqswap",
|
|
|
|
"rtltcp_compat",
|
|
|
|
]
|
|
|
|
|
|
|
|
def sendControlMessage(self, prop, value):
|
|
|
|
logger.debug("sending property change over control socket: {0} changed to {1}".format(prop, value))
|
|
|
|
self.controlSocket.sendall("{prop}:{value}\n".format(prop=prop, value=value).encode())
|
|
|
|
|
2019-12-27 23:26:45 +00:00
|
|
|
def onPropertyChange(self, prop, value):
|
|
|
|
if self.monitor is None:
|
|
|
|
return
|
|
|
|
if (
|
2019-12-28 00:24:07 +00:00
|
|
|
(prop == "center_freq" or prop == "lfo_offset")
|
|
|
|
and "lfo_offset" in self.rtlProps
|
|
|
|
and self.rtlProps["lfo_offset"] is not None
|
2019-12-27 23:26:45 +00:00
|
|
|
):
|
|
|
|
freq = self.rtlProps["center_freq"] + self.rtlProps["lfo_offset"]
|
|
|
|
self.sendControlMessage("center_freq", freq)
|
|
|
|
else:
|
|
|
|
self.sendControlMessage(prop, value)
|
2019-12-21 19:58:28 +00:00
|
|
|
|
|
|
|
def postStart(self):
|
|
|
|
logger.debug("opening control socket...")
|
|
|
|
self.controlSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
|
|
self.controlSocket.connect(("localhost", self.controlPort))
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
super().stop()
|
|
|
|
if self.controlSocket:
|
|
|
|
self.controlSocket.close()
|
|
|
|
self.controlSocket = None
|
|
|
|
|
2019-12-27 23:26:45 +00:00
|
|
|
def getControlPort(self):
|
|
|
|
return self.controlPort
|
2019-12-21 19:58:28 +00:00
|
|
|
|
2019-12-27 23:26:45 +00:00
|
|
|
def getCommandValues(self):
|
|
|
|
values = super().getCommandValues()
|
|
|
|
values["port"] = self.getPort()
|
|
|
|
values["controlPort"] = self.getControlPort()
|
|
|
|
return values
|