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

datahub.client.Emitter Maven / Gradle / Ivy

package datahub.client;

import com.linkedin.mxe.MetadataChangeProposal;
import datahub.event.MetadataChangeProposalWrapper;
import datahub.event.UpsertAspectRequest;
import java.io.Closeable;
import java.io.IOException;
import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import javax.annotation.Nonnull;
import javax.annotation.concurrent.ThreadSafe;

/**
 * An interface implemented by all metadata emitters to DataHub. Typical usage: 1. Construct the
 * emitter using the native constructor or builder for the Emitter. 2. Call `emitter.emit(mcpw,
 * callback)` for each event you want to send 3. Wait for all events to be sent by inspecting the
 * futures returned by each call or using callbacks 4. Call `emitter.close()` to finalize.
 */
@ThreadSafe
public interface Emitter extends Closeable {

  /**
   * Asynchronously emit a {@link MetadataChangeProposalWrapper} event.
   *
   * @param mcpw
   * @param callback if not null, is called from the IO thread. Should be a quick operation.
   * @return a {@link Future} for callers to inspect the result of the operation or block until one
   *     is available
   * @throws IOException
   */
  Future emit(@Nonnull MetadataChangeProposalWrapper mcpw, Callback callback)
      throws IOException;

  /**
   * Asynchronously emit a {@link MetadataChangeProposalWrapper} event.
   *
   * @param mcpw
   * @return a {@link Future} for callers to inspect the result of the operation or block until one
   *     is available
   * @throws IOException
   */
  default Future emit(@Nonnull MetadataChangeProposalWrapper mcpw)
      throws IOException {
    return emit(mcpw, null);
  }

  /**
   * Asynchronously emit a {@link MetadataChangeProposal} event. Prefer using the sibling method
   * that accepts a {@link MetadataChangeProposalWrapper} event as those are friendlier to
   * construct.
   *
   * @param mcp
   * @param callback if not null, is called from the IO thread. Should be a quick operation.
   * @return a {@link Future} for callers to inspect the result of the operation or block until one
   *     is available
   * @throws IOException
   */
  Future emit(@Nonnull MetadataChangeProposal mcp, Callback callback)
      throws IOException;

  /**
   * Asynchronously emit a {@link MetadataChangeProposal} event. Prefer using the sibling method
   * that accepts a {@link MetadataChangeProposalWrapper} event as those are friendlier to
   * construct.
   *
   * @param mcp
   * @return a {@link Future} for callers to inspect the result of the operation or block until one
   *     is available
   * @throws IOException
   */
  default Future emit(@Nonnull MetadataChangeProposal mcp)
      throws IOException {
    return emit(mcp, null);
  }

  /**
   * Test that the emitter can establish a valid connection to the DataHub platform
   *
   * @return true if a valid connection can be established, false or throws one of the exceptions
   *     otherwise
   * @throws IOException
   * @throws ExecutionException
   * @throws InterruptedException
   */
  boolean testConnection() throws IOException, ExecutionException, InterruptedException;

  /**
   * Asynchronously emit a {@link UpsertAspectRequest}.
   *
   * @param request request with with metadata aspect to upsert into DataHub
   * @return a {@link Future} for callers to inspect the result of the operation or block until one
   *     is available
   * @throws IOException
   */
  Future emit(List request, Callback callback)
      throws IOException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy