Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jcustenborder/connect-utils

Utility project for working with Kafka Connect.
https://github.com/jcustenborder/connect-utils

conversion kafka kafka-connect parsing schema

Last synced: about 7 hours ago
JSON representation

Utility project for working with Kafka Connect.

Awesome Lists containing this project

README

        

# Overview
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.github.jcustenborder.kafka.connect/connect-utils/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.github.jcustenborder.kafka.connect/connect-utils)

The purpose of this library is to aid with conversions from strings to the proper Kafka Connect data types. Hopefully this library can be usedful in reducing the amount of mind numbing string parsing code.

# Type Parsing

This section of code will help with conversions from strings to the proper Kafka Connect data types. Hopefully this library can be useful in reducing the amount of mind numbing string parsing code used
transform Strings to Integers. The current code supports nullable schemas. An exception will be thrown if a null is passed with a schema that is not optional.

## Convert to a schema type

```
Parser parser = new Parser();
Object value = parser.parseString(Schema.BOOLEAN_SCHEMA, "true");
```

```
Parser parser = new Parser();
Object value = parser.parseJson(Schema.BOOLEAN_SCHEMA, objectMapper.valueToTree(true));
```

## Nulls are supported too

```
Parser parser = new Parser();
Object value = parser.parseString(Schema.OPTIONAL_BOOLEAN_SCHEMA, null);
```

```
Parser parser = new Parser();
Object value = parser.parseJson(Schema.OPTIONAL_BOOLEAN_SCHEMA, null);
```

## Schemas without optional set do not support nulls

If you pass in a null to a schema that is not optional, you're going to have a bad time.

```
Parser parser = new Parser();
Object value = parser.parseString(Schema.BOOLEAN_SCHEMA, null);
```

```
Parser parser = new Parser();
Object value = parser.parseJson(Schema.BOOLEAN_SCHEMA, null);
```

## Register your own type converter or an alternate date format

```
Parser parser = new Parser();
parser.registerTypeParser(Timestamp.SCHEMA, new DateTypeConverter(TimeZone.getTimeZone("UTC"), new SimpleDateFormat("yyyy-MM-dd' 'HH:mm:ss")));
```

# Templating of Kafka Connect types.

There are several cases where you will want to route data to a different topic based on a field in your data.
[StructTemplate](src/main/java/com/github/jcustenborder/kafka/connect/utils/template/StructTemplate.java) is available to
assist you with this. It uses [FreeMarker](http://freemarker.org/) under the covers to allow you to apply templates to Connect Stucts. For example:

```java
// Setup the template once, maybe during start()
StructTemplate template = new StructTemplate();
template.addTemplate("test", "${stringField}");

//Apply the template.
Schema schema = SchemaBuilder.struct()
.name("TestStruct")
.field("stringField", Schema.STRING_SCHEMA)
.field("nullStringField", Schema.OPTIONAL_STRING_SCHEMA)
.build();

Struct struct = new Struct(schema);
struct.put("stringField", "TestValue");
String actual = this.structTemplate.execute("test", this.struct);

//actual == "TestValue"
```

You can combine static strings with variables to do something like `database.${stringField}` which would yield `database.TestValue`
using the example above.