AI-generated Key Takeaways
- 
          This method facilitates migrating from the older Key Access Control List Service (KACLS1) to the newer KACLS (KACLS2) by converting Data Encryption Keys (DEKs) wrapped with KACLS1 to be wrapped with KACLS2. 
- 
          The rewrapmethod requires an authorization token, the original KACLS URL, a reason for the operation, and the KACLS1-wrapped DEK in the request body.
- 
          A successful response provides a KACLS2-wrapped DEK and a resource key hash, ensuring the encrypted data remains accessible and manageable within Google Workspace. 
- 
          KACLS providers should encrypt and return the DEK within the wrapped_keyobject to prevent lifetime discrepancies and ensure data integrity.
- 
          Google Workspace doesn't send deletion requests to KACLS when objects are deleted, implying KACLS providers manage key lifecycles independently. 
This method helps you migrate from the old Key Access Control List Service
(KACLS1) to the newer KACLS (KACLS2). It takes a Data Encryption Key (DEK)
wrapped with KACLS1's wrap API, and returns a
DEK wrapped with KACLS2's wrap API.
HTTP request
POST https://KACLS_URL/rewrap
Replace KACLS_URL with the Key Access Control List
Service (KACLS) URL.
Path parameters
None.
Request body
The request body contains data with the following structure:
| JSON representation | |
|---|---|
| { "authorization": string, "original_kacls_url": string, "reason": string, "wrapped_key": string } | |
| Fields | |
|---|---|
| authorization | 
 A JWT asserting that the user is allowed to unwrap a key for  | 
| original_kacls_url | 
 URL of current wrapped_key's KACLS. | 
| reason | 
 A passthrough JSON string providing additional context about the operation. The JSON provided should be sanitized before being displayed. Max size: 1 KB. | 
| wrapped_key | 
 The base64 binary object returned by  | 
Response body
If successful, this method returns an opaque binary object that will be stored by Google Workspace along the encrypted object and sent as-is in any subsequent key unwrapping operation. It should also return the base64-encoded resource_key_hash.
If the operation fails, a structured error reply should be returned.
The binary object should contain the only copy of the encrypted DEK, implementation specific data can be stored in it.
Don't store the DEK in your KACLS system, instead encrypt it and return it in
the wrapped_key object. This prevents lifetime discrepancies between the
document and its keys. For example, to ensure that the user's data is fully
wiped out when they request it, or to make sure that previous versions restored
from a backup will be decryptable.
Google won't send deletion requests to the KACLS when objects are deleted.
| JSON representation | |
|---|---|
| { "resource_key_hash": string, "wrapped_key": string } | |
| Fields | |
|---|---|
| resource_key_hash | 
 base64 encoded binary object. See resource key hash. | 
| wrapped_key | 
 The base64-encoded binary object. Max size: 1 KB. | 
Example
This example provides a sample request and response for the rewrap method.
Request
POST https://mykacls.example.com/v1/rewrap
{
   "wrapped_key": "7qTh6Mp+svVwYPlnZMyuj8WHTrM59wl/UI50jo61Qt/QubZ9tfsUc1sD62xdg3zgxC9quV4r+y7AkbfIDhbmxGqP64pWbZgFzOkP0JcSn+1xm/CB2E5IknKsAbwbYREGpiHM3nzZu+eLnvlfbzvTnJuJwBpLoPYQcnPvcgm+5gU1j1BjUaNKS/uDn7VbVm7hjbKA3wkniORC2TU2MiHElutnfrEVZ8wQfrCEpuWkOXs98H8QxUK4pBM2ea1xxGj7vREAZZg1x/Ci/E77gHxymnZ/ekhUIih6Pwu75jf+dvKcMnpmdLpwAVlE1G4dNginhFVyV/199llf9jmHasQQuaMFzQ9UMWGjA1Hg2KsaD9e3EL74A5fLkKc2EEmBD5v/aP+1RRZ3ISbTOXvxqYIFCdSFSCfPbUhkc9I2nHS0obEH7Q7KiuagoDqV0cTNXWfCGJ1DtIlGQ9IA6mPDAjX8Lg==",
   "authorization": "eyJhbGciOi...",
   "original_kacls_url": "https://original.example.com/kacls/v1",
   "reason": "{client:'drive' op:'read'}"
}
Response
{
    "wrapped_key": "3qTh6Mp+svPwYPlnZMyuj8WHTrM59wl/UI50jo61Qt/QubZ9tfsUc1sD62xdg3zgxC9quV4r+y7AkbfIDhbmxGqP64pWbZgFzOkP0JcSn+1xm/CB2E5IknKsAbwbYREGpiHM3nzZu+eLnvlfbzvTnJuJwBpLoPYQcnPvcgm+5gU1j1BjUaNKS/uDn7VbVm7hjbKA3wkniORC2TU2MiHElutnfrEVZ8wQfrCEpuWkOXs98H8QxUK4pBM2ea1xxGj7vREAZZg1x/Ci/E77gHxymnZ/ekhUIih6Pwu75jf+dvKcMnpmdLpwAVlE1G4dNginhFVyV/199llf9jmHasQQuaMFzQ9UMWGjA1Hg2KsaD9e3EL74A5fLkKc2EEmBD5v/aP+1RRZ3ISbTOXvxqYIFCdSFSCfPbUhkc9I2nHS0obEH7Q7KiuagoDqV0cTNXWfCGJ1DtIlGQ9IA6mPDAjX8Lg==",
    "resource_key_hash": "SXOyPekBAUI95zuZSuJzsBlK4nO5SuJK4nNCPem5SuI="
}