mirror of
https://gitee.com/san-bing/JChargePointProtocol
synced 2026-05-06 19:09:57 +08:00
66 lines
2.0 KiB
Java
66 lines
2.0 KiB
Java
/**
|
||
* 抖音关注:程序员三丙
|
||
* 知识星球:https://t.zsxq.com/j9b21
|
||
*/
|
||
package sanbing.jcpp.protocol;
|
||
|
||
import lombok.extern.slf4j.Slf4j;
|
||
import sanbing.jcpp.infrastructure.stats.MessagesStats;
|
||
import sanbing.jcpp.infrastructure.util.exception.DownlinkException;
|
||
import sanbing.jcpp.infrastructure.util.trace.TracerRunnable;
|
||
import sanbing.jcpp.protocol.domain.ListenerToHandlerMsg;
|
||
import sanbing.jcpp.protocol.domain.SessionToHandlerMsg;
|
||
import sanbing.jcpp.protocol.forwarder.Forwarder;
|
||
|
||
import java.util.UUID;
|
||
|
||
/**
|
||
* @author baigod
|
||
*/
|
||
@Slf4j
|
||
public abstract class ProtocolMessageProcessor {
|
||
protected final Forwarder forwarder;
|
||
protected final ProtocolContext protocolContext;
|
||
|
||
protected ProtocolMessageProcessor(Forwarder forwarder, ProtocolContext protocolContext) {
|
||
this.forwarder = forwarder;
|
||
this.protocolContext = protocolContext;
|
||
}
|
||
|
||
public void uplinkHandleAsync(ListenerToHandlerMsg listenerToHandlerMsg, MessagesStats uplinkMsgStats) {
|
||
|
||
UUID id = listenerToHandlerMsg.session().getId();
|
||
|
||
protocolContext.getShardingThreadPool().execute(id, new TracerRunnable(() -> {
|
||
try {
|
||
|
||
listenerToHandlerMsg.session().setForwarder(forwarder);
|
||
|
||
uplinkHandle(listenerToHandlerMsg);
|
||
|
||
} catch (Exception e) {
|
||
|
||
uplinkMsgStats.incrementFailed();
|
||
|
||
log.error("{} 消息处理器处理报文异常", listenerToHandlerMsg.session(), e);
|
||
}
|
||
}));
|
||
}
|
||
|
||
protected abstract void uplinkHandle(ListenerToHandlerMsg listenerToHandlerMsg);
|
||
|
||
public void downlinkHandle(SessionToHandlerMsg sessionToHandlerMsg, MessagesStats downlinkMsgStats) throws DownlinkException {
|
||
try {
|
||
|
||
downlinkHandle(sessionToHandlerMsg);
|
||
|
||
} catch (Exception e) {
|
||
|
||
downlinkMsgStats.incrementFailed();
|
||
|
||
throw new DownlinkException(e.getMessage(), e);
|
||
}
|
||
}
|
||
|
||
protected abstract void downlinkHandle(SessionToHandlerMsg sessionToHandlerMsg);
|
||
} |