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

org.apache.kafka.streams.TTDUtils Maven / Gradle / Ivy

There is a newer version: 0.37.0
Show newest version
/*
 * Copyright 2024 Responsive Computing, Inc.
 *
 * This source code is licensed under the Responsive Business Source License Agreement v1.0
 * available at:
 *
 * https://www.responsive.dev/legal/responsive-bsl-10
 *
 * This software requires a valid Commercial License Key for production use. Trial and commercial
 * licenses can be obtained at https://www.responsive.dev
 */

package org.apache.kafka.streams;

import static org.apache.kafka.streams.processor.internals.ProcessorStateManager.storeChangelogTopic;

import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;

/**
 * A utility class that lives in the o.a.k.streams package so we can access
 * internal topology metadata such as topics
 */
public final class TTDUtils {

  /**
   * @param appId the application id
   * @param stores the list of state store names for which to derive changelog topic names
   * @return the set of expected changelog topics computed for the provided state store names
   */
  public static Set deriveChangelogTopic(final String appId, final List stores) {
    return stores
        .stream()
        .map(s -> storeChangelogTopic(appId, s, null))
        .collect(Collectors.toSet());
  }

  /**
   * @param topology a compiled topology (must have already been initialized by the TTD/app)
   * @return the set of actual changelog topics belonging to all state stores in this topology
   */
  public static Set extractChangelogTopics(final Topology topology) {
    return topology.internalTopologyBuilder
        .subtopologyToTopicsInfo().values()
        .stream()
        .flatMap(t -> t.stateChangelogTopics.keySet().stream())
        .collect(Collectors.toSet());
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy