Interface PubrelInboundInterceptor
- All Superinterfaces:
Interceptor
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
@FunctionalInterface public interface PubrelInboundInterceptor extends Interceptor
Interface for the inbound PUBREL interception.
Interceptors are always called by the same Thread for all messages from the same client.
If the same instance is shared between multiple clients it can be called in different Threads and must therefore be thread-safe.
When the method onInboundPubrel(PubrelInboundInput, PubrelInboundOutput) throws an exception or a call to
PubrelInboundOutput.async(Duration) times out with TimeoutFallback.FAILURE, HiveMQ will ignore this
interceptor and will:
- Log the exception
- Revert the changes to the
ModifiablePubrelPacketmade by the interceptor - Call the next
PubrelInboundInterceptoror send the PUBREL to the server if no interceptor is left
- Since:
- 4.3.0, CE 2020.1
-
Method Summary
Modifier and Type Method Description voidonInboundPubrel(@NotNull PubrelInboundInput pubrelInboundInput, @NotNull PubrelInboundOutput pubrelInboundOutput)When aPubrelInboundInterceptoris set through any extension, this method gets called for every inbound PUBREL packet from any MQTT client.
-
Method Details
-
onInboundPubrel
void onInboundPubrel(@NotNull PubrelInboundInput pubrelInboundInput, @NotNull PubrelInboundOutput pubrelInboundOutput)When aPubrelInboundInterceptoris set through any extension, this method gets called for every inbound PUBREL packet from any MQTT client.When the extension is enabled after HiveMQ is already running, this method will also be called for future PUBRELs of clients that are already connected.
- Parameters:
pubrelInboundInput- ThePubrelInboundInputparameter.pubrelInboundOutput- ThePubrelInboundOutputparameter.- Since:
- 4.3.0, CE 2020.1
-