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

com.databricks.sdk.core.retry.RequestBasedRetryStrategyPicker Maven / Gradle / Ivy

package com.databricks.sdk.core.retry;

import com.databricks.sdk.core.DatabricksConfig;
import com.databricks.sdk.core.http.Request;
import java.util.AbstractMap;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.regex.Pattern;
import java.util.stream.Collectors;

/**
 * A RetryStrategyPicker that selects a retry strategy based on whether the request is idempotent or
 * not.
 */
public class RequestBasedRetryStrategyPicker implements RetryStrategyPicker {
  private static final List IDEMPOTENT_REQUESTS =
      Arrays.asList(
          // Create a new session v1.0
          new Request("POST", "/api/2.0/sql/statements/sessions/"),
          // Create a new session v2.0
          new Request("POST", "/api/2.0/sql/sessions/"),
          // Delete an existing session v1.0
          new Request("DELETE", "/api/2.0/sql/statements/sessions/.*"),
          // Delete an existing session v2.0
          new Request("DELETE", "/api/2.0/sql/sessions/.*"),
          // Get status of a statement
          new Request("GET", "/api/2.0/sql/statements/.*"),
          // Close a statement
          new Request("DELETE", "/api/2.0/sql/statements/.*"),
          // Fetch a chunk of a statement result
          new Request("GET", "/api/2.0/sql/statements/.*/result/chunks/.*"));

  private final List> idempotentRequestsPattern;
  private static final NonIdempotentRequestRetryStrategy NON_IDEMPOTENT_RETRY_STRATEGY =
      new NonIdempotentRequestRetryStrategy();
  private static final IdempotentRequestRetryStrategy IDEMPOTENT_RETRY_STRATEGY =
      new IdempotentRequestRetryStrategy();

  public RequestBasedRetryStrategyPicker(DatabricksConfig config) {
    this.idempotentRequestsPattern =
        IDEMPOTENT_REQUESTS.stream()
            .map(
                request ->
                    new AbstractMap.SimpleEntry<>(
                        request.getMethod(),
                        Pattern.compile(
                            config.getHost() + request.getUrl(), Pattern.CASE_INSENSITIVE)))
            .collect(Collectors.toList());
  }

  /**
   * This function gets the retry strategy for a given request based on whether the request is
   * idempotent or not.
   *
   * @param request to get the retry strategy for
   * @return the retry strategy for the given request
   */
  @Override
  public RetryStrategy getRetryStrategy(Request request) {
    if (isIdempotentRequest(request)) {
      return IDEMPOTENT_RETRY_STRATEGY;
    } else {
      return NON_IDEMPOTENT_RETRY_STRATEGY;
    }
  }

  /**
   * This function checks if a given request is idempotent.
   *
   * @param request to check if it is idempotent
   * @return true if the request is idempotent, false otherwise
   */
  private boolean isIdempotentRequest(Request request) {
    for (Map.Entry idempotentRequest : idempotentRequestsPattern) {
      if (idempotentRequest.getKey().equals(request.getMethod())
          && idempotentRequest.getValue().matcher(request.getUrl()).find()) {
        return true;
      }
    }
    return false;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy