Files
JChargePointProtocol/jcpp-protocol-api/src/main/java/sanbing/jcpp/protocol/domain/ProtocolSession.java

122 lines
4.2 KiB
Java
Raw Normal View History

2024-10-08 09:38:54 +08:00
/**
2025-03-04 10:42:17 +08:00
* 开源代码仅供学习和交流研究使用商用请联系三丙
* 微信mohan_88888
* 抖音程序员三丙
* 付费课程知识星球https://t.zsxq.com/aKtXo
2024-10-08 09:38:54 +08:00
*/
package sanbing.jcpp.protocol.domain;
import com.github.benmanes.caffeine.cache.Cache;
import com.github.benmanes.caffeine.cache.Caffeine;
import lombok.Getter;
import lombok.Setter;
import lombok.extern.slf4j.Slf4j;
import sanbing.jcpp.proto.gen.ProtocolProto;
2024-10-22 17:11:05 +08:00
import sanbing.jcpp.proto.gen.ProtocolProto.DownlinkRequestMessage;
2024-10-08 09:38:54 +08:00
import sanbing.jcpp.protocol.forwarder.Forwarder;
import java.io.Closeable;
import java.time.Duration;
import java.time.LocalDateTime;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ScheduledFuture;
import java.util.function.Function;
/**
* @author 九筒
2024-10-08 09:38:54 +08:00
*/
@Getter
@Slf4j
public abstract class ProtocolSession implements Closeable {
private static final int REQUEST_CACHE_LIMIT = 1000;
protected final String protocolName;
protected final UUID id;
@Setter
protected LocalDateTime lastActivityTime;
protected final Set<String> pileCodeSet;
private final Map<String, ScheduledFuture<?>> scheduledFutures = new ConcurrentHashMap<>();
private final Cache<String, Object> requestCache = Caffeine.newBuilder()
.initialCapacity(REQUEST_CACHE_LIMIT)
.maximumSize(REQUEST_CACHE_LIMIT)
.expireAfterAccess(Duration.ofMinutes(1))
.build();
@Setter
private Forwarder forwarder;
2024-10-22 17:11:05 +08:00
protected ProtocolSession(String protocolName) {
2024-10-08 09:38:54 +08:00
this.protocolName = protocolName;
this.pileCodeSet = new LinkedHashSet<>();
this.id = UUID.randomUUID();
this.lastActivityTime = LocalDateTime.now();
}
2024-10-22 17:11:05 +08:00
public abstract void onDownlink(DownlinkRequestMessage downlinkMsg);
2024-10-08 09:38:54 +08:00
2025-02-13 10:03:59 +08:00
@Override
2024-10-08 09:38:54 +08:00
public void close() {
close(ProtocolProto.SessionCloseReason.SESSION_CLOSE_DESTRUCTION);
2024-10-08 09:38:54 +08:00
}
public void close(ProtocolProto.SessionCloseReason reason) {
2024-10-08 09:38:54 +08:00
log.info("[{}] Protocol会话关闭原因: {}", this, reason);
scheduledFutures.values().forEach(scheduledFuture -> scheduledFuture.cancel(true));
scheduledFutures.clear();
// 转发会话关闭事件到后端
if (forwarder != null && !pileCodeSet.isEmpty()) {
for (String pileCode : pileCodeSet) {
ProtocolProto.SessionCloseEventProto sessionCloseEvent = ProtocolProto.SessionCloseEventProto.newBuilder()
.setPileCode(pileCode)
.setReason(reason)
.setAdditionalInfo("Session closed: " + reason)
.build();
ProtocolProto.UplinkQueueMessage uplinkQueueMessage = ProtocolProto.UplinkQueueMessage.newBuilder()
.setMessageIdMSB(UUID.randomUUID().getMostSignificantBits())
.setMessageIdLSB(UUID.randomUUID().getLeastSignificantBits())
.setSessionIdMSB(id.getMostSignificantBits())
.setSessionIdLSB(id.getLeastSignificantBits())
.setMessageKey(pileCode + "_session_close")
.setProtocolName(protocolName)
.setSessionCloseEventProto(sessionCloseEvent)
.build();
try {
forwarder.sendMessage(uplinkQueueMessage);
log.debug("[{}] 会话关闭事件已转发,桩编码: {}, 原因: {}", this, pileCode, reason);
} catch (Exception e) {
log.error("[{}] 转发会话关闭事件失败,桩编码: {}", this, pileCode, e);
}
}
}
2024-10-08 09:38:54 +08:00
}
2024-10-08 09:38:54 +08:00
@Override
public String toString() {
return "[" + id + "]" + pileCodeSet;
}
public void addPileCode(String pileCode) {
this.pileCodeSet.add(pileCode);
}
public void addSchedule(String name, Function<String, ScheduledFuture<?>> scheduledFutureFunction) {
scheduledFutures.computeIfAbsent(name, scheduledFutureFunction);
}
}