Skip to content

Latest commit

 

History

History
83 lines (59 loc) · 2.61 KB

README.md

File metadata and controls

83 lines (59 loc) · 2.61 KB

kafka-ldap-integration

Enhancing kafka 2.x with

  • customized SimpleLDAPAuthentication using LDAPS simple bind for authentication
  • customized SimpleACLAuthorizer using LDAPS compare-matched for group membership verification

Thus, moving authentication from user and passwords in JAAS context file on kafka brokers to LDAP server

By defining Read/Write allowance with LDAP groups, authorization is moved from Zookeeper Access Control Lists to group membership verification.

Binding and group membership information is cached (limited lifetime after write), giving minor performance penalty and reduced LDAPS traffic.

Tools

  • Kotlin
  • Gradle build tool
  • Spek test framework

Components

  1. Unboundid LDAP SDK for LDAPS interaction
  2. Caffeine Cache
  3. YAML Configuration for LDAP baseDN for users, groups and more. See src/test/resources/ldapconfig.yaml for details

N.B. that the directory hosting yaml configuration file must be in CLASSPATH.

Kafka configuration examples

JAAS context file on Kafka broker use the standard class for plain login module during authentication

KafkaServer{
  org.apache.kafka.common.security.plain.PlainLoginModule required
    username="x"
    password="y";
};

Example of Kafka server.properties for using the customized classes for authentication and authorization. The example focus on minimum configuration only (sasl plaintext). A production environment utilize plain with TLS.

...
listeners=SASL_PLAINTEXT://localhost:9092
security.inter.broker.protocol=SASL_PLAINTEXT
sasl.mechanism.inter.broker.protocol=PLAIN
sasl.enabled.mechanisms=PLAIN 
...
listener.name.sasl_plaintext.plain.sasl.server.callback.handler.class=com.instaclustr.kafka.ldap.authentication.SimpleLDAPAuthentication
authorizer.class.name=com.instaclustr.kafka.ldap.authorization.SimpleLDAPAuthorizer
...

Testing

Use of Unboundid in-memory LDAP server for all test cases.

Tested on Kafka version 2.x

See Apache Kafka in order to test locally.

Build

./gradlew clean build
./gradlew shadowJar

The result is kafka-ldap-integration-2.4_<version>.jar hosting authentication and authorization classes.

N.B. that the directory hosting the given JAR file must be in CLASSPATH.

Contact us

Code/project related questions can be sent to

Credit to original authors

Maintainers of the GitHub project kafka-plain-saslserver-2-ad: