mirror of
https://git.robbyzambito.me/zaprus
synced 2025-12-20 16:24:50 +00:00
Last handshake packet uses non 8888 port
This commit is contained in:
@@ -14,7 +14,7 @@ pub fn deinit() void {
|
|||||||
network.deinit();
|
network.deinit();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn broadcastSaprusMessage(msg: SaprusMessage, allocator: Allocator) !void {
|
fn broadcastSaprusMessage(msg: SaprusMessage, udp_port: u16, allocator: Allocator) !void {
|
||||||
const msg_bytes = try msg.toBytes(allocator);
|
const msg_bytes = try msg.toBytes(allocator);
|
||||||
defer allocator.free(msg_bytes);
|
defer allocator.free(msg_bytes);
|
||||||
|
|
||||||
@@ -31,7 +31,7 @@ fn broadcastSaprusMessage(msg: SaprusMessage, allocator: Allocator) !void {
|
|||||||
|
|
||||||
const dest_addr = network.EndPoint{
|
const dest_addr = network.EndPoint{
|
||||||
.address = network.Address{ .ipv4 = network.Address.IPv4.broadcast },
|
.address = network.Address{ .ipv4 = network.Address.IPv4.broadcast },
|
||||||
.port = 8888,
|
.port = udp_port,
|
||||||
};
|
};
|
||||||
|
|
||||||
try sock.bind(bind_addr);
|
try sock.bind(bind_addr);
|
||||||
@@ -47,15 +47,20 @@ pub fn sendRelay(payload: []const u8, allocator: Allocator) !void {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
try broadcastSaprusMessage(msg, allocator);
|
try broadcastSaprusMessage(msg, 8888, allocator);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn randomPort() u16 {
|
||||||
|
var p: u16 = 0;
|
||||||
|
if (rand) |r| {
|
||||||
|
p = r.intRangeAtMost(u16, 1024, 65000);
|
||||||
|
} else unreachable;
|
||||||
|
|
||||||
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn sendInitialConnection(payload: []const u8, initial_port: u16, allocator: Allocator) !SaprusMessage {
|
pub fn sendInitialConnection(payload: []const u8, initial_port: u16, allocator: Allocator) !SaprusMessage {
|
||||||
var dest_port: u16 = 0;
|
const dest_port = randomPort();
|
||||||
if (rand) |r| {
|
|
||||||
dest_port = r.intRangeAtMost(u16, 1024, 65000);
|
|
||||||
} else unreachable;
|
|
||||||
|
|
||||||
const msg = SaprusMessage{
|
const msg = SaprusMessage{
|
||||||
.connection = .{
|
.connection = .{
|
||||||
.header = .{
|
.header = .{
|
||||||
@@ -69,7 +74,7 @@ pub fn sendInitialConnection(payload: []const u8, initial_port: u16, allocator:
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
try broadcastSaprusMessage(msg, allocator);
|
try broadcastSaprusMessage(msg, 8888, allocator);
|
||||||
|
|
||||||
return msg;
|
return msg;
|
||||||
}
|
}
|
||||||
@@ -90,7 +95,8 @@ fn awaitSentinelConnectionResponse(
|
|||||||
.port = 8888,
|
.port = 8888,
|
||||||
};
|
};
|
||||||
|
|
||||||
try sock.setReadTimeout(1000);
|
// timeout 1s
|
||||||
|
try sock.setReadTimeout(1_000_000);
|
||||||
try sock.bind(bind_addr);
|
try sock.bind(bind_addr);
|
||||||
|
|
||||||
// Signal that the socket is ready to receive data.
|
// Signal that the socket is ready to receive data.
|
||||||
@@ -128,7 +134,7 @@ pub fn connect(payload: []const u8, allocator: Allocator) !?SaprusMessage {
|
|||||||
);
|
);
|
||||||
|
|
||||||
// Block until the socket is set up.
|
// Block until the socket is set up.
|
||||||
try setting_up_socket.timedWait(500 * 1000 * 1000 * 1000);
|
try setting_up_socket.timedWait(5 * 1000 * 1000 * 1000 * 1000);
|
||||||
|
|
||||||
const msg = try sendInitialConnection(payload, initial_port, allocator);
|
const msg = try sendInitialConnection(payload, initial_port, allocator);
|
||||||
|
|
||||||
@@ -136,7 +142,7 @@ pub fn connect(payload: []const u8, allocator: Allocator) !?SaprusMessage {
|
|||||||
response_thread.join();
|
response_thread.join();
|
||||||
|
|
||||||
// Complete handshake after awaiting response
|
// Complete handshake after awaiting response
|
||||||
try broadcastSaprusMessage(msg, allocator);
|
try broadcastSaprusMessage(msg, randomPort(), allocator);
|
||||||
|
|
||||||
return initial_conn_res;
|
return initial_conn_res;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user