fix message

This commit is contained in:
anlicheng 2026-03-27 13:28:01 +08:00
parent 18d9b33399
commit 5358d9a2b7
2 changed files with 29 additions and 43 deletions

View File

@ -104,9 +104,6 @@ actor SDLContextActor {
// arp // arp
await self.arpServer.start() await self.arpServer.start()
// puncher
await self.puncherActor.start()
await self.supervisor.addWorker(name: "quicClient") { await self.supervisor.addWorker(name: "quicClient") {
SDLLogger.shared.log("[SDLContext] try start quicClient") SDLLogger.shared.log("[SDLContext] try start quicClient")
let quicClient = try await self.startQUICClient() let quicClient = try await self.startQUICClient()

View File

@ -9,14 +9,20 @@ import Foundation
import NIOCore import NIOCore
actor SDLPuncherActor { actor SDLPuncherActor {
nonisolated private let cooldownInterval: TimeInterval = 5 // 10
nonisolated private let cooldownInterval: TimeInterval = 10
struct RequestContext {
let expireAt: Date
let request: RegisterRequest
func isExpired() -> Bool {
return expireAt < Date()
}
}
// dstMac // dstMac
private var coolingDown: [Data: (UInt32, Date)] = [:] private var pendingRequests: [Data: RequestContext] = [:]
private var pktId: UInt32 = 1
//
private var pendingRequests: [UInt32: RegisterRequest] = [:]
private var cleanupTask: Task<Void, Never>?
struct RegisterRequest { struct RegisterRequest {
let srcMac: Data let srcMac: Data
@ -24,38 +30,28 @@ actor SDLPuncherActor {
let networkId: UInt32 let networkId: UInt32
} }
//
func start() {
self.cleanupTask?.cancel()
self.cleanupTask = Task {
while !Task.isCancelled {
try? await Task.sleep(for: .seconds(1))
self.cleanExpiredCoolingDown()
}
}
}
func submitRegisterRequest(quicClient: SDLQUICClient?, request: RegisterRequest) { func submitRegisterRequest(quicClient: SDLQUICClient?, request: RegisterRequest) {
let dstMac = request.dstMac guard let quicClient else {
guard let quicClient, coolingDown[dstMac] == nil else {
return return
} }
coolingDown[dstMac] = (pktId, Date().addingTimeInterval(cooldownInterval)) //
let dstMac = request.dstMac
guard self.isRequestExpired(dstMac: dstMac) else {
return
}
pendingRequests[dstMac] = .init(expireAt: Date().addingTimeInterval(cooldownInterval), request: request)
// //
var queryInfo = SDLQueryInfo() var queryInfo = SDLQueryInfo()
queryInfo.dstMac = request.dstMac queryInfo.dstMac = request.dstMac
self.pendingRequests[pktId] = request
if let queryData = try? queryInfo.serializedData() { if let queryData = try? queryInfo.serializedData() {
quicClient.send(type: .queryInfo, data: queryData) quicClient.send(type: .queryInfo, data: queryData)
} }
} }
func handlePeerInfo(using udpHole: SDLUDPHole?, peerInfo: SDLPeerInfo) async { func handlePeerInfo(using udpHole: SDLUDPHole?, peerInfo: SDLPeerInfo) async {
guard let udpHole, let request = pendingRequests.removeValue(forKey: peerInfo.pktID), guard let udpHole, let requestContext = pendingRequests.removeValue(forKey: peerInfo.dstMac),
let remoteAddress = try? await peerInfo.v4Info.socketAddress() else { let remoteAddress = try? await peerInfo.v4Info.socketAddress() else {
return return
} }
@ -63,28 +59,21 @@ actor SDLPuncherActor {
SDLLogger.shared.log("[SDLContext] hole sock address: \(remoteAddress)", level: .debug) SDLLogger.shared.log("[SDLContext] hole sock address: \(remoteAddress)", level: .debug)
// register // register
var register = SDLRegister() var register = SDLRegister()
register.networkID = request.networkId register.networkID = requestContext.request.networkId
register.srcMac = request.srcMac register.srcMac = requestContext.request.srcMac
register.dstMac = request.dstMac register.dstMac = requestContext.request.dstMac
if let registerData = try? register.serializedData() { if let registerData = try? register.serializedData() {
udpHole.send(type: .register, data: registerData, remoteAddress: remoteAddress) udpHole.send(type: .register, data: registerData, remoteAddress: remoteAddress)
} }
} }
private func cleanExpiredCoolingDown() { //
let date = Date() func isRequestExpired(dstMac: Data) -> Bool {
for (key, (pktId, expireAt)) in coolingDown { if let context = pendingRequests[dstMac] {
if expireAt < date { return context.isExpired()
self.coolingDown.removeValue(forKey: key)
self.pendingRequests.removeValue(forKey: pktId)
}
} }
} return true
deinit {
self.cleanupTask?.cancel()
self.cleanupTask = nil
} }
} }