userdirectory.test
Description
object userdirectory.test(array userDirectory)
This method allows to test user directory connection settings.
This method is only available to Super admin user type.
Parameters
(object)
User directory properties.
Since userdirectory.get
API does not return bind_password
field, userdirectoryid
and/or bind_password
should be supplied.
Additionally to the standard user directory properties, the method accepts the following parameters.
Parameter | Type | Description |
---|---|---|
test_username | string | Username to test in user directory. |
test_password | string | Username associated password to test in user directory. |
Return values
(bool)
Returns true on success.
Examples
Test user directory
Test user directory for user “user1”.
Request:
{
"jsonrpc": "2.0",
"method": "userdirectory.test",
"params": {
"userdirectoryid": "2",
"host": "127.0.0.1",
"port": "3389",
"base_dn": "ou=Users,dc=example,dc=org",
"search_attribute": "uid",
"bind_dn": "cn=ldap_search,dc=example,dc=org",
"bind_password": "password",
"test_username": "user1",
"test_password": "password"
},
"auth": "3a57200802b24cda67c4e4010b50c065",
"id": 1
}
Response:
{
"jsonrpc": "2.0",
"result": true,
"id": 1
}
Test user directory
Test non existing user “user2”.
Request:
{
"jsonrpc": "2.0",
"method": "userdirectory.test",
"params": {
"userdirectoryid": "2",
"host": "127.0.0.1",
"port": "3389",
"base_dn": "ou=Users,dc=example,dc=org",
"search_attribute": "uid",
"bind_dn": "cn=ldap_search,dc=example,dc=org",
"test_username": "user2",
"test_password": "password"
},
"auth": "3a57200802b24cda67c4e4010b50c065",
"id": 1
}
Response:
{
"jsonrpc": "2.0",
"error": {
"code": -32500,
"message": "Application error.",
"data": "Incorrect user name or password or account is temporarily blocked."
},
"id": 1
}
Test user directory for user provisioning
Test userdirectory “3” for what configured data matches the user directory settings for “user3” provisioning (e.g., what user role, user groups, user medias will be assigned to the user).
{
"jsonrpc": "2.0",
"method": "userdirectory.test",
"params": {
"userdirectoryid": "2",
"host": "host.example.com",
"port": "389",
"base_dn": "DC=zbx,DC=local",
"search_attribute": "sAMAccountName",
"bind_dn": "CN=Admin,OU=Users,OU=Zabbix,DC=zbx,DC=local",
"test_username": "user3",
"test_password": "password"
},
"id": 1
}
Response:
{
"jsonrpc": "2.0",
"result": {
"username": "user3",
"name": "John",
"surname": "Doe",
"medias": [],
"usrgrps": [
{
"usrgrpid": "8"
},
{
"usrgrpid": "7"
}
],
"roleid": "2",
"userdirectoryid": "2"
},
"id": 1
}
Source
CUserDirectory::test() in ui/include/classes/api/services/CUserDirectory.php.