From f5ff30d6c88d7241076ebff5324a0cbfa6c92248 Mon Sep 17 00:00:00 2001 From: x19 <100000306+0xNineteen@users.noreply.github.com> Date: Wed, 15 Jan 2025 13:35:12 -0500 Subject: [PATCH] address comments --- src/gossip/prune.zig | 38 ++++++++++++++++++++++++-------------- 1 file changed, 24 insertions(+), 14 deletions(-) diff --git a/src/gossip/prune.zig b/src/gossip/prune.zig index 6d79a16a2..316a786f8 100644 --- a/src/gossip/prune.zig +++ b/src/gossip/prune.zig @@ -75,28 +75,34 @@ pub const PruneData = struct { } pub fn signWithoutPrefix(self: *PruneData, keypair: *const KeyPair) !void { - var slice: [PACKET_DATA_SIZE]u8 = undefined; const signable_data = PruneSignableData{ .pubkey = self.pubkey, .prunes = self.prunes, .destination = self.destination, .wallclock = self.wallclock, }; - const out = try bincode.writeToSlice(&slice, signable_data, bincode.Params{}); - var signature = try keypair.sign(out, null); + + // serialize + var d: [PACKET_DATA_SIZE]u8 = undefined; + const data = try bincode.writeToSlice(&d, signable_data, .{}); + // sign + var signature = try keypair.sign(data, null); self.signature.data = signature.toBytes(); } pub fn signWithPrefix(self: *PruneData, keypair: *const KeyPair) !void { - var slice: [PACKET_DATA_SIZE]u8 = undefined; const signable_data = PruneSignableDataWithPrefix{ .pubkey = self.pubkey, .prunes = self.prunes, .destination = self.destination, .wallclock = self.wallclock, }; - const out = try bincode.writeToSlice(&slice, signable_data, bincode.Params{}); - var signature = try keypair.sign(out, null); + + // serialize + var d: [PACKET_DATA_SIZE]u8 = undefined; + const data = try bincode.writeToSlice(&d, signable_data, .{}); + // sign + var signature = try keypair.sign(data, null); self.signature.data = signature.toBytes(); } @@ -108,31 +114,35 @@ pub const PruneData = struct { } pub fn verifyWithoutPrefix(self: *const PruneData) !void { - var slice: [PACKET_DATA_SIZE]u8 = undefined; const signable_data = PruneSignableData{ .pubkey = self.pubkey, .prunes = self.prunes, .destination = self.destination, .wallclock = self.wallclock, }; - const out = try bincode.writeToSlice(&slice, signable_data, bincode.Params{}); - if (!try self.signature.verify(self.pubkey, out)) { + + // serialize + var d: [PACKET_DATA_SIZE]u8 = undefined; + const data = try bincode.writeToSlice(&d, signable_data, .{}); + // verify + if (!try self.signature.verify(self.pubkey, data)) return error.InvalidSignature; - } } pub fn verifyWithPrefix(self: *const PruneData) !void { - var slice: [PACKET_DATA_SIZE]u8 = undefined; const signable_data = PruneSignableDataWithPrefix{ .pubkey = self.pubkey, .prunes = self.prunes, .destination = self.destination, .wallclock = self.wallclock, }; - const out = try bincode.writeToSlice(&slice, signable_data, bincode.Params{}); - if (!try self.signature.verify(self.pubkey, out)) { + + // serialize + var d: [PACKET_DATA_SIZE]u8 = undefined; + const data = try bincode.writeToSlice(&d, signable_data, .{}); + // verify + if (!try self.signature.verify(self.pubkey, data)) return error.InvalidSignature; - } } };