# franz
[data:image/s3,"s3://crabby-images/c63c8/c63c8840eac97b3c4a2271e24668126097d5d16f" alt="Package Version"](https://hex.pm/packages/franz)
[data:image/s3,"s3://crabby-images/7c557/7c557a32f08e49c79944cb17a8d1b101a5ccade0" alt="Hex Docs"](https://hexdocs.pm/franz/)
`franz` is a Gleam library for interacting with Kafka. It provides functionalities to produce and consume messages, handle topics, and manage configurations.
## Installation
Add `franz` to your Gleam project:
```sh
gleam add franz
```
## Usage
```gleam
import franz
import franz/group_subscriber
import franz/producer
pub fn main() {
// Here we create a Kafka client.
let endpoint = franz.Endpoint("localhost", 9092)
let assert Ok(client) =
franz.new([endpoint])
|> franz.with_config(franz.AutoStartProducers(True))
|> franz.start()
// Then we create a group subscriber that commits messages after processing them.
group_subscriber.new(
client: client,
group_id: "test_group",
topics: ["test_topic"],
message_type: message_type.Message,
callback: fn(message: franz.KafkaMessage, _nil) {
let assert franz.KafkaMessage(
offset,
key,
value,
timestamp_type,
timestamp,
[],
) = message
group_subscriber.commit(cb_state)
},
init_callback_state: Nil,
)
|> group_subscriber.start()
// Finally, we produce a message.
producer.produce_sync(
client: client,
topic: "test_topic",
partition: producer.Partition(0),
key: <<"key">>,
value: producer.Value(<<"value">>, []),
)
}
```