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

com.databricks.sdk.core.GrpcTranscodingQueryParamsSerializer Maven / Gradle / Ivy

There is a newer version: 0.38.0
Show newest version
package com.databricks.sdk.core;

import com.databricks.sdk.support.QueryParam;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.lang.reflect.Field;
import java.util.*;

/**
 * Serializes an object into a list of query parameter entries compatible with gRPC-transcoding.
 *
 * 

The Databricks REST API uses gRPC transcoding to expose gRPC services as REST APIs. This * serializer is used to serialize objects into a map of query parameter entries that can be used to * invoke a gRPC service via REST. * *

See the * documentation for gRPC transcoding for more details. */ public class GrpcTranscodingQueryParamsSerializer { public static class QueryParamPair { private final String key; private final String value; public QueryParamPair(String key, String value) { this.key = key; this.value = value; } public String getKey() { return key; } public String getValue() { return value; } } /** * Serializes an object into a map of query parameter values compatible with gRPC-transcoding. * *

This method respects the QueryParam and JsonProperty annotations on the object's fields when * serializing the field name. If both annotations are present, the value of the QueryParam * annotation is used. * *

The returned object does not contain any top-level fields that are not annotated with * QueryParam. All nested fields are included, even if they are not annotated with QueryParam. * * @param o The object to serialize. * @return A list of query parameter entries compatible with gRPC-transcoding. */ public static List serialize(Object o) { Map flattened = flattenObject(o, true); List result = new ArrayList<>(); for (Map.Entry entry : flattened.entrySet()) { String key = entry.getKey(); Object value = entry.getValue(); if (value instanceof Collection) { for (Object v : (Collection) value) { result.add(new QueryParamPair(key, v.toString())); } } else { result.add(new QueryParamPair(key, value.toString())); } } return result; } private static final List> primitiveTypes = Arrays.asList( boolean.class, Boolean.class, byte.class, Byte.class, char.class, Character.class, short.class, Short.class, int.class, Integer.class, long.class, Long.class, float.class, Float.class, double.class, Double.class, String.class); private static String getFieldName(Field f) { QueryParam queryParam = f.getAnnotation(QueryParam.class); JsonProperty jsonProperty = f.getAnnotation(JsonProperty.class); if (queryParam != null) { return queryParam.value(); } else if (jsonProperty != null) { return jsonProperty.value(); } else { return f.getName(); } } private static Map flattenObject(Object o, Boolean onlyAnnotatedFields) { // LinkedHashMap ensures consistent ordering of fields. Map result = new LinkedHashMap<>(); Field[] fields = o.getClass().getDeclaredFields(); for (Field f : fields) { if (onlyAnnotatedFields && f.getAnnotation(QueryParam.class) == null) { continue; } f.setAccessible(true); try { String name = getFieldName(f); Object value = f.get(o); if (value == null) { continue; } // check if object is a primitive type, a collection of some kind, or an enum Class type = f.getType(); if (primitiveTypes.contains(type) || Iterable.class.isAssignableFrom(type) || type.isEnum()) { result.put(name, value); } else { // recursively flatten the object Map flattened = flattenObject(value, false); for (Map.Entry entry : flattened.entrySet()) { result.put(name + "." + entry.getKey(), entry.getValue()); } } } catch (IllegalAccessException e) { throw new RuntimeException(e); } finally { f.setAccessible(false); } } return result; } }