Update user profile data API

Update user profile data API

New API reference

For the most up-to-date API details, refer to Security APIs.

The user profile feature is designed only for use by Kibana and Elastic’s Observability, Enterprise Search, and Elastic Security solutions. Individual users and external applications should not call this API directly. Elastic reserves the right to change or remove this feature in future releases without prior notice.

Updates specific data for the user profile that’s associated with the specified unique ID.

Request

POST /_security/profile/<uid>/_data

Prerequisites

To use this API, you must have one of the following privileges:

  • The manage_user_profile cluster privilege.
  • The update_profile_data global privilege for the namespaces that are referenced in the request.

Description

The update user profile API updates the labels and data fields of an existing user profile document with JSON objects. New keys and their values are added to the profile document, and conflicting keys are replaced by data that’s included in the request.

For both labels and data, content is namespaced by the top-level fields. The update_profile_data global privilege grants privileges for updating only the allowed namespaces.

Path parameters

uid

(Required, string) A unique identifier for the user profile.

Query parameters

if_seq_no

(Optional, integer) Only perform the operation if the document has this sequence number. See Optimistic concurrency control.

if_primary_term

(Optional, integer) Only perform the operation if the document has this primary term. See Optimistic concurrency control.

refresh

(Optional, enum) If true, Elasticsearch refreshes the affected shards to make this operation visible to search, if wait_for then wait for a refresh to make this operation visible to search, if false do nothing with refreshes. Valid values: true, false, wait_for. Default: false.

uid

(Required, string) A unique identifier for the user profile.

Request body

labels

(Required*, object) Searchable data that you want to associate with the user profile. This field supports a nested data structure. Within the labels object, top-level keys cannot begin with an underscore (_) or contain a period (.).

data

(Required*, object) Non-searchable data that you want to associate with the user profile. This field supports a nested data structure. Within the data object, top-level keys cannot begin with an underscore (_) or contain a period (.) The data object is not searchable, but can be retrieved with the Get user profile API.

*Indicates that the setting is required in some, but not all situations.

Response body

A successful update user profile data API call returns a JSON structure indicating that the request is acknowledged:

  1. {
  2. "acknowledged": true
  3. }

Examples

The following request updates a profile document for a uid matching u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0:

  1. resp = client.security.update_user_profile_data(
  2. uid="u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. labels={
  4. "direction": "east"
  5. },
  6. data={
  7. "app1": {
  8. "theme": "default"
  9. }
  10. },
  11. )
  12. print(resp)
  1. const response = await client.security.updateUserProfileData({
  2. uid: "u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. labels: {
  4. direction: "east",
  5. },
  6. data: {
  7. app1: {
  8. theme: "default",
  9. },
  10. },
  11. });
  12. console.log(response);
  1. POST /_security/profile/u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0/_data
  2. {
  3. "labels": {
  4. "direction": "east"
  5. },
  6. "data": {
  7. "app1": {
  8. "theme": "default"
  9. }
  10. }
  11. }

You can update the profile data to replace some keys and add new keys:

  1. resp = client.security.update_user_profile_data(
  2. uid="u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. labels={
  4. "direction": "west"
  5. },
  6. data={
  7. "app1": {
  8. "font": "large"
  9. }
  10. },
  11. )
  12. print(resp)
  1. const response = await client.security.updateUserProfileData({
  2. uid: "u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. labels: {
  4. direction: "west",
  5. },
  6. data: {
  7. app1: {
  8. font: "large",
  9. },
  10. },
  11. });
  12. console.log(response);
  1. POST /_security/profile/u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0/_data
  2. {
  3. "labels": {
  4. "direction": "west"
  5. },
  6. "data": {
  7. "app1": {
  8. "font": "large"
  9. }
  10. }
  11. }

If you get the profile now, the consolidated profile data is returned:

  1. resp = client.security.get_user_profile(
  2. uid="u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. data="*",
  4. )
  5. print(resp)
  1. const response = await client.security.getUserProfile({
  2. uid: "u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  3. data: "*",
  4. });
  5. console.log(response);
  1. GET /_security/profile/u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0?data=*
  1. {
  2. "profiles": [
  3. {
  4. "uid": "u_P_0BMHgaOK3p7k-PFWUCbw9dQ-UFjt01oWJ_Dp2PmPc_0",
  5. "enabled": true,
  6. "last_synchronized": 1642650651037,
  7. "user": {
  8. "username": "jackrea",
  9. "roles": [
  10. "admin"
  11. ],
  12. "realm_name": "native",
  13. "full_name": "Jack Reacher",
  14. "email": "jackrea@example.com"
  15. },
  16. "labels": {
  17. "direction": "west"
  18. },
  19. "data": {
  20. "app1": {
  21. "theme": "default",
  22. "font": "large"
  23. }
  24. },
  25. "_doc": {
  26. "_primary_term": 88,
  27. "_seq_no": 66
  28. }
  29. }
  30. ]
  31. }