From 241c262049eb6f715ed6d7a2c11d78dc087e2df5 Mon Sep 17 00:00:00 2001 From: Alemiz Date: Wed, 24 Jul 2024 12:16:15 +0200 Subject: [PATCH] Fix NPE if metrics are not set --- .../codec/raknet/common/RakSessionCodec.java | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/transport-raknet/src/main/java/org/cloudburstmc/netty/handler/codec/raknet/common/RakSessionCodec.java b/transport-raknet/src/main/java/org/cloudburstmc/netty/handler/codec/raknet/common/RakSessionCodec.java index 03411f9..9ee631b 100644 --- a/transport-raknet/src/main/java/org/cloudburstmc/netty/handler/codec/raknet/common/RakSessionCodec.java +++ b/transport-raknet/src/main/java/org/cloudburstmc/netty/handler/codec/raknet/common/RakSessionCodec.java @@ -240,7 +240,10 @@ private void send(ChannelHandlerContext ctx, RakMessage message) { throw new IllegalArgumentException(); } - getMetrics().encapsulatedOut(1); + RakChannelMetrics metrics = this.getMetrics(); + if (metrics != null) { + metrics.encapsulatedOut(1); + } EncapsulatedPacket[] packets = this.createEncapsulated(message); if (message.priority() == RakPriority.IMMEDIATE) { this.sendImmediate(ctx, packets); @@ -317,14 +320,18 @@ private void handleDatagram(ChannelHandlerContext ctx, RakDatagramPacket packet) // Not reassembled continue; } - getMetrics().encapsulatedIn(1); + if (metrics != null) { + metrics.encapsulatedIn(1); + } try { this.checkForOrdered(ctx, reassembled); } finally { reassembled.release(); } } else { - getMetrics().encapsulatedIn(1); + if (metrics != null) { + metrics.encapsulatedIn(1); + } this.checkForOrdered(ctx, encapsulated); } }