public class GrantConstraints
extends java.lang.Object
implements java.io.Serializable
Use this structure to allow cryptographic operations in the grant only when the operation request includes the specified encryption context.
AWS KMS applies the grant constraints only to cryptographic operations that support an encryption context, that is, all cryptographic operations with a symmetric CMK. Grant constraints are not applied to operations that do not support an encryption context, such as cryptographic operations with asymmetric CMKs 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 AWS Key Management Service
Developer Guide .
Constructor and Description |
---|
GrantConstraints() |
Modifier and Type | Method and Description |
---|---|
GrantConstraints |
addEncryptionContextEqualsEntry(java.lang.String key,
java.lang.String value)
A list of key-value pairs that must match the encryption context in the
cryptographic operation request.
|
GrantConstraints |
addEncryptionContextSubsetEntry(java.lang.String key,
java.lang.String value)
A list of key-value pairs that must be included in the encryption context
of the cryptographic operation request.
|
GrantConstraints |
clearEncryptionContextEqualsEntries()
Removes all the entries added into EncryptionContextEquals.
|
GrantConstraints |
clearEncryptionContextSubsetEntries()
Removes all the entries added into EncryptionContextSubset.
|
boolean |
equals(java.lang.Object obj) |
java.util.Map<java.lang.String,java.lang.String> |
getEncryptionContextEquals()
A list of key-value pairs that must match the encryption context in the
cryptographic operation request.
|
java.util.Map<java.lang.String,java.lang.String> |
getEncryptionContextSubset()
A list of key-value pairs that must be included in the encryption context
of the cryptographic operation request.
|
int |
hashCode() |
void |
setEncryptionContextEquals(java.util.Map<java.lang.String,java.lang.String> encryptionContextEquals)
A list of key-value pairs that must match the encryption context in the
cryptographic operation request.
|
void |
setEncryptionContextSubset(java.util.Map<java.lang.String,java.lang.String> encryptionContextSubset)
A list of key-value pairs that must be included in the encryption context
of the cryptographic operation request.
|
java.lang.String |
toString()
Returns a string representation of this object; useful for testing and
debugging.
|
GrantConstraints |
withEncryptionContextEquals(java.util.Map<java.lang.String,java.lang.String> encryptionContextEquals)
A list of key-value pairs that must match the encryption context in the
cryptographic operation request.
|
GrantConstraints |
withEncryptionContextSubset(java.util.Map<java.lang.String,java.lang.String> encryptionContextSubset)
A list of key-value pairs that must be included in the encryption context
of the cryptographic operation request.
|
public java.util.Map<java.lang.String,java.lang.String> getEncryptionContextSubset()
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.
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.
public void setEncryptionContextSubset(java.util.Map<java.lang.String,java.lang.String> encryptionContextSubset)
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.
encryptionContextSubset
- 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.
public GrantConstraints withEncryptionContextSubset(java.util.Map<java.lang.String,java.lang.String> encryptionContextSubset)
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.
Returns a reference to this object so that method calls can be chained together.
encryptionContextSubset
- 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.
public GrantConstraints addEncryptionContextSubsetEntry(java.lang.String key, java.lang.String value)
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.
The method adds a new key-value pair into EncryptionContextSubset parameter, and returns a reference to this object so that method calls can be chained together.
key
- The key of the entry to be added into EncryptionContextSubset.value
- The corresponding value of the entry to be added into
EncryptionContextSubset.public GrantConstraints clearEncryptionContextSubsetEntries()
Returns a reference to this object so that method calls can be chained together.
public java.util.Map<java.lang.String,java.lang.String> getEncryptionContextEquals()
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.
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.
public void setEncryptionContextEquals(java.util.Map<java.lang.String,java.lang.String> encryptionContextEquals)
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.
encryptionContextEquals
- 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.
public GrantConstraints withEncryptionContextEquals(java.util.Map<java.lang.String,java.lang.String> encryptionContextEquals)
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.
Returns a reference to this object so that method calls can be chained together.
encryptionContextEquals
- 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.
public GrantConstraints addEncryptionContextEqualsEntry(java.lang.String key, java.lang.String value)
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.
The method adds a new key-value pair into EncryptionContextEquals parameter, and returns a reference to this object so that method calls can be chained together.
key
- The key of the entry to be added into EncryptionContextEquals.value
- The corresponding value of the entry to be added into
EncryptionContextEquals.public GrantConstraints clearEncryptionContextEqualsEntries()
Returns a reference to this object so that method calls can be chained together.
public java.lang.String toString()
toString
in class java.lang.Object
Object.toString()
public int hashCode()
hashCode
in class java.lang.Object
public boolean equals(java.lang.Object obj)
equals
in class java.lang.Object
Copyright © 2018 Amazon Web Services, Inc. All Rights Reserved.