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