All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.networknt.mesh.kafka.handler.ConsumersGroupInstancesInstanceSubscriptionsDeleteHandler Maven / Gradle / Ivy

The newest version!
package com.networknt.mesh.kafka.handler;

import com.networknt.exception.FrameworkException;
import com.networknt.handler.LightHttpHandler;
import com.networknt.mesh.kafka.ActiveConsumerStartupHook;
import io.undertow.server.HttpServerExchange;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
For more information on how to write business handlers, please check the link below.
https://doc.networknt.com/development/business-handler/rest/
*/
public class ConsumersGroupInstancesInstanceSubscriptionsDeleteHandler implements LightHttpHandler {
    private static final Logger logger = LoggerFactory.getLogger(ConsumersGroupInstancesInstanceSubscriptionsDeleteHandler.class);

    public ConsumersGroupInstancesInstanceSubscriptionsDeleteHandler () {
        if(logger.isDebugEnabled()) logger.debug("ConsumersGroupInstancesInstanceSubscriptionsDeleteHandler constructed!");
    }

    @Override
    public void handleRequest(HttpServerExchange exchange) throws Exception {
        String group = exchange.getPathParameters().get("group").getFirst();
        String instance = exchange.getPathParameters().get("instance").getFirst();
        if(logger.isDebugEnabled()) logger.debug("group = {} instance = {}", group, instance);
        try {
            ActiveConsumerStartupHook.kafkaConsumerManager.unsubscribe(group, instance);
            exchange.setStatusCode(204);
            exchange.endExchange();
        } catch (FrameworkException e) {
            if(logger.isDebugEnabled()) logger.debug("FrameworkException:", e);
            setExchangeStatus(exchange, e.getStatus());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy