mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
logging rework json/proto (#102)
* cleanup: remove ambiled device as written at the forum this is no longer supported. All people should move to adalight. They just need to flash a new sketch. * fix typo * travis.ci * travis: move to ubuntu 14.04 * script try * add serialport * update .json files * . * . * . * update travis * fix * typo * fix * . * disable v4l2 on mac * disable email notification * update osx * maybe fix * . * disable osx and rm v4l2 * try osx * try fix * travis update * add oe systemd file * Proto * Json * fix * fix2 * fix3 * . * typo * update * revert runtime error
This commit is contained in:
parent
070a534262
commit
c802505553
@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
// Hyperion includes
|
// Hyperion includes
|
||||||
#include <hyperion/Hyperion.h>
|
#include <hyperion/Hyperion.h>
|
||||||
|
#include <utils/Logger.h>
|
||||||
|
|
||||||
class JsonClientConnection;
|
class JsonClientConnection;
|
||||||
|
|
||||||
@ -56,4 +57,6 @@ private:
|
|||||||
|
|
||||||
/// List with open connections
|
/// List with open connections
|
||||||
QSet<JsonClientConnection *> _openConnections;
|
QSet<JsonClientConnection *> _openConnections;
|
||||||
|
|
||||||
|
Logger * _log;
|
||||||
};
|
};
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include <utils/ColorRgb.h>
|
#include <utils/ColorRgb.h>
|
||||||
#include <utils/GrabbingMode.h>
|
#include <utils/GrabbingMode.h>
|
||||||
#include <utils/VideoMode.h>
|
#include <utils/VideoMode.h>
|
||||||
|
#include <utils/Logger.h>
|
||||||
|
|
||||||
// jsoncpp includes
|
// jsoncpp includes
|
||||||
#include <message.pb.h>
|
#include <message.pb.h>
|
||||||
@ -126,4 +127,6 @@ private:
|
|||||||
|
|
||||||
/// The buffer used for reading data from the socket
|
/// The buffer used for reading data from the socket
|
||||||
QByteArray _receiveBuffer;
|
QByteArray _receiveBuffer;
|
||||||
|
|
||||||
|
Logger * _log;
|
||||||
};
|
};
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
#include <utils/ColorRgb.h>
|
#include <utils/ColorRgb.h>
|
||||||
#include <utils/GrabbingMode.h>
|
#include <utils/GrabbingMode.h>
|
||||||
#include <utils/VideoMode.h>
|
#include <utils/VideoMode.h>
|
||||||
|
#include <utils/Logger.h>
|
||||||
|
|
||||||
// forward decl
|
// forward decl
|
||||||
class ProtoClientConnection;
|
class ProtoClientConnection;
|
||||||
@ -87,4 +88,5 @@ private:
|
|||||||
/// Hyperion proto connection object for forwarding
|
/// Hyperion proto connection object for forwarding
|
||||||
QList<ProtoConnection*> _proxy_connections;
|
QList<ProtoConnection*> _proxy_connections;
|
||||||
|
|
||||||
|
Logger * _log;
|
||||||
};
|
};
|
||||||
|
@ -23,7 +23,7 @@ uint8_t BlackBorderDetector::calculateThreshold(double threshold)
|
|||||||
|
|
||||||
uint8_t blackborderThreshold = uint8_t(rgbThreshold);
|
uint8_t blackborderThreshold = uint8_t(rgbThreshold);
|
||||||
|
|
||||||
Info(Logger::getInstance("BLACKBORDER"), "threshold set to %f (%d)", threshold , int(blackborderThreshold));
|
Debug(Logger::getInstance("BLACKBORDER"), "threshold set to %f (%d)", threshold , int(blackborderThreshold));
|
||||||
|
|
||||||
return blackborderThreshold;
|
return blackborderThreshold;
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,7 @@ BlackBorderProcessor::BlackBorderProcessor(const Json::Value &blackborderConfig)
|
|||||||
, _consistentCnt(0)
|
, _consistentCnt(0)
|
||||||
, _inconsistentCnt(10)
|
, _inconsistentCnt(10)
|
||||||
{
|
{
|
||||||
Info(Logger::getInstance("BLACKBORDER"), "mode: %s", _detectionMode.c_str());
|
Debug(Logger::getInstance("BLACKBORDER"), "mode: %s", _detectionMode.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
BlackBorder BlackBorderProcessor::getCurrentBorder() const
|
BlackBorder BlackBorderProcessor::getCurrentBorder() const
|
||||||
|
@ -33,7 +33,8 @@ JsonClientConnection::JsonClientConnection(QTcpSocket *socket, Hyperion * hyperi
|
|||||||
_imageProcessor(ImageProcessorFactory::getInstance().newImageProcessor()),
|
_imageProcessor(ImageProcessorFactory::getInstance().newImageProcessor()),
|
||||||
_hyperion(hyperion),
|
_hyperion(hyperion),
|
||||||
_receiveBuffer(),
|
_receiveBuffer(),
|
||||||
_webSocketHandshakeDone(false)
|
_webSocketHandshakeDone(false),
|
||||||
|
_log(Logger::getInstance("JSONCLIENTCONNECTION"))
|
||||||
{
|
{
|
||||||
// connect internal signals and slots
|
// connect internal signals and slots
|
||||||
connect(_socket, SIGNAL(disconnected()), this, SLOT(socketClosed()));
|
connect(_socket, SIGNAL(disconnected()), this, SLOT(socketClosed()));
|
||||||
@ -167,7 +168,7 @@ void JsonClientConnection::handleWebSocketFrame()
|
|||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
std::cout << "JSONCLIENT INFO: Someone is sending very big messages over several frames... it's not supported yet" << std::endl;
|
Error(_log, "Someone is sending very big messages over several frames... it's not supported yet");
|
||||||
quint8 close[] = {0x88, 0};
|
quint8 close[] = {0x88, 0};
|
||||||
_socket->write((const char*)close, 2);
|
_socket->write((const char*)close, 2);
|
||||||
_socket->flush();
|
_socket->flush();
|
||||||
@ -178,7 +179,7 @@ void JsonClientConnection::handleWebSocketFrame()
|
|||||||
void JsonClientConnection::doWebSocketHandshake()
|
void JsonClientConnection::doWebSocketHandshake()
|
||||||
{
|
{
|
||||||
// http header, might not be a very reliable check...
|
// http header, might not be a very reliable check...
|
||||||
std::cout << "Websocket handshake" << std::endl;
|
Debug(_log, "Websocket handshake");
|
||||||
|
|
||||||
// get the key to prepare an answer
|
// get the key to prepare an answer
|
||||||
int start = _receiveBuffer.indexOf("Sec-WebSocket-Key") + 19;
|
int start = _receiveBuffer.indexOf("Sec-WebSocket-Key") + 19;
|
||||||
@ -403,7 +404,7 @@ void JsonClientConnection::handleServerInfoCommand(const Json::Value &)
|
|||||||
const ColorCorrection * colorTemp = _hyperion->getTemperature(tempId);
|
const ColorCorrection * colorTemp = _hyperion->getTemperature(tempId);
|
||||||
if (colorTemp == nullptr)
|
if (colorTemp == nullptr)
|
||||||
{
|
{
|
||||||
std::cerr << "JSONCLIENT ERROR: Incorrect color temperature correction id: " << tempId << std::endl;
|
Error(_log, "Incorrect color temperature correction id: %s", tempId.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -424,7 +425,7 @@ void JsonClientConnection::handleServerInfoCommand(const Json::Value &)
|
|||||||
const ColorTransform * colorTransform = _hyperion->getTransform(transformId);
|
const ColorTransform * colorTransform = _hyperion->getTransform(transformId);
|
||||||
if (colorTransform == nullptr)
|
if (colorTransform == nullptr)
|
||||||
{
|
{
|
||||||
std::cerr << "JSONCLIENT ERROR: Incorrect color transform id: " << transformId << std::endl;
|
Error(_log, "Incorrect color transform id: %s", transformId.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -462,7 +463,7 @@ void JsonClientConnection::handleServerInfoCommand(const Json::Value &)
|
|||||||
const ColorAdjustment * colorAdjustment = _hyperion->getAdjustment(adjustmentId);
|
const ColorAdjustment * colorAdjustment = _hyperion->getAdjustment(adjustmentId);
|
||||||
if (colorAdjustment == nullptr)
|
if (colorAdjustment == nullptr)
|
||||||
{
|
{
|
||||||
std::cerr << "JSONCLIENT ERROR: Incorrect color adjustment id: " << adjustmentId << std::endl;
|
Error(_log, "Incorrect color adjustment id: %s", adjustmentId.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -799,7 +800,7 @@ void JsonClientConnection::sendMessage(const Json::Value & message, QTcpSocket *
|
|||||||
socket->write(serializedMessage.c_str());
|
socket->write(serializedMessage.c_str());
|
||||||
if (!socket->waitForBytesWritten())
|
if (!socket->waitForBytesWritten())
|
||||||
{
|
{
|
||||||
//std::cout << "Error while writing data to host" << std::endl;
|
Debug(_log, "Error while writing data to host");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -810,7 +811,7 @@ void JsonClientConnection::sendMessage(const Json::Value & message, QTcpSocket *
|
|||||||
// receive reply
|
// receive reply
|
||||||
if (!socket->waitForReadyRead())
|
if (!socket->waitForReadyRead())
|
||||||
{
|
{
|
||||||
//std::cout << "Error while reading data from host" << std::endl;
|
Debug(_log, "Error while writing data from host");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -823,7 +824,7 @@ void JsonClientConnection::sendMessage(const Json::Value & message, QTcpSocket *
|
|||||||
Json::Value reply;
|
Json::Value reply;
|
||||||
if (!jsonReader.parse(serializedReply.constData(), serializedReply.constData() + bytes, reply))
|
if (!jsonReader.parse(serializedReply.constData(), serializedReply.constData() + bytes, reply))
|
||||||
{
|
{
|
||||||
//std::cout << "Error while parsing reply: invalid json" << std::endl;
|
Error(_log, "Error while parsing reply: invalid json");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -859,7 +860,7 @@ bool JsonClientConnection::checkJson(const Json::Value & message, const QString
|
|||||||
Json::Value schemaJson;
|
Json::Value schemaJson;
|
||||||
if (!jsonReader.parse(reinterpret_cast<const char *>(schemaData.data()), reinterpret_cast<const char *>(schemaData.data()) + schemaData.size(), schemaJson, false))
|
if (!jsonReader.parse(reinterpret_cast<const char *>(schemaData.data()), reinterpret_cast<const char *>(schemaData.data()) + schemaData.size(), schemaJson, false))
|
||||||
{
|
{
|
||||||
throw std::runtime_error("JSONCLIENT ERROR: Schema error: " + jsonReader.getFormattedErrorMessages()) ;
|
throw std::runtime_error("JSONCLIENT ERROR: Schema error: " + jsonReader.getFormattedErrorMessages());
|
||||||
}
|
}
|
||||||
|
|
||||||
// create schema checker
|
// create schema checker
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
|
|
||||||
// util includes
|
// util includes
|
||||||
#include <utils/jsonschema/JsonSchemaChecker.h>
|
#include <utils/jsonschema/JsonSchemaChecker.h>
|
||||||
|
#include <utils/Logger.h>
|
||||||
|
|
||||||
class ImageProcessor;
|
class ImageProcessor;
|
||||||
|
|
||||||
@ -194,4 +195,6 @@ private:
|
|||||||
|
|
||||||
/// used for WebSocket detection and connection handling
|
/// used for WebSocket detection and connection handling
|
||||||
bool _webSocketHandshakeDone;
|
bool _webSocketHandshakeDone;
|
||||||
|
|
||||||
|
Logger * _log;
|
||||||
};
|
};
|
||||||
|
@ -9,7 +9,8 @@ JsonServer::JsonServer(uint16_t port) :
|
|||||||
QObject(),
|
QObject(),
|
||||||
_hyperion(Hyperion::getInstance()),
|
_hyperion(Hyperion::getInstance()),
|
||||||
_server(),
|
_server(),
|
||||||
_openConnections()
|
_openConnections(),
|
||||||
|
_log(Logger::getInstance("JSONSERVER"))
|
||||||
{
|
{
|
||||||
if (!_server.listen(QHostAddress::Any, port))
|
if (!_server.listen(QHostAddress::Any, port))
|
||||||
{
|
{
|
||||||
@ -50,7 +51,7 @@ void JsonServer::newConnection()
|
|||||||
|
|
||||||
if (socket != nullptr)
|
if (socket != nullptr)
|
||||||
{
|
{
|
||||||
std::cout << "JSONSERVER INFO: New connection" << std::endl;
|
Debug(_log, "New connection");
|
||||||
JsonClientConnection * connection = new JsonClientConnection(socket, _hyperion);
|
JsonClientConnection * connection = new JsonClientConnection(socket, _hyperion);
|
||||||
_openConnections.insert(connection);
|
_openConnections.insert(connection);
|
||||||
|
|
||||||
@ -61,7 +62,7 @@ void JsonServer::newConnection()
|
|||||||
|
|
||||||
void JsonServer::closedConnection(JsonClientConnection *connection)
|
void JsonServer::closedConnection(JsonClientConnection *connection)
|
||||||
{
|
{
|
||||||
std::cout << "JSONSERVER INFO: Connection closed" << std::endl;
|
Debug(_log, "Connection closed");
|
||||||
_openConnections.remove(connection);
|
_openConnections.remove(connection);
|
||||||
|
|
||||||
// schedule to delete the connection object
|
// schedule to delete the connection object
|
||||||
|
@ -10,8 +10,9 @@
|
|||||||
ProtoConnection::ProtoConnection(const std::string & a) :
|
ProtoConnection::ProtoConnection(const std::string & a) :
|
||||||
_socket(),
|
_socket(),
|
||||||
_skipReply(false),
|
_skipReply(false),
|
||||||
_prevSocketState(QAbstractSocket::UnconnectedState)
|
_prevSocketState(QAbstractSocket::UnconnectedState),
|
||||||
{
|
_log(Logger::getInstance("PROTOCONNECTION"))
|
||||||
|
{
|
||||||
QString address(a.c_str());
|
QString address(a.c_str());
|
||||||
QStringList parts = address.split(":");
|
QStringList parts = address.split(":");
|
||||||
if (parts.size() != 2)
|
if (parts.size() != 2)
|
||||||
@ -28,7 +29,7 @@ ProtoConnection::ProtoConnection(const std::string & a) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
// try to connect to host
|
// try to connect to host
|
||||||
std::cout << "PROTOCONNECTION INFO: Connecting to Hyperion: " << _host.toStdString() << ":" << _port << std::endl;
|
Info(_log, "Connecting to Hyperion: %s:%d", _host.toStdString().c_str(), _port);
|
||||||
connectToHost();
|
connectToHost();
|
||||||
|
|
||||||
// start the connection timer
|
// start the connection timer
|
||||||
@ -74,7 +75,7 @@ void ProtoConnection::readData()
|
|||||||
|
|
||||||
if (!reply.ParseFromArray(_receiveBuffer.data() + 4, messageSize))
|
if (!reply.ParseFromArray(_receiveBuffer.data() + 4, messageSize))
|
||||||
{
|
{
|
||||||
std::cerr << "PROTOCONNECTION ERROR: Unable to parse message" << std::endl;
|
Error(_log, "Unable to parse message");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,11 +156,11 @@ void ProtoConnection::sendMessage(const proto::HyperionRequest &message)
|
|||||||
switch (_socket.state() )
|
switch (_socket.state() )
|
||||||
{
|
{
|
||||||
case QAbstractSocket::UnconnectedState:
|
case QAbstractSocket::UnconnectedState:
|
||||||
std::cout << "PROTOCONNECTION INFO: No connection to Hyperion: " << _host.toStdString() << ":" << _port << std::endl;
|
Info(_log, "No connection to Hyperion: %s:%d", _host.toStdString().c_str(), _port);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case QAbstractSocket::ConnectedState:
|
case QAbstractSocket::ConnectedState:
|
||||||
std::cout << "PROTOCONNECTION INFO: Connected to Hyperion: " << _host.toStdString() << ":" << _port << std::endl;
|
Info(_log, "Connected to Hyperion: %s:%d", _host.toStdString().c_str(), _port);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -193,7 +194,7 @@ void ProtoConnection::sendMessage(const proto::HyperionRequest &message)
|
|||||||
count += _socket.write(reinterpret_cast<const char *>(serializedMessage.data()), length);
|
count += _socket.write(reinterpret_cast<const char *>(serializedMessage.data()), length);
|
||||||
if (!_socket.waitForBytesWritten())
|
if (!_socket.waitForBytesWritten())
|
||||||
{
|
{
|
||||||
std::cerr << "PROTOCONNECTION ERROR: Error while writing data to host" << std::endl;
|
Error(_log, "Error while writing data to host");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,8 @@ ProtoServer::ProtoServer(uint16_t port) :
|
|||||||
QObject(),
|
QObject(),
|
||||||
_hyperion(Hyperion::getInstance()),
|
_hyperion(Hyperion::getInstance()),
|
||||||
_server(),
|
_server(),
|
||||||
_openConnections()
|
_openConnections(),
|
||||||
|
_log(Logger::getInstance("PROTOSERVER"))
|
||||||
{
|
{
|
||||||
|
|
||||||
MessageForwarder * forwarder = _hyperion->getForwarder();
|
MessageForwarder * forwarder = _hyperion->getForwarder();
|
||||||
@ -57,7 +58,7 @@ void ProtoServer::newConnection()
|
|||||||
|
|
||||||
if (socket != nullptr)
|
if (socket != nullptr)
|
||||||
{
|
{
|
||||||
std::cout << "PROTOSERVER INFO: New connection" << std::endl;
|
Debug(_log, "New connection");
|
||||||
ProtoClientConnection * connection = new ProtoClientConnection(socket, _hyperion);
|
ProtoClientConnection * connection = new ProtoClientConnection(socket, _hyperion);
|
||||||
_openConnections.insert(connection);
|
_openConnections.insert(connection);
|
||||||
|
|
||||||
@ -86,7 +87,7 @@ void ProtoServer::sendImageToProtoSlaves(int priority, const Image<ColorRgb> & i
|
|||||||
|
|
||||||
void ProtoServer::closedConnection(ProtoClientConnection *connection)
|
void ProtoServer::closedConnection(ProtoClientConnection *connection)
|
||||||
{
|
{
|
||||||
std::cout << "PROTOSERVER INFO: Connection closed" << std::endl;
|
Debug(_log, "Connection closed");
|
||||||
_openConnections.remove(connection);
|
_openConnections.remove(connection);
|
||||||
|
|
||||||
// schedule to delete the connection object
|
// schedule to delete the connection object
|
||||||
|
@ -299,7 +299,7 @@ void HyperionDaemon::startNetworkServices()
|
|||||||
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-rgbled._udp", QString()),
|
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-rgbled._udp", QString()),
|
||||||
_udpListener->getPort()
|
_udpListener->getPort()
|
||||||
);
|
);
|
||||||
Info(_log, "UDP LIstener mDNS responder started");
|
Debug(_log, "UDP LIstener mDNS responder started");
|
||||||
}
|
}
|
||||||
|
|
||||||
// zeroconf json
|
// zeroconf json
|
||||||
@ -308,7 +308,7 @@ void HyperionDaemon::startNetworkServices()
|
|||||||
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-json._tcp", QString()),
|
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-json._tcp", QString()),
|
||||||
_jsonServer->getPort()
|
_jsonServer->getPort()
|
||||||
);
|
);
|
||||||
Info(_log, "Json mDNS responder started");
|
Debug(_log, "Json mDNS responder started");
|
||||||
|
|
||||||
// zeroconf proto
|
// zeroconf proto
|
||||||
BonjourServiceRegister *bonjourRegister_proto = new BonjourServiceRegister();
|
BonjourServiceRegister *bonjourRegister_proto = new BonjourServiceRegister();
|
||||||
@ -316,7 +316,7 @@ void HyperionDaemon::startNetworkServices()
|
|||||||
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-proto._tcp", QString()),
|
BonjourRecord(mDNSDescr.c_str(), "_hyperiond-proto._tcp", QString()),
|
||||||
_protoServer->getPort()
|
_protoServer->getPort()
|
||||||
);
|
);
|
||||||
Info(_log, "Proto mDNS responder started");
|
Debug(_log, "Proto mDNS responder started");
|
||||||
}
|
}
|
||||||
|
|
||||||
void HyperionDaemon::createGrabberDispmanx()
|
void HyperionDaemon::createGrabberDispmanx()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user