java.lang.Object
software.amazon.awssdk.services.auditmanager.model.SourceKeyword
All Implemented Interfaces:
Serializable, SdkPojo, ToCopyableBuilder<SourceKeyword.Builder,SourceKeyword>

@Generated("software.amazon.awssdk:codegen") public final class SourceKeyword extends Object implements SdkPojo, Serializable, ToCopyableBuilder<SourceKeyword.Builder,SourceKeyword>

A keyword that relates to the control data source.

For manual evidence, this keyword indicates if the manual evidence is a file or text.

For automated evidence, this keyword identifies a specific CloudTrail event, Config rule, Security Hub control, or Amazon Web Services API name.

To learn more about the supported keywords that you can use when mapping a control data source, see the following pages in the Audit Manager User Guide:

See Also:
  • Method Details

    • keywordInputType

      public final KeywordInputType keywordInputType()

      The input method for the keyword.

      • SELECT_FROM_LIST is used when mapping a data source for automated evidence.

        • When keywordInputType is SELECT_FROM_LIST, a keyword must be selected to collect automated evidence. For example, this keyword can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      • UPLOAD_FILE and INPUT_TEXT are only used when mapping a data source for manual evidence.

        • When keywordInputType is UPLOAD_FILE, a file must be uploaded as manual evidence.

        • When keywordInputType is INPUT_TEXT, text must be entered as manual evidence.

      If the service returns an enum value that is not available in the current SDK version, keywordInputType will return KeywordInputType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available from keywordInputTypeAsString().

      Returns:
      The input method for the keyword.

      • SELECT_FROM_LIST is used when mapping a data source for automated evidence.

        • When keywordInputType is SELECT_FROM_LIST, a keyword must be selected to collect automated evidence. For example, this keyword can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      • UPLOAD_FILE and INPUT_TEXT are only used when mapping a data source for manual evidence.

        • When keywordInputType is UPLOAD_FILE, a file must be uploaded as manual evidence.

        • When keywordInputType is INPUT_TEXT, text must be entered as manual evidence.

      See Also:
    • keywordInputTypeAsString

      public final String keywordInputTypeAsString()

      The input method for the keyword.

      • SELECT_FROM_LIST is used when mapping a data source for automated evidence.

        • When keywordInputType is SELECT_FROM_LIST, a keyword must be selected to collect automated evidence. For example, this keyword can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      • UPLOAD_FILE and INPUT_TEXT are only used when mapping a data source for manual evidence.

        • When keywordInputType is UPLOAD_FILE, a file must be uploaded as manual evidence.

        • When keywordInputType is INPUT_TEXT, text must be entered as manual evidence.

      If the service returns an enum value that is not available in the current SDK version, keywordInputType will return KeywordInputType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available from keywordInputTypeAsString().

      Returns:
      The input method for the keyword.

      • SELECT_FROM_LIST is used when mapping a data source for automated evidence.

        • When keywordInputType is SELECT_FROM_LIST, a keyword must be selected to collect automated evidence. For example, this keyword can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      • UPLOAD_FILE and INPUT_TEXT are only used when mapping a data source for manual evidence.

        • When keywordInputType is UPLOAD_FILE, a file must be uploaded as manual evidence.

        • When keywordInputType is INPUT_TEXT, text must be entered as manual evidence.

      See Also:
    • keywordValue

      public final String keywordValue()

      The value of the keyword that's used when mapping a control data source. For example, this can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      If you’re mapping a data source to a rule in Config, the keywordValue that you specify depends on the type of rule:

      • For managed rules, you can use the rule identifier as the keywordValue. You can find the rule identifier from the list of Config managed rules. For some rules, the rule identifier is different from the rule name. For example, the rule name restricted-ssh has the following rule identifier: INCOMING_SSH_DISABLED. Make sure to use the rule identifier, not the rule name.

        Keyword example for managed rules:

      • For custom rules, you form the keywordValue by adding the Custom_ prefix to the rule name. This prefix distinguishes the custom rule from a managed rule.

        Keyword example for custom rules:

        • Custom rule name: my-custom-config-rule

          keywordValue: Custom_my-custom-config-rule

      • For service -linked rules, you form the keywordValue by adding the Custom_ prefix to the rule name. In addition, you remove the suffix ID that appears at the end of the rule name.

        Keyword examples for service-linked rules:

        • Service-linked rule name: CustomRuleForAccount-conformance-pack-szsm1uv0w

          keywordValue: Custom_CustomRuleForAccount-conformance-pack

        • Service-linked rule name: OrgConfigRule-s3-bucket-versioning-enabled-dbgzf8ba

          keywordValue: Custom_OrgConfigRule-s3-bucket-versioning-enabled

      The keywordValue is case sensitive. If you enter a value incorrectly, Audit Manager might not recognize the data source mapping. As a result, you might not successfully collect evidence from that data source as intended.

      Keep in mind the following requirements, depending on the data source type that you're using.

      1. For Config:

        • For managed rules, make sure that the keywordValue is the rule identifier in ALL_CAPS_WITH_UNDERSCORES. For example, CLOUDWATCH_LOG_GROUP_ENCRYPTED. For accuracy, we recommend that you reference the list of supported Config managed rules.

        • For custom rules, make sure that the keywordValue has the Custom_ prefix followed by the custom rule name. The format of the custom rule name itself may vary. For accuracy, we recommend that you visit the Config console to verify your custom rule name.

      2. For Security Hub: The format varies for Security Hub control names. For accuracy, we recommend that you reference the list of supported Security Hub controls.

      3. For Amazon Web Services API calls: Make sure that the keywordValue is written as serviceprefix_ActionName. For example, iam_ListGroups. For accuracy, we recommend that you reference the list of supported API calls.

      4. For CloudTrail: Make sure that the keywordValue is written as serviceprefix_ActionName. For example, cloudtrail_StartLogging. For accuracy, we recommend that you review the Amazon Web Service prefix and action names in the Service Authorization Reference.

      Returns:
      The value of the keyword that's used when mapping a control data source. For example, this can be a CloudTrail event name, a rule name for Config, a Security Hub control, or the name of an Amazon Web Services API call.

      If you’re mapping a data source to a rule in Config, the keywordValue that you specify depends on the type of rule:

      • For managed rules, you can use the rule identifier as the keywordValue. You can find the rule identifier from the list of Config managed rules. For some rules, the rule identifier is different from the rule name. For example, the rule name restricted-ssh has the following rule identifier: INCOMING_SSH_DISABLED. Make sure to use the rule identifier, not the rule name.

        Keyword example for managed rules:

      • For custom rules, you form the keywordValue by adding the Custom_ prefix to the rule name. This prefix distinguishes the custom rule from a managed rule.

        Keyword example for custom rules:

        • Custom rule name: my-custom-config-rule

          keywordValue: Custom_my-custom-config-rule

      • For service-linked rules, you form the keywordValue by adding the Custom_ prefix to the rule name. In addition, you remove the suffix ID that appears at the end of the rule name.

        Keyword examples for service-linked rules:

        • Service-linked rule name: CustomRuleForAccount-conformance-pack-szsm1uv0w

          keywordValue: Custom_CustomRuleForAccount-conformance-pack

        • Service-linked rule name: OrgConfigRule-s3-bucket-versioning-enabled-dbgzf8ba

          keywordValue: Custom_OrgConfigRule-s3-bucket-versioning-enabled

      The keywordValue is case sensitive. If you enter a value incorrectly, Audit Manager might not recognize the data source mapping. As a result, you might not successfully collect evidence from that data source as intended.

      Keep in mind the following requirements, depending on the data source type that you're using.

      1. For Config:

        • For managed rules, make sure that the keywordValue is the rule identifier in ALL_CAPS_WITH_UNDERSCORES. For example, CLOUDWATCH_LOG_GROUP_ENCRYPTED. For accuracy, we recommend that you reference the list of supported Config managed rules.

        • For custom rules, make sure that the keywordValue has the Custom_ prefix followed by the custom rule name. The format of the custom rule name itself may vary. For accuracy, we recommend that you visit the Config console to verify your custom rule name.

      2. For Security Hub: The format varies for Security Hub control names. For accuracy, we recommend that you reference the list of supported Security Hub controls.

      3. For Amazon Web Services API calls: Make sure that the keywordValue is written as serviceprefix_ActionName. For example, iam_ListGroups. For accuracy, we recommend that you reference the list of supported API calls.

      4. For CloudTrail: Make sure that the keywordValue is written as serviceprefix_ActionName. For example, cloudtrail_StartLogging. For accuracy, we recommend that you review the Amazon Web Service prefix and action names in the Service Authorization Reference.

    • toBuilder

      public SourceKeyword.Builder toBuilder()
      Description copied from interface: ToCopyableBuilder
      Take this object and create a builder that contains all of the current property values of this object.
      Specified by:
      toBuilder in interface ToCopyableBuilder<SourceKeyword.Builder,SourceKeyword>
      Returns:
      a builder for type T
    • builder

      public static SourceKeyword.Builder builder()
    • serializableBuilderClass

      public static Class<? extends SourceKeyword.Builder> serializableBuilderClass()
    • hashCode

      public final int hashCode()
      Overrides:
      hashCode in class Object
    • equals

      public final boolean equals(Object obj)
      Overrides:
      equals in class Object
    • equalsBySdkFields

      public final boolean equalsBySdkFields(Object obj)
      Description copied from interface: SdkPojo
      Indicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in an SdkPojo class, and is generated based on a service model.

      If an SdkPojo class does not have any inherited fields, equalsBySdkFields and equals are essentially the same.

      Specified by:
      equalsBySdkFields in interface SdkPojo
      Parameters:
      obj - the object to be compared with
      Returns:
      true if the other object equals to this object by sdk fields, false otherwise.
    • toString

      public final String toString()
      Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be redacted from this string using a placeholder value.
      Overrides:
      toString in class Object
    • getValueForField

      public final <T> Optional<T> getValueForField(String fieldName, Class<T> clazz)
    • sdkFields

      public final List<SdkField<?>> sdkFields()
      Specified by:
      sdkFields in interface SdkPojo
      Returns:
      List of SdkField in this POJO. May be empty list but should never be null.