From 868c78c0781691b4d721c81709250d93979a9416 Mon Sep 17 00:00:00 2001 From: Shamser Ahmed Date: Tue, 21 May 2024 12:57:52 +0100 Subject: [PATCH] HPCC-31775 Hook jlog to use api to log operator messages Signed-off-by: Shamser Ahmed --- dali/base/daclient.cpp | 4 ++ dali/base/sysinfologger.cpp | 78 +++++++++++++++++++++- dali/base/sysinfologger.hpp | 2 + esp/services/ws_workunits/ws_wudetails.cpp | 17 +++++ 4 files changed, 100 insertions(+), 1 deletion(-) diff --git a/dali/base/daclient.cpp b/dali/base/daclient.cpp index b8ef382995b..a61926c7b80 100644 --- a/dali/base/daclient.cpp +++ b/dali/base/daclient.cpp @@ -29,6 +29,7 @@ #include "dautils.hpp" #include "daclient.hpp" +#include "sysinfologger.hpp" extern bool registerClientProcess(ICommunicator *comm, IGroup *& retcoven,unsigned timeout,DaliClientRole role); extern void stopClientProcess(); @@ -141,6 +142,8 @@ bool initClientProcess(IGroup *servergrp, DaliClientRole role, unsigned mpport, covengrp->Release(); queryLogMsgManager()->setSession(myProcessSession()); + if (getGlobalConfigSP()->getPropBool("@enableGlobalSysLog", true)) + UseDaliForOperatorMessages(); if (!isContainerized()) // The Environment is bare-metal only { // auto install environment monitor for server roles @@ -177,6 +180,7 @@ void removeShutdownHook(IDaliClientShutdown &shutdown) void closedownClientProcess() { + UseDaliForOperatorMessages(false); if (!daliClientIsActive) return; while (shutdownHooks.ordinality()) diff --git a/dali/base/sysinfologger.cpp b/dali/base/sysinfologger.cpp index f91b6d7f91f..2adb21a5cb0 100644 --- a/dali/base/sysinfologger.cpp +++ b/dali/base/sysinfologger.cpp @@ -608,7 +608,83 @@ unsigned deleteOlderThanLogSysInfoMsg(bool visibleOnly, bool hiddenOnly, unsigne return count; } -#ifdef DISABLE_USE_CPPUNIT +class DaliMsgLoggerHandler : public CInterfaceOf +{ +public: + DaliMsgLoggerHandler(unsigned _messageFields=MSGFIELD_all) : messageFields(_messageFields) + { + } + virtual void handleMessage(const LogMsg & msg) override + { + LogMsgSysInfo sysInfo = msg.querySysInfo(); + time_t timeNum = sysInfo.queryTime(); + unsigned __int64 ts = sysInfo.queryTime() * 1000000 + sysInfo.queryUSecs(); + logSysInfoError(sysInfo.queryMsgID(), msg.queryCategory(), msg.queryCode(), queryComponentName(), msg.queryText(), ts); + } + virtual bool needsPrep() const override + { + return false; + } + virtual void prep() override + { + } + virtual unsigned queryMessageFields() const override + { + return messageFields; + } + virtual void setMessageFields(unsigned _fields = MSGFIELD_all) override + { + messageFields = _fields; + } + virtual void addToPTree(IPropertyTree * parent) const override + { + IPropertyTree * handlerTree = createPTree(ipt_caseInsensitive); + handlerTree->setProp("@type", "globalmessages"); + handlerTree->setPropInt("@fields", messageFields); + parent->addPropTree("handler", handlerTree); + } + virtual int flush() override + { + return 0; + } + virtual bool getLogName(StringBuffer &name) const override + { + return false; + } + virtual offset_t getLogPosition(StringBuffer &logFileName) const override + { + return 0; + } +private: + unsigned messageFields = MSGFIELD_all; +}; + +void UseDaliForOperatorMessages(bool use) +{ + static ILogMsgHandler *msgHandler=NULL; + if (use==(msgHandler!=NULL)) + return; + if (use) + { + msgHandler = getDaliMsgLoggerHandler(); + ILogMsgFilter * operatorFilter = getCategoryLogMsgFilter(MSGAUD_operator, + MSGCLS_disaster|MSGCLS_error|MSGCLS_warning, + WarnMsgThreshold, + true); + queryLogMsgManager()->addMonitorOwn(msgHandler, operatorFilter); + } + else { + queryLogMsgManager()->removeMonitor(msgHandler); + msgHandler = NULL; + } +} + +ILogMsgHandler * getDaliMsgLoggerHandler() +{ + return new DaliMsgLoggerHandler(); +} + +#ifdef _USE_CPPUNIT #include "unittests.hpp" #define SOURCE_CPPUNIT "cppunit" diff --git a/dali/base/sysinfologger.hpp b/dali/base/sysinfologger.hpp index a79924d50d7..4b80b906bea 100644 --- a/dali/base/sysinfologger.hpp +++ b/dali/base/sysinfologger.hpp @@ -88,4 +88,6 @@ SYSINFO_API unsigned hideLogSysInfoMsg(ISysInfoLoggerMsgFilter * msgFilter); SYSINFO_API unsigned deleteLogSysInfoMsg(ISysInfoLoggerMsgFilter * msgFilter); SYSINFO_API unsigned deleteOlderThanLogSysInfoMsg(bool visibleOnly, bool hiddenOnly, unsigned year, unsigned month, unsigned day); +SYSINFO_API ILogMsgHandler * getDaliMsgLoggerHandler(); +SYSINFO_API void UseDaliForOperatorMessages(bool use=true); #endif diff --git a/esp/services/ws_workunits/ws_wudetails.cpp b/esp/services/ws_workunits/ws_wudetails.cpp index bd295fbab37..e37f5c79408 100644 --- a/esp/services/ws_workunits/ws_wudetails.cpp +++ b/esp/services/ws_workunits/ws_wudetails.cpp @@ -22,6 +22,7 @@ #include "workunit.hpp" #include "jset.hpp" #include "jstatcodes.h" +#include "sysinfologger.hpp" typedef std::pair AttribValuePair; bool operator==(const AttribValuePair & p1, const AttribValuePair & p2) @@ -504,6 +505,22 @@ void WUDetails::processRequest(IEspWUDetailsRequest &req, IEspWUDetailsResponse espWuResponseNote->setCost(0); espWuResponseNotes.append(*espWuResponseNote.getClear()); } + Owned msgFilter = createSysInfoLoggerMsgFilter(); + msgFilter->setVisibleOnly(); + Owned msgIter = createSysInfoLoggerMsgIterator(msgFilter); + ForEach(*msgIter) + { + ISysInfoLoggerMsg & sysInfoMsg = msgIter->query(); + Owned espWuResponseNote = createWUResponseNote("",""); + StringBuffer tmpbuf; + encodeXML(sysInfoMsg.queryMsg(), tmpbuf, ENCODE_NEWLINES, strlen(sysInfoMsg.queryMsg()), true); + espWuResponseNote->setSource(sysInfoMsg.querySource()); + espWuResponseNote->setMessage(tmpbuf.str()); + espWuResponseNote->setErrorCode(sysInfoMsg.queryLogMsgCode()); + espWuResponseNote->setSeverity(LogMsgClassToVarString(sysInfoMsg.queryClass())); + espWuResponseNote->setCost(0); + espWuResponseNotes.append(*espWuResponseNote.getClear()); + } Owned respScope = createWUResponseScope("",""); respScope->setScopeName(""); respScope->setNotes(espWuResponseNotes);