Sha256: 10a03f4b25f843972290ade9634e2c36a32d93f4863371a90f7c116b69e29566

Contents?: true

Size: 1.68 KB

Versions: 15

Compression:

Stored size: 1.68 KB

Contents

# frozen_string_literal: true

require 'kafka/sasl/plain'
require 'kafka/sasl/gssapi'
require 'kafka/sasl/scram'
require 'kafka/sasl/oauth'

module Kafka
  class SaslAuthenticator
    def initialize(logger:, sasl_gssapi_principal:, sasl_gssapi_keytab:,
                   sasl_plain_authzid:, sasl_plain_username:, sasl_plain_password:,
                   sasl_scram_username:, sasl_scram_password:, sasl_scram_mechanism:,
                   sasl_oauth_token_provider:)
      @logger = TaggedLogger.new(logger)

      @plain = Sasl::Plain.new(
        authzid: sasl_plain_authzid,
        username: sasl_plain_username,
        password: sasl_plain_password,
        logger: @logger,
      )

      @gssapi = Sasl::Gssapi.new(
        principal: sasl_gssapi_principal,
        keytab: sasl_gssapi_keytab,
        logger: @logger,
      )

      @scram = Sasl::Scram.new(
        username: sasl_scram_username,
        password: sasl_scram_password,
        mechanism: sasl_scram_mechanism,
        logger: @logger,
      )

      @oauth = Sasl::OAuth.new(
        token_provider: sasl_oauth_token_provider,
        logger: @logger,
      )

      @mechanism = [@gssapi, @plain, @scram, @oauth].find(&:configured?)
    end

    def enabled?
      !@mechanism.nil?
    end

    def authenticate!(connection)
      return unless enabled?

      ident = @mechanism.ident
      response = connection.send_request(Kafka::Protocol::SaslHandshakeRequest.new(ident))

      unless response.error_code == 0 && response.enabled_mechanisms.include?(ident)
        raise Kafka::Error, "#{ident} is not supported."
      end

      @mechanism.authenticate!(connection.to_s, connection.encoder, connection.decoder)
    end
  end
end

Version data entries

15 entries across 15 versions & 3 rubygems

Version Path
ruby-kafka-1.4.0 lib/kafka/sasl_authenticator.rb
ruby-kafka-temp-fork-0.0.2 lib/kafka/sasl_authenticator.rb
ruby-kafka-temp-fork-0.0.1 lib/kafka/sasl_authenticator.rb
ruby-kafka-1.3.0 lib/kafka/sasl_authenticator.rb
ruby-kafka-1.2.0 lib/kafka/sasl_authenticator.rb
ruby-kafka-1.1.0 lib/kafka/sasl_authenticator.rb
ruby-kafka-1.1.0.beta1 lib/kafka/sasl_authenticator.rb
ruby-kafka-1.0.0 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.10 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.9 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.8 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.7 lib/kafka/sasl_authenticator.rb
ruby-kafka-custom-0.7.7.26 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.6 lib/kafka/sasl_authenticator.rb
ruby-kafka-0.7.6.beta2 lib/kafka/sasl_authenticator.rb