LDAP

    LDAP authentication login complements Doris authentication login by accessing the LDAP service for password authentication; Doris uses LDAP to authenticate the user’s password first; if the user does not exist in the LDAP service, it continues to use Doris to authenticate the password; if the LDAP password is correct but there is no corresponding account in Doris, a temporary user is created to log in to Doris.

    LDAP group authorization, is to map the group in LDAP to the Role in Doris, if the user belongs to multiple user groups in LDAP, after logging into Doris the user will get the permission of all groups corresponding to the Role, requiring the group name to be the same as the Role name.

    • LDAP: Lightweight directory access protocol that enables centralized management of account passwords.
    • Privilege: Permissions act on nodes, databases or tables. Different permissions represent different permission to operate.
    • Role: Doris can create custom named roles. A role can be thought of as a collection of permissions.

    You need to configure the LDAP basic information in the fe/conf/ldap.conf file, and the LDAP administrator password needs to be set using sql statements.

    Configure the fe/conf/ldap.conf file:

    • ldap_authentication_enabled = false
      Set the value to “true” to enable LDAP authentication; when the value is “false”, LDAP authentication is not enabled and all other configuration items of this profile are invalid.Set the value to “true” to enable LDAP authentication; when the value is “false”, LDAP authentication is not enabled and all other configuration items of this profile are invalid.

    • ldap_host = 127.0.0.1
      LDAP service ip.

    • ldap_port = 389
      LDAP service port, the default plaintext transfer port is 389, currently Doris’ LDAP function only supports plaintext password transfer.

    • ldap_admin_name = cn=admin,dc=domain,dc=com
      LDAP administrator account “Distinguished Name”. When a user logs into Doris using LDAP authentication, Doris will bind the administrator account to search for user information in LDAP.

    • ldap_user_basedn = ou=people,dc=domain,dc=com Doris base dn when searching for user information in LDAP.

    • ldap_group_basedn = ou=group,dc=domain,dc=com base dn when Doris searches for group information in LDAP. if this item is not configured, LDAP group authorization will not be enabled.

    Set the LDAP administrator password:

    After configuring the ldap.conf file, start fe, log in to Doris with the root or admin account, and execute sql:

    Client-side LDAP authentication requires the mysql client-side explicit authentication plugin to be enabled. Logging into Doris using the command line enables the mysql explicit authentication plugin in one of two ways.

    • Set the environment variable LIBMYSQL_ENABLE_CLEARTEXT_PLUGIN to value 1. For example, in a linux or max environment you can use the command:

    • Add the parameter “—enable-cleartext-plugin” each time you log in to Doris.

    LDAP password authentication and group authorization are complementary to Doris password authentication and authorization. Enabling LDAP functionality does not completely replace Doris password authentication and authorization, but coexists with Doris password authentication and authorization.

    When LDAP is enabled, users have the following in Doris and DLAP:

    After LDAP is enabled, when a user logs in using mysql client, Doris will first verify the user’s password through the LDAP service, and if the LDAP user exists and the password is correct, Doris will use the user to log in; at this time, if the corresponding account exists, Doris will directly log in to the account, and if the corresponding account does not exist, it will create a temporary account for the user and log in to the account. The temporary account has the appropriate pair of permissions (see LDAP Group Authorization) and is only valid for the current connection. doris does not create the user and does not generate metadata for creating the user pair.
    If no login user exists in the LDAP service, Doris is used for password authentication.

    For example:

    1:Accounts exist in both Doris and LDAP.

    Doris account exists: jack@’172.10.1.10’, password: 123456
    LDAP user node presence attribute: uid: jack user password: abcdef
    The jack@’172.10.1.10’ account can be logged into by logging into Doris using the following command:

    1. mysql -hDoris_HOST -PDoris_PORT -ujack -p abcdef

    Login will fail with the following command:

    2:The user exists in LDAP and the corresponding account does not exist in Doris.

    LDAP user node presence attribute: uid: jack User password: abcdef
    Use the following command to create a temporary user and log in to jack@’%’, the temporary user has basic privileges DatabasePrivs: Select_priv, Doris will delete the temporary user after the user logs out and logs in:

    3:LDAP does not exist for the user.

    Doris account exists: jack@’172.10.1.10’, password: 123456
    Login to the account using the Doris password, successfully:

    If a DLAP user dn is the “member” attribute of an LDAP group node, Doris assumes that the user belongs to the group. Doris will revoke the corresponding role privileges after the user logs out. Before using LDAP group authorization, you should create the corresponding role pairs in Doris and authorize the roles.

    Login user Privileges are related to Doris user and group Privileges, as shown in the following table:
    |LDAP Users|Doris Users|Login User Privileges| |—|—|—| |exist|exist|LDAP group Privileges + Doris user Privileges| |Does not exist|Exists|Doris user Privileges| |exist|non-exist|LDAP group Privileges|

    If the logged-in user is a temporary user and no group permission exists, the user has the select_priv permission of the information_schema by default

    Example:
    LDAP user dn is the “member” attribute of the LDAP group node then the user is considered to belong to the group, Doris will intercept the first Rdn of group dn as the group name.
    For example, if user dn is “uid=jack,ou=aidp,dc=domain,dc=com”, the group information is as follows:

    1. dn: cn=doris_rd,ou=group,dc=domain,dc=com
    2. member: uid=jack,ou=aidp,dc=domain,dc=com

    If jack also belongs to the LDAP groups doris_qa, doris_pm; Doris exists roles: doris_rd, doris_qa, doris_pm, after logging in using LDAP authentication, the user will not only have the original permissions of the account, but will also get the roles doris_rd, doris_qa and doris _pm privileges.

    • The current LDAP feature of Doris only supports plaintext password authentication, that is, when a user logs in, the password is transmitted in plaintext between client and fe and between fe and LDAP service.