This commit is contained in:
anlicheng 2026-03-27 13:35:02 +08:00
parent 5358d9a2b7
commit 2e311cbf9e

View File

@ -41,7 +41,7 @@ actor SDLPuncherActor {
return
}
pendingRequests[dstMac] = .init(expireAt: Date().addingTimeInterval(cooldownInterval), request: request)
self.pendingRequests[dstMac] = .init(expireAt: Date().addingTimeInterval(cooldownInterval), request: request)
//
var queryInfo = SDLQueryInfo()
queryInfo.dstMac = request.dstMac
@ -51,20 +51,27 @@ actor SDLPuncherActor {
}
func handlePeerInfo(using udpHole: SDLUDPHole?, peerInfo: SDLPeerInfo) async {
guard let udpHole, let requestContext = pendingRequests.removeValue(forKey: peerInfo.dstMac),
let remoteAddress = try? await peerInfo.v4Info.socketAddress() else {
// ;
guard let requestContext = pendingRequests.removeValue(forKey: peerInfo.dstMac) else {
return
}
SDLLogger.shared.log("[SDLContext] hole sock address: \(remoteAddress)", level: .debug)
// register
var register = SDLRegister()
register.networkID = requestContext.request.networkId
register.srcMac = requestContext.request.srcMac
register.dstMac = requestContext.request.dstMac
//
guard let udpHole, peerInfo.hasV4Info else {
return
}
if let registerData = try? register.serializedData() {
udpHole.send(type: .register, data: registerData, remoteAddress: remoteAddress)
if let remoteAddress = try? await peerInfo.v4Info.socketAddress() {
SDLLogger.shared.log("[SDLContext] hole sock address: \(remoteAddress)", level: .debug)
// register
var register = SDLRegister()
register.networkID = requestContext.request.networkId
register.srcMac = requestContext.request.srcMac
register.dstMac = requestContext.request.dstMac
if let registerData = try? register.serializedData() {
udpHole.send(type: .register, data: registerData, remoteAddress: remoteAddress)
}
}
}