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

com.databricks.jdbc.dbclient.impl.http.RequestSanitizer Maven / Gradle / Ivy

package com.databricks.jdbc.dbclient.impl.http;

import java.net.URI;
import java.net.URISyntaxException;
import java.util.List;
import org.apache.http.client.methods.HttpUriRequest;

public class RequestSanitizer {
  private static final List SENSITIVE_QUERY_PARAMS =
      List.of("X-Amz-Security-Token", "X-Amz-Signature", "X-Amz-Credential");

  public static String sanitizeRequest(HttpUriRequest request) {
    try {
      URI uri = new URI(request.getURI().toString());
      String sanitizedQuery = sanitizeQuery(uri.getRawQuery());
      URI sanitizedUri =
          new URI(
              uri.getScheme(),
              uri.getAuthority(),
              uri.getPath(),
              sanitizedQuery,
              uri.getFragment());
      return sanitizedUri.toString();
    } catch (URISyntaxException e) {
      return "Error sanitizing URI: " + e.getMessage();
    }
  }

  private static String sanitizeQuery(String query) {
    if (query == null) {
      return null;
    }

    StringBuilder sanitizedQuery = new StringBuilder();
    String[] pairs = query.split("&");
    for (String pair : pairs) {
      int idx = pair.indexOf("=");
      String key = (idx > 0) ? pair.substring(0, idx) : pair;
      if (SENSITIVE_QUERY_PARAMS.contains(key)) {
        sanitizedQuery.append(key).append("=REDACTED");
      } else {
        sanitizedQuery.append(pair);
      }
      sanitizedQuery.append("&");
    }

    // Remove the trailing '&' if present
    if (sanitizedQuery.length() > 0) {
      sanitizedQuery.setLength(sanitizedQuery.length() - 1);
    }

    return sanitizedQuery.toString();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy