Struct aws_sdk_kms::types::GrantConstraints
source · #[non_exhaustive]pub struct GrantConstraints {
pub encryption_context_subset: Option<HashMap<String, String>>,
pub encryption_context_equals: Option<HashMap<String, String>>,
}
Expand description
Use this structure to allow cryptographic operations in the grant only when the operation request includes the specified encryption context.
KMS applies the grant constraints only to cryptographic operations that support an encryption context, that is, all cryptographic operations with a symmetric KMS key. Grant constraints are not applied to operations that do not support an encryption context, such as cryptographic operations with asymmetric KMS keys and management operations, such as DescribeKey
or RetireGrant
.
In a cryptographic operation, the encryption context in the decryption operation must be an exact, case-sensitive match for the keys and values in the encryption context of the encryption operation. Only the order of the pairs can vary.
However, in a grant constraint, the key in each key-value pair is not case sensitive, but the value is case sensitive.
To avoid confusion, do not use multiple encryption context pairs that differ only by case. To require a fully case-sensitive encryption context, use the kms:EncryptionContext:
and kms:EncryptionContextKeys
conditions in an IAM or key policy. For details, see kms:EncryptionContext: in the Key Management Service Developer Guide .
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.encryption_context_subset: Option<HashMap<String, String>>
A list of key-value pairs that must be included in the encryption context of the cryptographic operation request. The grant allows the cryptographic operation only when the encryption context in the request includes the key-value pairs specified in this constraint, although it can include additional key-value pairs.
encryption_context_equals: Option<HashMap<String, String>>
A list of key-value pairs that must match the encryption context in the cryptographic operation request. The grant allows the operation only when the encryption context in the request is the same as the encryption context specified in this constraint.
Implementations§
source§impl GrantConstraints
impl GrantConstraints
sourcepub fn encryption_context_subset(&self) -> Option<&HashMap<String, String>>
pub fn encryption_context_subset(&self) -> Option<&HashMap<String, String>>
A list of key-value pairs that must be included in the encryption context of the cryptographic operation request. The grant allows the cryptographic operation only when the encryption context in the request includes the key-value pairs specified in this constraint, although it can include additional key-value pairs.
sourcepub fn encryption_context_equals(&self) -> Option<&HashMap<String, String>>
pub fn encryption_context_equals(&self) -> Option<&HashMap<String, String>>
A list of key-value pairs that must match the encryption context in the cryptographic operation request. The grant allows the operation only when the encryption context in the request is the same as the encryption context specified in this constraint.
source§impl GrantConstraints
impl GrantConstraints
sourcepub fn builder() -> GrantConstraintsBuilder
pub fn builder() -> GrantConstraintsBuilder
Creates a new builder-style object to manufacture GrantConstraints
.
Trait Implementations§
source§impl Clone for GrantConstraints
impl Clone for GrantConstraints
source§fn clone(&self) -> GrantConstraints
fn clone(&self) -> GrantConstraints
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for GrantConstraints
impl Debug for GrantConstraints
source§impl PartialEq for GrantConstraints
impl PartialEq for GrantConstraints
source§fn eq(&self, other: &GrantConstraints) -> bool
fn eq(&self, other: &GrantConstraints) -> bool
self
and other
values to be equal, and is used
by ==
.