add "enable" : true/false to both udp listener and boblight, zeroconf cleanup (#22)

* Added "enable" : true to both udp and boblight server

* Changed the zeroconf/mDNS service names:
	_hyperiond-proto._tcp local
	_hyperiond-json._tcp local
	_hyperiond-rgbled._udp local

Changed the zeroconf/mDNS description:
	$leddevicename@$hostname

Removed the ability to configure these from the json config file

Cleaned up the formatting

* Change default priority of udp listener to be 700
This commit is contained in:
penfold42 2016-06-20 23:17:29 +10:00 committed by brindosch
parent 352738d74b
commit b971c39b07

View File

@ -218,55 +218,62 @@ void HyperionDaemon::startNetworkServices()
if (_config.isMember("boblightServer")) if (_config.isMember("boblightServer"))
{ {
const Json::Value & boblightServerConfig = _config["boblightServer"]; const Json::Value & boblightServerConfig = _config["boblightServer"];
_boblightServer = new BoblightServer(hyperion, boblightServerConfig.get("priority",900).asInt(), boblightServerConfig["port"].asUInt()); if ( boblightServerConfig.get("enable", true).asBool() )
{
_boblightServer = new BoblightServer(hyperion,
boblightServerConfig.get("priority",900).asInt(),
boblightServerConfig["port"].asUInt()
);
Info(_log, "Boblight server created and started on port %d", _boblightServer->getPort()); Info(_log, "Boblight server created and started on port %d", _boblightServer->getPort());
} }
}
// Create UDP listener if configuration is present // Create UDP listener if configuration is present
if (_config.isMember("udpListener")) if (_config.isMember("udpListener"))
{ {
const Json::Value & udpListenerConfig = _config["udpListener"]; const Json::Value & udpListenerConfig = _config["udpListener"];
if ( udpListenerConfig.get("enable", true).asBool() )
{
_udpListener = new UDPListener(hyperion, _udpListener = new UDPListener(hyperion,
udpListenerConfig.get("priority",890).asInt(), udpListenerConfig.get("priority",700).asInt(),
udpListenerConfig.get("timeout",10000).asInt(), udpListenerConfig.get("timeout",10000).asInt(),
udpListenerConfig["port"].asUInt() udpListenerConfig.get("port", 2801).asUInt()
); );
Info(_log, "UDP listener created and started on port %d", _udpListener->getPort()); Info(_log, "UDP listener created and started on port %d", _udpListener->getPort());
} }
// zeroconf
const Json::Value & deviceConfig = _config["device"];
const std::string deviceName = deviceConfig.get("name", "").asString();
const std::string hostname = QHostInfo::localHostName().toStdString();
// zeroconf json
std::string mDNSDescr_json = hostname;
std::string mDNSService_json = "_hyperiond_json._tcp";
if (_config.isMember("jsonServer"))
{
const Json::Value & jsonServerConfig = _config["jsonServer"];
mDNSDescr_json = jsonServerConfig.get("mDNSDescr", mDNSDescr_json).asString();
mDNSService_json = jsonServerConfig.get("mDNSService", mDNSService_json).asString();
} }
// zeroconf description - $leddevicename@$hostname
const Json::Value & deviceConfig = _config["device"];
const std::string mDNSDescr = ( deviceConfig.get("name", "").asString()
+ "@" +
QHostInfo::localHostName().toStdString()
);
// zeroconf udp listener
if (_udpListener != nullptr) {
BonjourServiceRegister *bonjourRegister_udp = new BonjourServiceRegister();
bonjourRegister_udp->registerService(
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-rgbled._udp", QString()),
_udpListener->getPort()
);
Info(_log, "UDP LIstener mDNS responder started");
}
// zeroconf json
BonjourServiceRegister *bonjourRegister_json = new BonjourServiceRegister(); BonjourServiceRegister *bonjourRegister_json = new BonjourServiceRegister();
bonjourRegister_json->registerService(BonjourRecord((deviceName + " @ " + mDNSDescr_json).c_str(), mDNSService_json.c_str(), bonjourRegister_json->registerService(
QString()), _jsonServer->getPort() ); BonjourRecord(mDNSDescr.c_str(), "_hyperiond-json._tcp", QString()),
_jsonServer->getPort()
);
Info(_log, "Json mDNS responder started"); Info(_log, "Json mDNS responder started");
// zeroconf proto // zeroconf proto
std::string mDNSDescr_proto = hostname;
std::string mDNSService_proto = "_hyperiond_proto._tcp";
if (_config.isMember("protoServer"))
{
const Json::Value & protoServerConfig = _config["protoServer"];
mDNSDescr_proto = protoServerConfig.get("mDNSDescr", mDNSDescr_proto).asString();
mDNSService_proto = protoServerConfig.get("mDNSService", mDNSService_proto).asString();
}
BonjourServiceRegister *bonjourRegister_proto = new BonjourServiceRegister(); BonjourServiceRegister *bonjourRegister_proto = new BonjourServiceRegister();
bonjourRegister_proto->registerService(BonjourRecord((deviceName + " @ " + mDNSDescr_proto).c_str(), mDNSService_proto.c_str(), bonjourRegister_proto->registerService(
QString()), _protoServer->getPort() ); BonjourRecord(mDNSDescr.c_str(), "_hyperiond-proto._tcp", QString()),
_protoServer->getPort()
);
Info(_log, "Proto mDNS responder started"); Info(_log, "Proto mDNS responder started");
} }