com.logicbus.service.BizLoggerPause Maven / Gradle / Ivy
package com.logicbus.service;
import java.util.HashMap;
import java.util.Map;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import com.anysoft.util.Settings;
import com.logicbus.backend.AbstractServant;
import com.logicbus.backend.Context;
import com.logicbus.backend.ServantException;
import com.logicbus.backend.bizlog.BizLogger;
import com.logicbus.backend.message.JsonMessage;
import com.logicbus.backend.message.XMLMessage;
import com.logicbus.models.servant.ServiceDescription;
/**
* 暂停BizLogger的处理
*
* @author duanyy
*
* @since 1.2.7.2
*
* @version 1.4.0 [20141117 duanyy]
* - 将MessageDoc和Context进行合并整合
*/
public class BizLoggerPause extends AbstractServant {
protected void onDestroy() {
}
protected void onCreate(ServiceDescription sd) throws ServantException {
}
protected int onXml(Context ctx) {
XMLMessage msg = (XMLMessage) ctx.asMessage(XMLMessage.class);
Settings settings = Settings.get();
BizLogger bizLogger = (BizLogger) settings.get("bizLogger");
if (bizLogger != null){
bizLogger.pause();
Element root = msg.getRoot();
Document doc = root.getOwnerDocument();
Element logger = doc.createElement(bizLogger.getHandlerType());
bizLogger.report(logger);
root.appendChild(logger);
}
return 0;
}
protected int onJson(Context ctx) {
JsonMessage msg = (JsonMessage)ctx.asMessage(JsonMessage.class);
Settings settings = Settings.get();
BizLogger bizLogger = (BizLogger) settings.get("bizLogger");
if (bizLogger != null){
bizLogger.pause();
Map root = msg.getRoot();
Map logger = new HashMap();
bizLogger.report(logger);
root.put(bizLogger.getHandlerType(), logger);
}
return 0;
}
}