Version: SG FLX
Enterprise

Internal Users API

Used to receive, create, update and delete users. Users are added to the internal user database. It only makes sense to use this if you use internal as authentication_backend.

Endpoint

/_searchguard/api/internalusers/{username}

Where username is the name of the user.

GET

Get a single user

GET /_searchguard/api/internalusers/{username}

Returns the settings for the respective user in JSON format, for example:

GET /_searchguard/api/internalusers/kirk
{
  "kirk": {
    "description": "The captain.",
    "hash": "",
    "backend_roles": [ "captains", "starfleet" ],
    "attributes": {
       "attribute1": "value1",
       "attribute2": "value2"   	
    }
  }
}

The password hash is not returned by this API endpoint.

Get all users

GET /_searchguard/api/internalusers/

Returns all users in JSON format.

DELETE

DELETE /_searchguard/api/internalusers/{username}

Deletes the user specified by username. If successful, the call returns with status code 200 and a JSON success message.

DELETE /_searchguard/api/internalusers/kirk
{
  "status":"OK",
  "message":"user kirk deleted."
}

PUT

PUT /_searchguard/api/internalusers/{username}

Replaces or creates the user specified by username.

PUT /_searchguard/api/internalusers/kirk
{
  "hash": "$2a$12$xZOcnwYPYQ3zIadnlQIJ0eNhX1ngwMkTN.oMwkKxoGvDVPn4/6XtO", OR
  "password": "kirk",
  "backend_roles": ["captains", "starfleet"],
   "attributes": {
     "attribute1": "value1",
     "attribute2": "value2",       	
   }
}

You need to specify either hash or password.

You can either use an already hashed password (hash field) or provide it in clear text (password field). In the latter case the password hashed automatically before storing it. If both fields are specified, hash takes precedence.

backend_roles contains an array of the user’s backend roles. This is optional. If the call is successful, a JSON structure is returned, indicating whether the user was created or updated.

{
  "status":"CREATED",
  "message":"User kirk created"
}

PATCH

The PATCH endpoint can be used to change individual attributes of a user, or to create, change and delete users in a bulk call. The PATCH endpoint expects a payload in JSON Patch format. Search Guard supports the complete JSON patch specification.

JSON patch specification: http://jsonpatch.com/

Example: Patch a single user

PATCH /_searchguard/api/internalusers/{username}

Adds, deletes or changes one or more attributes of a user specified by username.

PATCH /_searchguard/api/internalusers/kirk
[ 
  { 
    "op": "replace", "path": "/backend_roles", "value": ["klingons"] 
  },
  { 
    "op": "replace", "path": "/attributes", "value": {"newattribute": "newvalue"} 
  }
]

Example: Bulk add, delete and change users

PATCH /_searchguard/api/internalusers
[ 
  { 
    "op": "add", "path": "/spock", "value": { "password": "testpassword1", "backend_roles": ["testrole1"] } 
  },
  { 
    "op": "add", "path": "/worf", "value": { "password": "testpassword2", "backend_roles": ["testrole2"] } 
  },
  { 
    "op": "remove", "path": "/riker"
  }
]

Example: Modify an existing object or array

PATCH /_searchguard/api/internalusers/spock
[
  {
    "op": "add", "path": "/backend_roles/0", "value": "testrole2" 
  },
  {
    "op": "add", "path": "/backend_roles/-", "value": "testrole3"
  },
]

The operation inserts the value into an array. The value is inserted before the given index. The - character can be used instead of an index to insert at the end of an array.

PATCH /_searchguard/api/internalusers/spock
[
  {
    "op": "remove", "path": "/backend_roles/0"
  }
]

The operation removes the element 0 of the array (or just removes the "0" key if backend_roles is an object)

For more examples, please refer to JSON patch format documentation.

Changing the internal user password

The password of internal users can easily be updated either via the Kibana dashboard in Home -> Internal Users -> Update User or via REST

PUT /_searchguard/api/internalusers/<user name>
{
  "password": "<new password>"
}

Please note that the password is immediately changed and you might need to update your Basic Authorization header (username:password) in subsequent requests.

Password rules

In order to enforce password rules (e.g. mixed letters and digits, minimum length), you can configure a regular expression in elasticsearch.yml:

searchguard.restapi.password_validation_regex: "(?=.*[A-Z])(?=.*[^a-zA-Z\d])(?=.*[0-9])(?=.*[a-z]).{8,}"

The above regex expression, for example, will only permit passwords with a minimum length of eight characters and it must contain at least one upper case, one special char, one digit and one lower case char.

If the password does not match the configured regular expression, Search Guard will return:

{
	"status": "error",
	"reason": "<error message>"
} 

The error message should match your regular expression and tell the user what rules the password must meet. If you are using the Kibana config GUI, the error message will be displayed to the user. You can set the error message in elasticsearch.yml:

searchguard.restapi.password_validation_error_message: "Password must be at least 8 characters ..."


Not what you were looking for? Try the search.