Skip to main content

Update objects (bulk)

patch
/api/pvlt/1.0/data/collections/{collection}/bulk/objects

Updates properties of objects in a collection.

If any object update fails, the operation fails and no objects are updated.

The maximum number of objects that can be updated in one operation is determined by the PVAULT_SERVICE_MAX_PAGE_SIZE environment variable.

The role performing this operation must have both of the following:

  • The CapDataWriter or the CapDataUpdater capability.
  • For each object in the request, at least one allowing policy and no denying policies for the write operation for each of the object's properties.

See identity and access management for more information about how capabilities are used to control access to operations and policies are used to control access to data.

Request

Header parameters

  • X-Tenant-Id - array of strings

    List of tenant IDs to enforce on the request.

Path parameters

  • collection - string required*

    The name of a collection.

Query parameters

  • expiration_secs - string

    Expiration time in seconds for the tokens. If not set, the expiry dates of the tokens are not changed.

  • options - array of strings

    Options for the operation. Options include:

    • archived – whether to update only archived objects. If not specified, updates only active objects.
    Each string:
  • prop - string

    The name of a property.

  • adhoc_reason - string

    An ad-hoc reason for accessing the Vault data. Required when reason is set to Other.

  • reason - string

    Details of the reason for requesting the property. The default is set when no access reason is provided and PVAULT_SERVICE_FORCE_ACCESS_REASON is false.

  • custom_audit - string

    Custom audit information to be included in the audit log.

  • reload_cache - boolean

    Reloads the cache before the action.

  • import - boolean

    Whether to write built-in property values.

  • export_key - string

    The encrypted copy of the key used to encrypt exported data. The key is encrypted using the export KMS key defined by the PVAULT_KMS_EXPORT_URI or PVAULT_KMS_EXPORT_SEED environment variables. When importing data, the key is decrypted by the KMS, then used to decrypt the data. This parameter is not intended to be used manually, but through the CLI command pvault import.

Request body

List of objects properties to update. The order of the objects in the array is preserved in the response.

array of objects required*

List of objects properties to update.

Each object:

A list of maps of object properties and their values.

Example
{
"date_of_birth": "1993-02-22",
"email": "patfar@example.com",
"first_name": "Pat",
"last_name": "Far",
"phone_number": "+11011010101"
}
Example
[
{
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"phone_number": "+11011010102"
},
{
"id": "69861845-8405-430c-b8ef-7e646d153149",
"phone_number": "+19099090908"
}
]

Possible responses

The bulk operation is successful. This status doesn't indicate that the operation is successful for all objects. Check the response body for details of the status of each object.

object required*
  • ok - boolean required*

    Indicates whether the operation was completed successfully for all objects in the bulk operation. If the operation failed for one or more of the provided objects, this property will be set to false.

  • results - array of objects required*

    An array of objects representing the processing result of each item in the bulk operation. The order of the objects in the array will match the order of the objects in the request.

    Each object:

    A result object representing the processing of an object in the bulk operation. Each result object includes there fields:

    • ok a boolean that indicates whether the operation completed successfully for the object.
    • id the unique identifier for the processed object. This field might be omitted if the operation failed before an id was assigned to the object.
    • error is present when ok is false and provides more information about any error. The error field follows the same structure as the error objects returned in single object operations.
    • id - string

      The unique identifier for the object.

    • ok - boolean required*

      Indicates whether the operation was completed successfully for this object. If true, the operation completed successfully. If false, the operation failed and the error field will contain more information.

    • error - object
      • context - object required*

        The error context.

        Values of additional properties are strings
        Example
        {
        "objectid": "b56dd6aa-35f0-11ed-a261-0242ac120002"
        }
      • error_code - string required*

        The error code.

      • message - string required*

        The error message.

      • error_url - string

        The URL to the error documentation.

Example
{
"ok": false,
"results": [
{
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"ok": false,
"error": {
"context": {
"objectid": "b56dd6aa-35f0-11ed-a261-0242ac120002"
},
"error_code": "PVxxxx",
"message": "The object is not found.",
"error_url": "https://docs.piiano.com/api/error-codes#PV1005"
}
}
]
}

Try the API

Authorization

Path parameters

Query parameters

Headers

Request body

Navigate to the docs of your local Vault installation to try the API directly from there.

Code examples

Example