An auth provider is a factory for Authenticator instances (or objects matching that interface). Its #create_authenticator will be called once for each connection that requires authentication.

If the authentication requires keeping state, keep that in the authenticator instances, not in the auth provider.

Abstract
Auth providers given to Cassandra.cluster don’t need to be subclasses of this class, but need to implement the same methods. This class exists only for documentation purposes.
Note
Creating an authenticator must absolutely not block, or the whole connection process will block.
See Also:

Inherits

Object

Direct Known Subclasses

Methods

create_authenticator

(authentication_class, protocol_version)

Create a new authenticator object. This method will be called once per connection that requires authentication. The auth provider can create different authenticators for different authentication classes, or return nil if it does not support the authentication class.

Note
This method must absolutely not block.
Parameters:
Name Type Details
authentication_class String the authentication class used by the server.
Returns:
Type Details
(Auth::Authenticator or nil) an object with an interface matching Authenticator or nil if the authentication class is not supported.