メソッド: wrap

暗号化されたデータ暗号鍵(DEK)と関連データを返します。

詳細については、データの暗号化と復号をご覧ください。

HTTP リクエスト

POST https://KACLS_URL/wrap

KACLS_URL は、Key Access Control List Service(KACLS)の URL に置き換えます。

パスパラメータ

なし。

リクエストの本文

リクエストの本文には、次の構造のデータが含まれます。

JSON 表現
{
  "authentication": string,
  "authorization": string,
  "key": string,
  "reason": string
}
フィールド
authentication

string

ユーザーが誰であるかをアサートする IdP によって発行された JWT。認証トークンをご覧ください。

authorization

string

ユーザーが resource_name の鍵をラップできることを表明する JWT。認証トークンをご覧ください。

key

string

base64 でエンコードされた DEK。最大サイズ: 128 バイト。

reason

string (UTF-8)

オペレーションに関する追加のコンテキストを提供するパススルー JSON 文字列。提供された JSON は、表示する前にサニタイズする必要があります。最大サイズ: 1 KB。

レスポンスの本文

成功すると、このメソッドは不透明なバイナリ オブジェクトを返します。このオブジェクトは、暗号化されたオブジェクトとともに Google Workspace に保存され、後続のキーのラップ解除オペレーションでそのまま送信されます。

オペレーションが失敗した場合は、構造化されたエラー応答を返す必要があります。

バイナリ オブジェクトには、暗号化された DEK のコピーが 1 つだけ含まれている必要があります。実装固有のデータは、このオブジェクトに保存できます。

DEK を Key Access Control List Service(KACLS)システムに保存しないでください。代わりに、DEK を暗号化して、wrapped_key オブジェクトで返します。これにより、ドキュメントとそのキーの有効期間の不一致を防ぐことができます。たとえば、ユーザーがリクエストしたときにユーザーのデータが完全に消去されるようにするため、またはバックアップから復元された以前のバージョンが復号化可能であることを確認するためです。

JSON 表現
{
  "wrapped_key": string
}
フィールド
wrapped_key

string

base64 でエンコードされたバイナリ オブジェクト。最大サイズ: 1 KB。

この例は、wrap メソッドのサンプル リクエストとレスポンスを示しています。

リクエスト

POST https://mykacls.example.com/v1/wrap

{
   "key":"wHrlNOTI9mU6PBdqiq7EQA==",
   "authorization": "eyJhbGciOi…"
   "authentication": "eyJhbGciOi…"
   "reason": "{client:'drive' op:'update'}"
}

レスポンス

{
    "wrapped_key": "3qTh6Mp+svPwYPlnZMyuj8WHTrM59wl/UI50jo61Qt/QubZ9tfsUc1sD62xdg3zgxC9quV4r+y7AkbfIDhbmxGqP64pWbZgFzOkP0JcSn+1xm/CB2E5IknKsAbwbYREGpiHM3nzZu+eLnvlfbzvTnJuJwBpLoPYQcnPvcgm+5gU1j1BjUaNKS/uDn7VbVm7hjbKA3wkniORC2TU2MiHElutnfrEVZ8wQfrCEpuWkOXs98H8QxUK4pBM2ea1xxGj7vREAZZg1x/Ci/E77gHxymnZ/ekhUIih6Pwu75jf+dvKcMnpmdLpwAVlE1G4dNginhFVyV/199llf9jmHasQQuaMFzQ9UMWGjA1Hg2KsaD9e3EL74A5fLkKc2EEmBD5v/aP+1RRZ3ISbTOXvxqYIFCdSFSCfPbUhkc9I2nHS0obEH7Q7KiuagoDqV0cTNXWfCGJ1DtIlGQ9IA6mPDAjX8Lg=="
}