2013-08-23 20:44:53 +02:00
|
|
|
// Qt includes
|
|
|
|
#include <QUrl>
|
|
|
|
|
|
|
|
#include <xbmcvideochecker/XBMCVideoChecker.h>
|
|
|
|
|
2013-08-24 11:51:52 +02:00
|
|
|
XBMCVideoChecker::XBMCVideoChecker(const std::string & address, uint16_t port, uint64_t interval_ms, Hyperion * hyperion, int priority) :
|
2013-08-23 20:44:53 +02:00
|
|
|
QObject(),
|
2013-08-24 11:51:52 +02:00
|
|
|
_address(QString::fromStdString(address)),
|
2013-08-23 21:40:42 +02:00
|
|
|
_port(port),
|
|
|
|
_request("{\"jsonrpc\":\"2.0\",\"method\":\"Player.GetActivePlayers\",\"id\":1}"),
|
2013-08-23 20:44:53 +02:00
|
|
|
_timer(),
|
2013-08-23 21:40:42 +02:00
|
|
|
_socket(),
|
2013-08-23 20:44:53 +02:00
|
|
|
_hyperion(hyperion),
|
|
|
|
_priority(priority)
|
|
|
|
{
|
|
|
|
// setup timer
|
|
|
|
_timer.setSingleShot(false);
|
|
|
|
_timer.setInterval(interval_ms);
|
|
|
|
connect(&_timer, SIGNAL(timeout()), this, SLOT(sendRequest()));
|
|
|
|
|
2013-08-23 21:40:42 +02:00
|
|
|
// setup socket
|
|
|
|
connect(&_socket, SIGNAL(readyRead()), this, SLOT(receiveReply()));
|
2013-08-23 20:44:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void XBMCVideoChecker::start()
|
|
|
|
{
|
|
|
|
_timer.start();
|
|
|
|
}
|
|
|
|
|
|
|
|
void XBMCVideoChecker::sendRequest()
|
|
|
|
{
|
2013-08-23 21:40:42 +02:00
|
|
|
switch (_socket.state())
|
|
|
|
{
|
|
|
|
case QTcpSocket::UnconnectedState:
|
|
|
|
// not connected. try to connect
|
|
|
|
std::cout << "Connecting to " << _address.toStdString() << ":" << _port << " to check XBMC player status" << std::endl;
|
|
|
|
_socket.connectToHost(_address, _port);
|
|
|
|
break;
|
|
|
|
case QTcpSocket::ConnectedState:
|
|
|
|
// write the request on the socket
|
|
|
|
_socket.write(_request);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// whatever. let's check again at the next timer tick
|
|
|
|
break;
|
|
|
|
}
|
2013-08-23 20:44:53 +02:00
|
|
|
}
|
|
|
|
|
2013-08-23 21:40:42 +02:00
|
|
|
void XBMCVideoChecker::receiveReply()
|
2013-08-23 20:44:53 +02:00
|
|
|
{
|
2013-08-24 11:51:52 +02:00
|
|
|
// expect that the reply is received as a single message. Probably oke considering the size of the expected reply
|
2013-08-23 21:40:42 +02:00
|
|
|
QString reply(_socket.readAll());
|
|
|
|
|
|
|
|
if (reply.contains("playerid"))
|
2013-08-23 20:44:53 +02:00
|
|
|
{
|
2013-08-23 21:40:42 +02:00
|
|
|
// something is playing. check for "video" to check if a video is playing
|
|
|
|
// clear our priority channel to allow the grabbed vido colors to be shown
|
|
|
|
_hyperion->clear(_priority);
|
2013-08-23 20:44:53 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-08-23 21:40:42 +02:00
|
|
|
// Nothing is playing. set our priority channel completely to black
|
|
|
|
// The timeout is used to have the channel cleared after 30 seconds of connection problems...
|
|
|
|
_hyperion->setColor(_priority, RgbColor::BLACK, 30000);
|
2013-08-23 20:44:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|