本文整理匯總了Java中org.apache.kafka.connect.data.ConnectSchema類的典型用法代碼示例。如果您正苦於以下問題:Java ConnectSchema類的具體用法?Java ConnectSchema怎麽用?Java ConnectSchema使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ConnectSchema類屬於org.apache.kafka.connect.data包,在下文中一共展示了ConnectSchema類的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: apply
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
@Override
public R apply(R record) {
final Schema schema = operatingSchema(record);
requireSchema(schema, "updating schema metadata");
final boolean isArray = schema.type() == Schema.Type.ARRAY;
final boolean isMap = schema.type() == Schema.Type.MAP;
final Schema updatedSchema = new ConnectSchema(
schema.type(),
schema.isOptional(),
schema.defaultValue(),
schemaName != null ? schemaName : schema.name(),
schemaVersion != null ? schemaVersion : schema.version(),
schema.doc(),
schema.parameters(),
schema.fields(),
isMap ? schema.keySchema() : null,
isMap || isArray ? schema.valueSchema() : null
);
return newRecord(record, updatedSchema);
}
示例2: validateFormat
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
public static <K, V> void validateFormat(Map<K, V> offsetData) {
// Both keys and values for offsets may be null. For values, this is a useful way to delete offsets or indicate
// that there's not usable concept of offsets in your source system.
if (offsetData == null)
return;
for (Map.Entry<K, V> entry : offsetData.entrySet()) {
if (!(entry.getKey() instanceof String))
throw new DataException("Offsets may only use String keys");
Object value = entry.getValue();
if (value == null)
continue;
Schema.Type schemaType = ConnectSchema.schemaType(value.getClass());
if (schemaType == null)
throw new DataException("Offsets may only contain primitive types as values, but field " + entry.getKey() + " contains " + value.getClass());
if (!schemaType.isPrimitive())
throw new DataException("Offsets may only contain primitive types as values, but field " + entry.getKey() + " contains " + schemaType);
}
}
示例3: castValueToType
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
private static Object castValueToType(Object value, Schema.Type targetType) {
try {
if (value == null) return null;
Schema.Type inferredType = ConnectSchema.schemaType(value.getClass());
if (inferredType == null) {
throw new DataException("Cast transformation was passed a value of type " + value.getClass()
+ " which is not supported by Connect's data API");
}
// Ensure the type we are trying to cast from is supported
validCastType(inferredType, FieldType.INPUT);
switch (targetType) {
case INT8:
return castToInt8(value);
case INT16:
return castToInt16(value);
case INT32:
return castToInt32(value);
case INT64:
return castToInt64(value);
case FLOAT32:
return castToFloat32(value);
case FLOAT64:
return castToFloat64(value);
case BOOLEAN:
return castToBoolean(value);
case STRING:
return castToString(value);
default:
throw new DataException(targetType.toString() + " is not supported in the Cast transformation.");
}
} catch (NumberFormatException e) {
throw new DataException("Value (" + value.toString() + ") was out of range for requested data type", e);
}
}
示例4: applySchemaless
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
private void applySchemaless(Map<String, Object> originalRecord, String fieldNamePrefix, Map<String, Object> newRecord) {
for (Map.Entry<String, Object> entry : originalRecord.entrySet()) {
final String fieldName = fieldName(fieldNamePrefix, entry.getKey());
Object value = entry.getValue();
if (value == null) {
newRecord.put(fieldName(fieldNamePrefix, entry.getKey()), null);
return;
}
Schema.Type inferredType = ConnectSchema.schemaType(value.getClass());
if (inferredType == null) {
throw new DataException("Flatten transformation was passed a value of type " + value.getClass()
+ " which is not supported by Connect's data API");
}
switch (inferredType) {
case INT8:
case INT16:
case INT32:
case INT64:
case FLOAT32:
case FLOAT64:
case BOOLEAN:
case STRING:
case BYTES:
newRecord.put(fieldName(fieldNamePrefix, entry.getKey()), entry.getValue());
break;
case MAP:
final Map<String, Object> fieldValue = requireMap(entry.getValue(), PURPOSE);
applySchemaless(fieldValue, fieldName, newRecord);
break;
default:
throw new DataException("Flatten transformation does not support " + entry.getValue().getClass()
+ " for record without schemas (for field " + fieldName + ").");
}
}
}
示例5: convertKey
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
private String convertKey(Schema keySchema, Object key) {
if (key == null) {
throw new ConnectException("Key is used as document id and can not be null.");
}
final Schema.Type schemaType;
if (keySchema == null) {
schemaType = ConnectSchema.schemaType(key.getClass());
if (schemaType == null) {
throw new DataException(
"Java class "
+ key.getClass()
+ " does not have corresponding schema type."
);
}
} else {
schemaType = keySchema.type();
}
switch (schemaType) {
case INT8:
case INT16:
case INT32:
case INT64:
case STRING:
return String.valueOf(key);
default:
throw new DataException(schemaType.name() + " is not supported as the document id.");
}
}
示例6: testEnforceFieldTypeTaking1And1WithNull
import org.apache.kafka.connect.data.ConnectSchema; //導入依賴的package包/類
@Test
public void testEnforceFieldTypeTaking1And1WithNull() {
SchemaBuilder schemaBuilder = SchemaBuilder.struct();
GenericRowValueTypeEnforcer genericRowValueTypeEnforcer = new GenericRowValueTypeEnforcer(schemaBuilder);
Schema.Type schema_Type = Schema.Type.BOOLEAN;
ConnectSchema connectSchema = new ConnectSchema(schema_Type);
try {
genericRowValueTypeEnforcer.enforceFieldType(connectSchema, null);
fail("Expecting exception: KsqlException");
} catch(KsqlException e) {
assertEquals(GenericRowValueTypeEnforcer.class.getName(), e.getStackTrace()[0].getClassName());
}
}