使用 Cloud HSM 配置密钥访问理由
本页介绍了如何为 Assured Workloads 负载的日本地区控制软件包使用 Cloud HSM 配置 Key Access Justifications。
在为日本区域创建新的 Assured Workloads 文件夹的步骤中,您可以选择为加密密钥创建新项目和密钥环。您可以将 Cloud HSM 密钥添加到此密钥环,还可以配置“Key Access Justifications”政策来控制对每个密钥的访问权限。
准备工作
- 将 Key Access Justifications 与 Cloud HSM 密钥搭配使用的能力仅适用于 Assured Workloads 中的日本区域控制包。
- 确保您的管理员已向您授予所需的 Identity and Access Management (IAM) 角色之一,以便您创建和管理 Key Access Justifications 政策以及 Cloud HSM 密钥本身。
必需的 IAM 权限
如需获得创建和管理 Cloud HSM 密钥及其 Key Access Justifications 政策所需的权限,请让您的管理员向您授予包含密钥环的项目的 Cloud KMS Admin (roles/cloudkms.admin
) IAM 角色。
如需详细了解如何授予角色,请参阅管理对项目、文件夹和组织的访问权限。
此预定义角色包含创建和管理 Cloud HSM 密钥及其 Key Access Justifications 政策所需的权限。如需查看所需的确切权限,请展开所需权限部分:
所需权限
如需创建和管理 Cloud HSM 密钥及其 Key Access Justifications 政策,您需要具备以下权限:
-
cloudkms.cryptoKeys.create
-
cloudkms.cryptoKeys.update
-
cloudkms.cryptoKeys.get
使用 Key Access Justifications 配置 Cloud HSM 密钥
如需使用 Cloud HSM 密钥配置 Key Access Justifications,您可以在创建密钥时将密钥访问权限政策作为参数添加进去,也可以在创建密钥后使用该政策更新密钥。
创建新的密钥和政策
REST
使用 cryptoKeys.create
方法创建新的密钥和政策:
POST https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/cryptoKeys?crypto_key_id=KEY_NAME
在请求中,替换以下占位值:
- PROJECT_ID:包含您要向其添加密钥的密钥环的项目 ID,例如
919698201234
。 - LOCATION:密钥环的位置,例如
us-west1
。 - KEY_RING:您在创建“Assured Workloads”文件夹的密钥管理项目和密钥环时指定的密钥环的名称,例如
my-key-ring
。 - KEY_NAME:您要创建的 HSM 密钥的名称,例如
my-hsm-key
。
请求正文:
{ "purpose": "PURPOSE", "versionTemplate": { "protectionLevel": "HSM", "algorithm": "ALGORITHM" }, "keyAccessJustificationsPolicy": { "allowedAccessReasons": [ ALLOWED_ACCESS_REASONS ] } }
在请求正文中,替换以下占位值:
- PURPOSE:密钥的用途。如需查看不同密钥用途的列表,请参阅密钥用途,例如
ENCRYPT_DECRYPT
。 - ALGORITHM:要使用的加密算法。如需查看可用算法列表,请参阅 Cloud KMS 算法,例如
GOOGLE_SYMMETRIC_ENCRYPTION
。 - ALLOWED_ACCESS_REASONS:Key Access Justifications 政策,用于定义一个或多个允许的理由代码(例如
CUSTOMER_INITIATED_ACCESS
),以便访问加密密钥。
以下示例请求和请求正文仅允许使用访问权限理由,原因如下:
POST https://cloudkms.googleapis.com/v1/projects/919698201234/locations/us-west1/keyRings/my-key-ring/cryptoKeys?crypto_key_id=my-hsm-key
{ "purpose": "ENCRYPT_DECRYPT", "versionTemplate": { "protectionLevel": "HSM", "algorithm": "GOOGLE_SYMMETRIC_ENCRYPTION" }, "keyAccessJustificationsPolicy": { "allowedAccessReasons": [ "CUSTOMER_INITIATED_ACCESS", "GOOGLE_INITIATED_SYSTEM_OPERATION" ] } }
更新现有密钥的政策
REST
使用 cryptoKeys.patch
方法更新 Cloud KMS 中的现有密钥:
PATCH https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/cryptoKeys/KEY_NAME?update_mask=keyAccessJustificationsPolicy
在请求中,替换以下占位值:
- PROJECT_ID:包含密钥对应的密钥环的项目的 ID,例如
919698201234
。 - LOCATION:密钥环的位置,例如
us-west1
。 - KEY_RING:您在创建“Assured Workloads”文件夹的密钥管理项目和密钥环时指定的密钥环的名称,例如
my-key-ring
。 - KEY_NAME:您要更新的 HSM 密钥的名称,例如
my-hsm-key
。
请求正文:
{ "purpose": "PURPOSE", "versionTemplate": { "protectionLevel": "HSM", "algorithm": "ALGORITHM" }, "keyAccessJustificationsPolicy": { "allowedAccessReasons": [ ALLOWED_ACCESS_REASONS ] } }
在请求正文中,替换以下占位值:
- PURPOSE:密钥的用途。如需查看不同密钥用途的列表,请参阅密钥用途,例如
ENCRYPT_DECRYPT
。 - ALGORITHM:要使用的加密算法。如需查看可用算法列表,请参阅 Cloud KMS 算法,例如
GOOGLE_SYMMETRIC_ENCRYPTION
。 - ALLOWED_ACCESS_REASONS:Key Access Justifications 政策,用于定义一个或多个允许的理由代码(例如
CUSTOMER_INITIATED_ACCESS
),以便访问加密密钥。
以下示例请求和请求正文仅允许使用访问权限理由,原因如下:
PATCH https://cloudkms.googleapis.com/v1/projects/919698201234/locations/us-west1/keyRings/my-key-ring/cryptoKeys/my-hsm-key?keyAccessJustificationsPolicy
{ "purpose": "ENCRYPT_DECRYPT", "versionTemplate": { "protectionLevel": "HSM", "algorithm": "GOOGLE_SYMMETRIC_ENCRYPTION" }, "keyAccessJustificationsPolicy": { "allowedAccessReasons": [ "CUSTOMER_INITIATED_ACCESS", "GOOGLE_INITIATED_SYSTEM_OPERATION" ] } }
获取密钥的 Key Access Justifications 政策
REST
使用 cryptoKeys.get
方法获取 Cloud KMS 中现有密钥的元数据:
GET https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/cryptoKeys/KEY_NAME
在请求参数中,将以下占位符值替换为您自己的值:
- PROJECT_ID:包含密钥对应的密钥环的项目 ID,例如
919698201234
。 - LOCATION:密钥环的位置,例如
us-west1
。 - KEY_RING:您在创建“Assured Workloads”文件夹的密钥管理项目和密钥环时指定的密钥环的名称,例如
my-key-ring
。 - KEY_NAME:您要获取的 HSM 密钥的名称,例如
my-hsm-key
。
以下示例请求会获取 Cloud KMS 中密钥的元数据:
GET https://cloudkms.googleapis.com/v1/projects/919698201234/locations/us-west1/keyRings/my-key-ring/cryptoKeys/my-hsm-key
响应正文包含有关您的密钥的元数据,包括 keyAccessJustificationsPolicy
。例如:
{ "purpose": "ENCRYPT_DECRYPT", "versionTemplate": { "protectionLevel": "HSM", "algorithm": "GOOGLE_SYMMETRIC_ENCRYPTION" }, "keyAccessJustificationsPolicy": { "allowedAccessReasons": [ "CUSTOMER_INITIATED_ACCESS", "GOOGLE_INITIATED_SYSTEM_OPERATION" ] } }