2020-06-01 17:11:56 +01:00
|
|
|
#include "stdafx.h"
|
|
|
|
#include "ApiLog.h"
|
2020-07-04 11:07:36 +01:00
|
|
|
#include <Windows.h>
|
|
|
|
|
|
|
|
CApiLogEntry::CApiLogEntry(quint64 ProcessId, const QString& Message)
|
|
|
|
{
|
|
|
|
m_ProcessId = ProcessId;
|
|
|
|
m_Message = Message;
|
|
|
|
m_TimeStamp = QDateTime::currentDateTime(); // ms resolution
|
|
|
|
|
|
|
|
static atomic<quint64> uid = 0;
|
|
|
|
m_uid = uid.fetch_add(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
//
|
2020-06-01 17:11:56 +01:00
|
|
|
|
|
|
|
CApiLog::CApiLog(QObject* parent) : QThread(parent)
|
|
|
|
{
|
|
|
|
m_pServer = NULL;
|
|
|
|
|
|
|
|
start();
|
|
|
|
}
|
|
|
|
|
|
|
|
CApiLog::~CApiLog()
|
|
|
|
{
|
|
|
|
quit();
|
|
|
|
if (!wait(10 * 1000))
|
|
|
|
terminate();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CApiLog::run()
|
|
|
|
{
|
|
|
|
qDebug() << "LogAPI server started";
|
|
|
|
|
|
|
|
m_pServer = new CApiLogServer();
|
|
|
|
|
|
|
|
QThread::run(); // run messge loop
|
|
|
|
|
|
|
|
m_pServer->deleteLater();
|
|
|
|
|
|
|
|
qDebug() << "LogAPI server stopped";
|
|
|
|
}
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
|
|
|
|
CApiLogServer::CApiLogServer()
|
|
|
|
{
|
|
|
|
m_pServer = new QLocalServer(this);
|
|
|
|
m_pServer->setSocketOptions(QLocalServer::WorldAccessOption);
|
|
|
|
if (!m_pServer->listen("LogAPI")) {
|
|
|
|
qDebug() << "Not able to open Server Pipe";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
connect(m_pServer, SIGNAL(newConnection()), this, SLOT(OnPipe()));
|
|
|
|
|
|
|
|
m_pApiLog = qobject_cast<CApiLog*>(thread());
|
|
|
|
}
|
|
|
|
|
|
|
|
void CApiLogServer::OnPipe()
|
|
|
|
{
|
|
|
|
QLocalSocket *pSocket = m_pServer->nextPendingConnection();
|
|
|
|
connect(pSocket, SIGNAL(readyRead()), this, SLOT(OnData()));
|
|
|
|
connect(pSocket, SIGNAL(disconnected()), this, SLOT(OnClose()));
|
|
|
|
|
2020-07-04 11:07:36 +01:00
|
|
|
ULONG ClientProcessId = 0;
|
|
|
|
GetNamedPipeClientProcessId((HANDLE)pSocket->socketDescriptor(), &ClientProcessId);
|
|
|
|
|
|
|
|
m_pClients.insert(pSocket, new SApiLog(ClientProcessId));
|
2020-06-01 17:11:56 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void CApiLogServer::OnData()
|
|
|
|
{
|
|
|
|
QLocalSocket* pSocket = qobject_cast<QLocalSocket*>(sender());
|
|
|
|
SApiLog* ApiLog = m_pClients.value(pSocket);
|
|
|
|
if (!ApiLog)
|
|
|
|
return;
|
|
|
|
|
|
|
|
ApiLog->Buffer.append(pSocket->readAll());
|
|
|
|
|
|
|
|
for (;;)
|
|
|
|
{
|
|
|
|
int endPos = ApiLog->Buffer.indexOf('\0');
|
|
|
|
if (endPos == -1)
|
|
|
|
break;
|
|
|
|
|
2020-07-04 11:07:36 +01:00
|
|
|
CApiLogEntryPtr LogEntry = CApiLogEntryPtr(new CApiLogEntry(ApiLog->ProcessId, QString(ApiLog->Buffer.data())));
|
2020-06-01 17:11:56 +01:00
|
|
|
ApiLog->Buffer.remove(0, endPos + 1);
|
2020-07-04 11:07:36 +01:00
|
|
|
|
|
|
|
QWriteLocker Lock(&m_pApiLog->m_ApiLogMutex);
|
|
|
|
m_pApiLog->m_ApiLogList.append(LogEntry);
|
2020-06-01 17:11:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CApiLogServer::OnClose()
|
|
|
|
{
|
|
|
|
QLocalSocket* pSocket = qobject_cast<QLocalSocket*>(sender());
|
|
|
|
delete m_pClients.take(pSocket);
|
|
|
|
pSocket->deleteLater();
|
|
|
|
}
|