# frozen_string_literal: true

# WARNING ABOUT GENERATED CODE
#
# This file is generated. See the contributing guide for more information:
# https://github.com/aws/aws-sdk-ruby/blob/version-3/CONTRIBUTING.md
#
# WARNING ABOUT GENERATED CODE

module Aws::AuditManager
  module Types

    # The wrapper of Amazon Web Services account details, such as account ID
    # or email address.
    #
    # @!attribute [rw] id
    #   The identifier for the Amazon Web Services account.
    #   @return [String]
    #
    # @!attribute [rw] email_address
    #   The email address that's associated with the Amazon Web Services
    #   account.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the Amazon Web Services account.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AWSAccount AWS API Documentation
    #
    class AWSAccount < Struct.new(
      :id,
      :email_address,
      :name)
      SENSITIVE = [:email_address]
      include Aws::Structure
    end

    # An Amazon Web Service such as Amazon S3 or CloudTrail.
    #
    # For an example of how to find an Amazon Web Service name and how to
    # define it in your assessment scope, see the following:
    #
    # * [Finding an Amazon Web Service name to use in your assessment
    #   scope][1]
    #
    # * [Defining an Amazon Web Service name in your assessment scope][2]
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_GetServicesInScope.html#API_GetServicesInScope_Example_2
    # [2]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_GetServicesInScope.html#API_GetServicesInScope_Example_3
    #
    # @!attribute [rw] service_name
    #   The name of the Amazon Web Service.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AWSService AWS API Documentation
    #
    class AWSService < Struct.new(
      :service_name)
      SENSITIVE = []
      include Aws::Structure
    end

    # Your account isn't registered with Audit Manager. Check the delegated
    # administrator setup on the Audit Manager settings page, and try again.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AccessDeniedException AWS API Documentation
    #
    class AccessDeniedException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # An entity that defines the scope of audit evidence collected by Audit
    # Manager. An Audit Manager assessment is an implementation of an Audit
    # Manager framework.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] aws_account
    #   The Amazon Web Services account that's associated with the
    #   assessment.
    #   @return [Types::AWSAccount]
    #
    # @!attribute [rw] metadata
    #   The metadata for the assessment.
    #   @return [Types::AssessmentMetadata]
    #
    # @!attribute [rw] framework
    #   The framework that the assessment was created from.
    #   @return [Types::AssessmentFramework]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the assessment.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Assessment AWS API Documentation
    #
    class Assessment < Struct.new(
      :arn,
      :aws_account,
      :metadata,
      :framework,
      :tags)
      SENSITIVE = [:framework]
      include Aws::Structure
    end

    # The control entity that represents a standard control or a custom
    # control in an Audit Manager assessment.
    #
    # @!attribute [rw] id
    #   The identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the control.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The status of the control.
    #   @return [String]
    #
    # @!attribute [rw] response
    #   The response of the control.
    #   @return [String]
    #
    # @!attribute [rw] comments
    #   The list of comments that's attached to the control.
    #   @return [Array<Types::ControlComment>]
    #
    # @!attribute [rw] evidence_sources
    #   The list of data sources for the evidence.
    #   @return [Array<String>]
    #
    # @!attribute [rw] evidence_count
    #   The amount of evidence that's collected for the control.
    #   @return [Integer]
    #
    # @!attribute [rw] assessment_report_evidence_count
    #   The amount of evidence in the assessment report.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentControl AWS API Documentation
    #
    class AssessmentControl < Struct.new(
      :id,
      :name,
      :description,
      :status,
      :response,
      :comments,
      :evidence_sources,
      :evidence_count,
      :assessment_report_evidence_count)
      SENSITIVE = [:description]
      include Aws::Structure
    end

    # Represents a set of controls in an Audit Manager assessment.
    #
    # @!attribute [rw] id
    #   The identifier of the control set in the assessment. This is the
    #   control set name in a plain string format.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description for the control set.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the control set.
    #   @return [String]
    #
    # @!attribute [rw] roles
    #   The roles that are associated with the control set.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] controls
    #   The list of controls that's contained with the control set.
    #   @return [Array<Types::AssessmentControl>]
    #
    # @!attribute [rw] delegations
    #   The delegations that are associated with the control set.
    #   @return [Array<Types::Delegation>]
    #
    # @!attribute [rw] system_evidence_count
    #   The total number of evidence objects that are retrieved
    #   automatically for the control set.
    #   @return [Integer]
    #
    # @!attribute [rw] manual_evidence_count
    #   The total number of evidence objects that are uploaded manually to
    #   the control set.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentControlSet AWS API Documentation
    #
    class AssessmentControlSet < Struct.new(
      :id,
      :description,
      :status,
      :roles,
      :controls,
      :delegations,
      :system_evidence_count,
      :manual_evidence_count)
      SENSITIVE = [:roles, :delegations]
      include Aws::Structure
    end

    # The folder where Audit Manager stores evidence for an assessment.
    #
    # @!attribute [rw] name
    #   The name of the evidence folder.
    #   @return [String]
    #
    # @!attribute [rw] date
    #   The date when the first evidence was added to the evidence folder.
    #   @return [Time]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] data_source
    #   The Amazon Web Service that the evidence was collected from.
    #   @return [String]
    #
    # @!attribute [rw] author
    #   The name of the user who created the evidence folder.
    #   @return [String]
    #
    # @!attribute [rw] total_evidence
    #   The total amount of evidence in the evidence folder.
    #   @return [Integer]
    #
    # @!attribute [rw] assessment_report_selection_count
    #   The total count of evidence that's included in the assessment
    #   report.
    #   @return [Integer]
    #
    # @!attribute [rw] control_name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] evidence_resources_included_count
    #   The amount of evidence that's included in the evidence folder.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_by_type_configuration_data_count
    #   The number of evidence that falls under the configuration data
    #   category. This evidence is collected from configuration snapshots of
    #   other Amazon Web Services such as Amazon EC2, Amazon S3, or IAM.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_by_type_manual_count
    #   The number of evidence that falls under the manual category. This
    #   evidence is imported manually.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_by_type_compliance_check_count
    #   The number of evidence that falls under the compliance check
    #   category. This evidence is collected from Config or Security Hub.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_by_type_compliance_check_issues_count
    #   The total number of issues that were reported directly from Security
    #   Hub, Config, or both.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_by_type_user_activity_count
    #   The number of evidence that falls under the user activity category.
    #   This evidence is collected from CloudTrail logs.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_aws_service_source_count
    #   The total number of Amazon Web Services resources that were assessed
    #   to generate the evidence.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentEvidenceFolder AWS API Documentation
    #
    class AssessmentEvidenceFolder < Struct.new(
      :name,
      :date,
      :assessment_id,
      :control_set_id,
      :control_id,
      :id,
      :data_source,
      :author,
      :total_evidence,
      :assessment_report_selection_count,
      :control_name,
      :evidence_resources_included_count,
      :evidence_by_type_configuration_data_count,
      :evidence_by_type_manual_count,
      :evidence_by_type_compliance_check_count,
      :evidence_by_type_compliance_check_issues_count,
      :evidence_by_type_user_activity_count,
      :evidence_aws_service_source_count)
      SENSITIVE = []
      include Aws::Structure
    end

    # The file used to structure and automate Audit Manager assessments for
    # a given compliance standard.
    #
    # @!attribute [rw] id
    #   The unique identifier for the framework.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the framework.
    #   @return [String]
    #
    # @!attribute [rw] metadata
    #   The metadata of a framework, such as the name, ID, or description.
    #   @return [Types::FrameworkMetadata]
    #
    # @!attribute [rw] control_sets
    #   The control sets that are associated with the framework.
    #   @return [Array<Types::AssessmentControlSet>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentFramework AWS API Documentation
    #
    class AssessmentFramework < Struct.new(
      :id,
      :arn,
      :metadata,
      :control_sets)
      SENSITIVE = []
      include Aws::Structure
    end

    # The metadata that's associated with a standard framework or a custom
    # framework.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the framework.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the framework.
    #   @return [String]
    #
    # @!attribute [rw] type
    #   The framework type, such as a standard framework or a custom
    #   framework.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the framework.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the framework.
    #   @return [String]
    #
    # @!attribute [rw] logo
    #   The logo that's associated with the framework.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The compliance type that the new custom framework supports, such as
    #   CIS or HIPAA.
    #   @return [String]
    #
    # @!attribute [rw] controls_count
    #   The number of controls that are associated with the framework.
    #   @return [Integer]
    #
    # @!attribute [rw] control_sets_count
    #   The number of control sets that are associated with the framework.
    #   @return [Integer]
    #
    # @!attribute [rw] created_at
    #   The time when the framework was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated_at
    #   The time when the framework was most recently updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentFrameworkMetadata AWS API Documentation
    #
    class AssessmentFrameworkMetadata < Struct.new(
      :arn,
      :id,
      :type,
      :name,
      :description,
      :logo,
      :compliance_type,
      :controls_count,
      :control_sets_count,
      :created_at,
      :last_updated_at)
      SENSITIVE = [:compliance_type]
      include Aws::Structure
    end

    # Represents a share request for a custom framework in Audit Manager.
    #
    # @!attribute [rw] id
    #   The unique identifier for the share request.
    #   @return [String]
    #
    # @!attribute [rw] framework_id
    #   The unique identifier for the shared custom framework.
    #   @return [String]
    #
    # @!attribute [rw] framework_name
    #   The name of the custom framework that the share request is for.
    #   @return [String]
    #
    # @!attribute [rw] framework_description
    #   The description of the shared custom framework.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The status of the share request.
    #   @return [String]
    #
    # @!attribute [rw] source_account
    #   The Amazon Web Services account of the sender.
    #   @return [String]
    #
    # @!attribute [rw] destination_account
    #   The Amazon Web Services account of the recipient.
    #   @return [String]
    #
    # @!attribute [rw] destination_region
    #   The Amazon Web Services Region of the recipient.
    #   @return [String]
    #
    # @!attribute [rw] expiration_time
    #   The time when the share request expires.
    #   @return [Time]
    #
    # @!attribute [rw] creation_time
    #   The time when the share request was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated
    #   Specifies when the share request was last updated.
    #   @return [Time]
    #
    # @!attribute [rw] comment
    #   An optional comment from the sender about the share request.
    #   @return [String]
    #
    # @!attribute [rw] standard_controls_count
    #   The number of standard controls that are part of the shared custom
    #   framework.
    #   @return [Integer]
    #
    # @!attribute [rw] custom_controls_count
    #   The number of custom controls that are part of the shared custom
    #   framework.
    #   @return [Integer]
    #
    # @!attribute [rw] compliance_type
    #   The compliance type that the shared custom framework supports, such
    #   as CIS or HIPAA.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentFrameworkShareRequest AWS API Documentation
    #
    class AssessmentFrameworkShareRequest < Struct.new(
      :id,
      :framework_id,
      :framework_name,
      :framework_description,
      :status,
      :source_account,
      :destination_account,
      :destination_region,
      :expiration_time,
      :creation_time,
      :last_updated,
      :comment,
      :standard_controls_count,
      :custom_controls_count,
      :compliance_type)
      SENSITIVE = [:compliance_type]
      include Aws::Structure
    end

    # The metadata that's associated with the specified assessment.
    #
    # @!attribute [rw] name
    #   The name of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The name of the compliance standard that's related to the
    #   assessment, such as PCI-DSS.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The overall status of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_reports_destination
    #   The destination that evidence reports are stored in for the
    #   assessment.
    #   @return [Types::AssessmentReportsDestination]
    #
    # @!attribute [rw] scope
    #   The wrapper of Amazon Web Services accounts and services that are in
    #   scope for the assessment.
    #   @return [Types::Scope]
    #
    # @!attribute [rw] roles
    #   The roles that are associated with the assessment.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] delegations
    #   The delegations that are associated with the assessment.
    #   @return [Array<Types::Delegation>]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the assessment was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated
    #   The time of the most recent update.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentMetadata AWS API Documentation
    #
    class AssessmentMetadata < Struct.new(
      :name,
      :id,
      :description,
      :compliance_type,
      :status,
      :assessment_reports_destination,
      :scope,
      :roles,
      :delegations,
      :creation_time,
      :last_updated)
      SENSITIVE = [:name, :description, :compliance_type, :assessment_reports_destination, :scope, :roles, :delegations]
      include Aws::Structure
    end

    # A metadata object that's associated with an assessment in Audit
    # Manager.
    #
    # @!attribute [rw] name
    #   The name of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The name of the compliance standard that's related to the
    #   assessment, such as PCI-DSS.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] roles
    #   The roles that are associated with the assessment.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] delegations
    #   The delegations that are associated with the assessment.
    #   @return [Array<Types::Delegation>]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the assessment was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated
    #   The time of the most recent update.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentMetadataItem AWS API Documentation
    #
    class AssessmentMetadataItem < Struct.new(
      :name,
      :id,
      :compliance_type,
      :status,
      :roles,
      :delegations,
      :creation_time,
      :last_updated)
      SENSITIVE = [:name, :compliance_type, :roles, :delegations]
      include Aws::Structure
    end

    # A finalized document that's generated from an Audit Manager
    # assessment. These reports summarize the relevant evidence that was
    # collected for your audit, and link to the relevant evidence folders.
    # These evidence folders are named and organized according to the
    # controls that are specified in your assessment.
    #
    # @!attribute [rw] id
    #   The unique identifier for the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name that's given to the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the specified assessment report.
    #   @return [String]
    #
    # @!attribute [rw] aws_account_id
    #   The identifier for the specified Amazon Web Services account.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the specified assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the associated assessment.
    #   @return [String]
    #
    # @!attribute [rw] author
    #   The name of the user who created the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the specified assessment report.
    #   @return [String]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the assessment report was created.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentReport AWS API Documentation
    #
    class AssessmentReport < Struct.new(
      :id,
      :name,
      :description,
      :aws_account_id,
      :assessment_id,
      :assessment_name,
      :author,
      :status,
      :creation_time)
      SENSITIVE = [:description, :assessment_name, :author]
      include Aws::Structure
    end

    # An error entity for assessment report evidence errors. This is used to
    # provide more meaningful errors than a simple string message.
    #
    # @!attribute [rw] evidence_id
    #   The identifier for the evidence.
    #   @return [String]
    #
    # @!attribute [rw] error_code
    #   The error code that was returned.
    #   @return [String]
    #
    # @!attribute [rw] error_message
    #   The error message that was returned.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentReportEvidenceError AWS API Documentation
    #
    class AssessmentReportEvidenceError < Struct.new(
      :evidence_id,
      :error_code,
      :error_message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The metadata objects that are associated with the specified assessment
    # report.
    #
    # @!attribute [rw] id
    #   The unique identifier for the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The unique identifier for the associated assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the associated assessment.
    #   @return [String]
    #
    # @!attribute [rw] author
    #   The name of the user who created the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the assessment report was created.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentReportMetadata AWS API Documentation
    #
    class AssessmentReportMetadata < Struct.new(
      :id,
      :name,
      :description,
      :assessment_id,
      :assessment_name,
      :author,
      :status,
      :creation_time)
      SENSITIVE = [:description, :assessment_name, :author]
      include Aws::Structure
    end

    # The location where Audit Manager saves assessment reports for the
    # given assessment.
    #
    # @!attribute [rw] destination_type
    #   The destination type, such as Amazon S3.
    #   @return [String]
    #
    # @!attribute [rw] destination
    #   The destination bucket where Audit Manager stores assessment
    #   reports.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssessmentReportsDestination AWS API Documentation
    #
    class AssessmentReportsDestination < Struct.new(
      :destination_type,
      :destination)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssociateAssessmentReportEvidenceFolderRequest AWS API Documentation
    #
    class AssociateAssessmentReportEvidenceFolderRequest < Struct.new(
      :assessment_id,
      :evidence_folder_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/AssociateAssessmentReportEvidenceFolderResponse AWS API Documentation
    #
    class AssociateAssessmentReportEvidenceFolderResponse < Aws::EmptyStructure; end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] evidence_ids
    #   The list of evidence identifiers.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchAssociateAssessmentReportEvidenceRequest AWS API Documentation
    #
    class BatchAssociateAssessmentReportEvidenceRequest < Struct.new(
      :assessment_id,
      :evidence_folder_id,
      :evidence_ids)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence_ids
    #   The list of evidence identifiers.
    #   @return [Array<String>]
    #
    # @!attribute [rw] errors
    #   A list of errors that the `BatchAssociateAssessmentReportEvidence`
    #   API returned.
    #   @return [Array<Types::AssessmentReportEvidenceError>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchAssociateAssessmentReportEvidenceResponse AWS API Documentation
    #
    class BatchAssociateAssessmentReportEvidenceResponse < Struct.new(
      :evidence_ids,
      :errors)
      SENSITIVE = []
      include Aws::Structure
    end

    # An error entity for the `BatchCreateDelegationByAssessment` API. This
    # is used to provide more meaningful errors than a simple string
    # message.
    #
    # @!attribute [rw] create_delegation_request
    #   The API request to batch create delegations in Audit Manager.
    #   @return [Types::CreateDelegationRequest]
    #
    # @!attribute [rw] error_code
    #   The error code that the `BatchCreateDelegationByAssessment` API
    #   returned.
    #   @return [String]
    #
    # @!attribute [rw] error_message
    #   The error message that the `BatchCreateDelegationByAssessment` API
    #   returned.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchCreateDelegationByAssessmentError AWS API Documentation
    #
    class BatchCreateDelegationByAssessmentError < Struct.new(
      :create_delegation_request,
      :error_code,
      :error_message)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] create_delegation_requests
    #   The API request to batch create delegations in Audit Manager.
    #   @return [Array<Types::CreateDelegationRequest>]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchCreateDelegationByAssessmentRequest AWS API Documentation
    #
    class BatchCreateDelegationByAssessmentRequest < Struct.new(
      :create_delegation_requests,
      :assessment_id)
      SENSITIVE = [:create_delegation_requests]
      include Aws::Structure
    end

    # @!attribute [rw] delegations
    #   The delegations that are associated with the assessment.
    #   @return [Array<Types::Delegation>]
    #
    # @!attribute [rw] errors
    #   A list of errors that the `BatchCreateDelegationByAssessment` API
    #   returned.
    #   @return [Array<Types::BatchCreateDelegationByAssessmentError>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchCreateDelegationByAssessmentResponse AWS API Documentation
    #
    class BatchCreateDelegationByAssessmentResponse < Struct.new(
      :delegations,
      :errors)
      SENSITIVE = [:delegations, :errors]
      include Aws::Structure
    end

    # An error entity for the `BatchDeleteDelegationByAssessment` API. This
    # is used to provide more meaningful errors than a simple string
    # message.
    #
    # @!attribute [rw] delegation_id
    #   The identifier for the delegation.
    #   @return [String]
    #
    # @!attribute [rw] error_code
    #   The error code that the `BatchDeleteDelegationByAssessment` API
    #   returned.
    #   @return [String]
    #
    # @!attribute [rw] error_message
    #   The error message that the `BatchDeleteDelegationByAssessment` API
    #   returned.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchDeleteDelegationByAssessmentError AWS API Documentation
    #
    class BatchDeleteDelegationByAssessmentError < Struct.new(
      :delegation_id,
      :error_code,
      :error_message)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] delegation_ids
    #   The identifiers for the delegations.
    #   @return [Array<String>]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchDeleteDelegationByAssessmentRequest AWS API Documentation
    #
    class BatchDeleteDelegationByAssessmentRequest < Struct.new(
      :delegation_ids,
      :assessment_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] errors
    #   A list of errors that the `BatchDeleteDelegationByAssessment` API
    #   returned.
    #   @return [Array<Types::BatchDeleteDelegationByAssessmentError>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchDeleteDelegationByAssessmentResponse AWS API Documentation
    #
    class BatchDeleteDelegationByAssessmentResponse < Struct.new(
      :errors)
      SENSITIVE = [:errors]
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] evidence_ids
    #   The list of evidence identifiers.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchDisassociateAssessmentReportEvidenceRequest AWS API Documentation
    #
    class BatchDisassociateAssessmentReportEvidenceRequest < Struct.new(
      :assessment_id,
      :evidence_folder_id,
      :evidence_ids)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence_ids
    #   The identifier for the evidence.
    #   @return [Array<String>]
    #
    # @!attribute [rw] errors
    #   A list of errors that the
    #   `BatchDisassociateAssessmentReportEvidence` API returned.
    #   @return [Array<Types::AssessmentReportEvidenceError>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchDisassociateAssessmentReportEvidenceResponse AWS API Documentation
    #
    class BatchDisassociateAssessmentReportEvidenceResponse < Struct.new(
      :evidence_ids,
      :errors)
      SENSITIVE = []
      include Aws::Structure
    end

    # An error entity for the `BatchImportEvidenceToAssessmentControl` API.
    # This is used to provide more meaningful errors than a simple string
    # message.
    #
    # @!attribute [rw] manual_evidence
    #   Manual evidence that can't be collected automatically by Audit
    #   Manager.
    #   @return [Types::ManualEvidence]
    #
    # @!attribute [rw] error_code
    #   The error code that the `BatchImportEvidenceToAssessmentControl` API
    #   returned.
    #   @return [String]
    #
    # @!attribute [rw] error_message
    #   The error message that the `BatchImportEvidenceToAssessmentControl`
    #   API returned.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchImportEvidenceToAssessmentControlError AWS API Documentation
    #
    class BatchImportEvidenceToAssessmentControlError < Struct.new(
      :manual_evidence,
      :error_code,
      :error_message)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_id
    #   The identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] manual_evidence
    #   The list of manual evidence objects.
    #   @return [Array<Types::ManualEvidence>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchImportEvidenceToAssessmentControlRequest AWS API Documentation
    #
    class BatchImportEvidenceToAssessmentControlRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :control_id,
      :manual_evidence)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] errors
    #   A list of errors that the `BatchImportEvidenceToAssessmentControl`
    #   API returned.
    #   @return [Array<Types::BatchImportEvidenceToAssessmentControlError>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/BatchImportEvidenceToAssessmentControlResponse AWS API Documentation
    #
    class BatchImportEvidenceToAssessmentControlResponse < Struct.new(
      :errors)
      SENSITIVE = []
      include Aws::Structure
    end

    # The record of a change within Audit Manager. For example, this could
    # be the status change of an assessment or the delegation of a control
    # set.
    #
    # @!attribute [rw] object_type
    #   The object that was changed, such as an assessment, control, or
    #   control set.
    #   @return [String]
    #
    # @!attribute [rw] object_name
    #   The name of the object that changed. This could be the name of an
    #   assessment, control, or control set.
    #   @return [String]
    #
    # @!attribute [rw] action
    #   The action that was performed.
    #   @return [String]
    #
    # @!attribute [rw] created_at
    #   The time when the action was performed and the changelog record was
    #   created.
    #   @return [Time]
    #
    # @!attribute [rw] created_by
    #   The user or role that performed the action.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ChangeLog AWS API Documentation
    #
    class ChangeLog < Struct.new(
      :object_type,
      :object_name,
      :action,
      :created_at,
      :created_by)
      SENSITIVE = []
      include Aws::Structure
    end

    # A control in Audit Manager.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the control.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] type
    #   Specifies whether the control is a standard control or a custom
    #   control.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the control.
    #   @return [String]
    #
    # @!attribute [rw] testing_information
    #   The steps that you should follow to determine if the control has
    #   been satisfied.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_title
    #   The title of the action plan for remediating the control.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_instructions
    #   The recommended actions to carry out if the control isn't
    #   fulfilled.
    #   @return [String]
    #
    # @!attribute [rw] control_sources
    #   The data source types that determine where Audit Manager collects
    #   evidence from for the control.
    #   @return [String]
    #
    # @!attribute [rw] control_mapping_sources
    #   The data mapping sources for the control.
    #   @return [Array<Types::ControlMappingSource>]
    #
    # @!attribute [rw] created_at
    #   The time when the control was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated_at
    #   The time when the control was most recently updated.
    #   @return [Time]
    #
    # @!attribute [rw] created_by
    #   The user or role that created the control.
    #   @return [String]
    #
    # @!attribute [rw] last_updated_by
    #   The user or role that most recently updated the control.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   The tags associated with the control.
    #   @return [Hash<String,String>]
    #
    # @!attribute [rw] state
    #   The state of the control. The `END_OF_SUPPORT` state is applicable
    #   to standard controls only. This state indicates that the standard
    #   control can still be used to collect evidence, but Audit Manager is
    #   no longer updating or maintaining that control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Control AWS API Documentation
    #
    class Control < Struct.new(
      :arn,
      :id,
      :type,
      :name,
      :description,
      :testing_information,
      :action_plan_title,
      :action_plan_instructions,
      :control_sources,
      :control_mapping_sources,
      :created_at,
      :last_updated_at,
      :created_by,
      :last_updated_by,
      :tags,
      :state)
      SENSITIVE = [:description, :testing_information, :action_plan_title, :action_plan_instructions, :created_by, :last_updated_by]
      include Aws::Structure
    end

    # A comment that's posted by a user on a control. This includes the
    # author's name, the comment text, and a timestamp.
    #
    # @!attribute [rw] author_name
    #   The name of the user who authored the comment.
    #   @return [String]
    #
    # @!attribute [rw] comment_body
    #   The body text of a control comment.
    #   @return [String]
    #
    # @!attribute [rw] posted_date
    #   The time when the comment was posted.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlComment AWS API Documentation
    #
    class ControlComment < Struct.new(
      :author_name,
      :comment_body,
      :posted_date)
      SENSITIVE = [:author_name, :comment_body]
      include Aws::Structure
    end

    # A summary of the latest analytics data for a specific control domain.
    #
    # Control domain insights are grouped by control domain, and ranked by
    # the highest total count of non-compliant evidence.
    #
    # @!attribute [rw] name
    #   The name of the control domain.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the control domain. Audit Manager supports
    #   the control domains that are provided by Amazon Web Services Control
    #   Catalog. For information about how to find a list of available
    #   control domains, see [ `ListDomains` ][1] in the Amazon Web Services
    #   Control Catalog API Reference.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListDomains.html
    #   @return [String]
    #
    # @!attribute [rw] controls_count_by_noncompliant_evidence
    #   The number of controls in the control domain that collected
    #   non-compliant evidence on the `lastUpdated` date.
    #   @return [Integer]
    #
    # @!attribute [rw] total_controls_count
    #   The total number of controls in the control domain.
    #   @return [Integer]
    #
    # @!attribute [rw] evidence_insights
    #   A breakdown of the compliance check status for the evidence that’s
    #   associated with the control domain.
    #   @return [Types::EvidenceInsights]
    #
    # @!attribute [rw] last_updated
    #   The time when the control domain insights were last updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlDomainInsights AWS API Documentation
    #
    class ControlDomainInsights < Struct.new(
      :name,
      :id,
      :controls_count_by_noncompliant_evidence,
      :total_controls_count,
      :evidence_insights,
      :last_updated)
      SENSITIVE = []
      include Aws::Structure
    end

    # A summary of the latest analytics data for a specific control in a
    # specific active assessment.
    #
    # Control insights are grouped by control domain, and ranked by the
    # highest total count of non-compliant evidence.
    #
    # @!attribute [rw] name
    #   The name of the assessment control.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the assessment control.
    #   @return [String]
    #
    # @!attribute [rw] evidence_insights
    #   A breakdown of the compliance check status for the evidence that’s
    #   associated with the assessment control.
    #   @return [Types::EvidenceInsights]
    #
    # @!attribute [rw] control_set_name
    #   The name of the control set that the assessment control belongs to.
    #   @return [String]
    #
    # @!attribute [rw] last_updated
    #   The time when the assessment control insights were last updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlInsightsMetadataByAssessmentItem AWS API Documentation
    #
    class ControlInsightsMetadataByAssessmentItem < Struct.new(
      :name,
      :id,
      :evidence_insights,
      :control_set_name,
      :last_updated)
      SENSITIVE = []
      include Aws::Structure
    end

    # A summary of the latest analytics data for a specific control.
    #
    # This data reflects the total counts for the specified control across
    # all active assessments. Control insights are grouped by control
    # domain, and ranked by the highest total count of non-compliant
    # evidence.
    #
    # @!attribute [rw] name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] evidence_insights
    #   A breakdown of the compliance check status for the evidence that’s
    #   associated with the control.
    #   @return [Types::EvidenceInsights]
    #
    # @!attribute [rw] last_updated
    #   The time when the control insights were last updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlInsightsMetadataItem AWS API Documentation
    #
    class ControlInsightsMetadataItem < Struct.new(
      :name,
      :id,
      :evidence_insights,
      :last_updated)
      SENSITIVE = []
      include Aws::Structure
    end

    # The data source that determines where Audit Manager collects evidence
    # from for the control.
    #
    # @!attribute [rw] source_id
    #   The unique identifier for the source.
    #   @return [String]
    #
    # @!attribute [rw] source_name
    #   The name of the source.
    #   @return [String]
    #
    # @!attribute [rw] source_description
    #   The description of the source.
    #   @return [String]
    #
    # @!attribute [rw] source_set_up_option
    #   The setup option for the data source. This option reflects if the
    #   evidence collection method is automated or manual. If you don’t
    #   provide a value for `sourceSetUpOption`, Audit Manager automatically
    #   infers and populates the correct value based on the `sourceType`
    #   that you specify.
    #   @return [String]
    #
    # @!attribute [rw] source_type
    #   Specifies which type of data source is used to collect evidence.
    #
    #   * The source can be an individual data source type, such as
    #     `AWS_Cloudtrail`, `AWS_Config`, `AWS_Security_Hub`,
    #     `AWS_API_Call`, or `MANUAL`.
    #
    #   * The source can also be a managed grouping of data sources, such as
    #     a `Core_Control` or a `Common_Control`.
    #   @return [String]
    #
    # @!attribute [rw] source_keyword
    #   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*:
    #
    #   * [Config rules supported by Audit Manager][1]
    #
    #   * [Security Hub controls supported by Audit Manager][2]
    #
    #   * [API calls supported by Audit Manager][3]
    #
    #   * [CloudTrail event names supported by Audit Manager][4]
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-config.html
    #   [2]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-ash.html
    #   [3]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-api.html
    #   [4]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-cloudtrail.html
    #   @return [Types::SourceKeyword]
    #
    # @!attribute [rw] source_frequency
    #   Specifies how often evidence is collected from the control mapping
    #   source.
    #   @return [String]
    #
    # @!attribute [rw] troubleshooting_text
    #   The instructions for troubleshooting the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlMappingSource AWS API Documentation
    #
    class ControlMappingSource < Struct.new(
      :source_id,
      :source_name,
      :source_description,
      :source_set_up_option,
      :source_type,
      :source_keyword,
      :source_frequency,
      :troubleshooting_text)
      SENSITIVE = [:troubleshooting_text]
      include Aws::Structure
    end

    # The metadata that's associated with the standard control or custom
    # control.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the control.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] control_sources
    #   The data source that determines where Audit Manager collects
    #   evidence from for the control.
    #   @return [String]
    #
    # @!attribute [rw] created_at
    #   The time when the control was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated_at
    #   The time when the control was most recently updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlMetadata AWS API Documentation
    #
    class ControlMetadata < Struct.new(
      :arn,
      :id,
      :name,
      :control_sources,
      :created_at,
      :last_updated_at)
      SENSITIVE = []
      include Aws::Structure
    end

    # A set of controls in Audit Manager.
    #
    # @!attribute [rw] id
    #   The identifier of the control set in the assessment. This is the
    #   control set name in a plain string format.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the control set.
    #   @return [String]
    #
    # @!attribute [rw] controls
    #   The list of controls within the control set.
    #   @return [Array<Types::Control>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ControlSet AWS API Documentation
    #
    class ControlSet < Struct.new(
      :id,
      :name,
      :controls)
      SENSITIVE = []
      include Aws::Structure
    end

    # The control entity attributes that uniquely identify an existing
    # control to be added to a framework in Audit Manager.
    #
    # @!attribute [rw] id
    #   The unique identifier of the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentFrameworkControl AWS API Documentation
    #
    class CreateAssessmentFrameworkControl < Struct.new(
      :id)
      SENSITIVE = []
      include Aws::Structure
    end

    # A `controlSet` entity that represents a collection of controls in
    # Audit Manager. This doesn't contain the control set ID.
    #
    # @!attribute [rw] name
    #   The name of the control set.
    #   @return [String]
    #
    # @!attribute [rw] controls
    #   The list of controls within the control set. This doesn't contain
    #   the control set ID.
    #   @return [Array<Types::CreateAssessmentFrameworkControl>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentFrameworkControlSet AWS API Documentation
    #
    class CreateAssessmentFrameworkControlSet < Struct.new(
      :name,
      :controls)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the new custom framework.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   An optional description for the new custom framework.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The compliance type that the new custom framework supports, such as
    #   CIS or HIPAA.
    #   @return [String]
    #
    # @!attribute [rw] control_sets
    #   The control sets that are associated with the framework.
    #   @return [Array<Types::CreateAssessmentFrameworkControlSet>]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the framework.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentFrameworkRequest AWS API Documentation
    #
    class CreateAssessmentFrameworkRequest < Struct.new(
      :name,
      :description,
      :compliance_type,
      :control_sets,
      :tags)
      SENSITIVE = [:compliance_type]
      include Aws::Structure
    end

    # @!attribute [rw] framework
    #   The name of the new framework that the `CreateAssessmentFramework`
    #   API returned.
    #   @return [Types::Framework]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentFrameworkResponse AWS API Documentation
    #
    class CreateAssessmentFrameworkResponse < Struct.new(
      :framework)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the new assessment report.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] query_statement
    #   A SQL statement that represents an evidence finder query.
    #
    #   Provide this parameter when you want to generate an assessment
    #   report from the results of an evidence finder search query. When you
    #   use this parameter, Audit Manager generates a one-time report using
    #   only the evidence from the query output. This report does not
    #   include any assessment evidence that was manually [added to a report
    #   using the console][1], or [associated with a report using the
    #   API][2].
    #
    #   To use this parameter, the [enablementStatus][3] of evidence finder
    #   must be `ENABLED`.
    #
    #   For examples and help resolving `queryStatement` validation
    #   exceptions, see [Troubleshooting evidence finder issues][4] in the
    #   *Audit Manager User Guide.*
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/userguide/generate-assessment-report.html#generate-assessment-report-include-evidence
    #   [2]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_BatchAssociateAssessmentReportEvidence.html
    #   [3]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_EvidenceFinderEnablement.html#auditmanager-Type-EvidenceFinderEnablement-enablementStatus
    #   [4]: https://docs.aws.amazon.com/audit-manager/latest/userguide/evidence-finder-issues.html#querystatement-exceptions
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentReportRequest AWS API Documentation
    #
    class CreateAssessmentReportRequest < Struct.new(
      :name,
      :description,
      :assessment_id,
      :query_statement)
      SENSITIVE = [:description]
      include Aws::Structure
    end

    # @!attribute [rw] assessment_report
    #   The new assessment report that the `CreateAssessmentReport` API
    #   returned.
    #   @return [Types::AssessmentReport]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentReportResponse AWS API Documentation
    #
    class CreateAssessmentReportResponse < Struct.new(
      :assessment_report)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the assessment to be created.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The optional description of the assessment to be created.
    #   @return [String]
    #
    # @!attribute [rw] assessment_reports_destination
    #   The assessment report storage destination for the assessment that's
    #   being created.
    #   @return [Types::AssessmentReportsDestination]
    #
    # @!attribute [rw] scope
    #   The wrapper that contains the Amazon Web Services accounts that are
    #   in scope for the assessment.
    #
    #   <note markdown="1"> You no longer need to specify which Amazon Web Services are in scope
    #   when you create or update an assessment. Audit Manager infers the
    #   services in scope by examining your assessment controls and their
    #   data sources, and then mapping this information to the relevant
    #   Amazon Web Services.
    #
    #    If an underlying data source changes for your assessment, we
    #   automatically update the services scope as needed to reflect the
    #   correct Amazon Web Services. This ensures that your assessment
    #   collects accurate and comprehensive evidence about all of the
    #   relevant services in your AWS environment.
    #
    #    </note>
    #   @return [Types::Scope]
    #
    # @!attribute [rw] roles
    #   The list of roles for the assessment.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] framework_id
    #   The identifier for the framework that the assessment will be created
    #   from.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the assessment.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentRequest AWS API Documentation
    #
    class CreateAssessmentRequest < Struct.new(
      :name,
      :description,
      :assessment_reports_destination,
      :scope,
      :roles,
      :framework_id,
      :tags)
      SENSITIVE = [:name, :description, :assessment_reports_destination, :scope, :roles]
      include Aws::Structure
    end

    # @!attribute [rw] assessment
    #   An entity that defines the scope of audit evidence collected by
    #   Audit Manager. An Audit Manager assessment is an implementation of
    #   an Audit Manager framework.
    #   @return [Types::Assessment]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateAssessmentResponse AWS API Documentation
    #
    class CreateAssessmentResponse < Struct.new(
      :assessment)
      SENSITIVE = []
      include Aws::Structure
    end

    # The mapping attributes that determine the evidence source for a given
    # control, along with related parameters and metadata. This doesn't
    # contain `mappingID`.
    #
    # @!attribute [rw] source_name
    #   The name of the control mapping data source.
    #   @return [String]
    #
    # @!attribute [rw] source_description
    #   The description of the data source that determines where Audit
    #   Manager collects evidence from for the control.
    #   @return [String]
    #
    # @!attribute [rw] source_set_up_option
    #   The setup option for the data source. This option reflects if the
    #   evidence collection method is automated or manual. If you don’t
    #   provide a value for `sourceSetUpOption`, Audit Manager automatically
    #   infers and populates the correct value based on the `sourceType`
    #   that you specify.
    #   @return [String]
    #
    # @!attribute [rw] source_type
    #   Specifies which type of data source is used to collect evidence.
    #
    #   * The source can be an individual data source type, such as
    #     `AWS_Cloudtrail`, `AWS_Config`, `AWS_Security_Hub`,
    #     `AWS_API_Call`, or `MANUAL`.
    #
    #   * The source can also be a managed grouping of data sources, such as
    #     a `Core_Control` or a `Common_Control`.
    #   @return [String]
    #
    # @!attribute [rw] source_keyword
    #   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*:
    #
    #   * [Config rules supported by Audit Manager][1]
    #
    #   * [Security Hub controls supported by Audit Manager][2]
    #
    #   * [API calls supported by Audit Manager][3]
    #
    #   * [CloudTrail event names supported by Audit Manager][4]
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-config.html
    #   [2]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-ash.html
    #   [3]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-api.html
    #   [4]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-cloudtrail.html
    #   @return [Types::SourceKeyword]
    #
    # @!attribute [rw] source_frequency
    #   Specifies how often evidence is collected from the control mapping
    #   source.
    #   @return [String]
    #
    # @!attribute [rw] troubleshooting_text
    #   The instructions for troubleshooting the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateControlMappingSource AWS API Documentation
    #
    class CreateControlMappingSource < Struct.new(
      :source_name,
      :source_description,
      :source_set_up_option,
      :source_type,
      :source_keyword,
      :source_frequency,
      :troubleshooting_text)
      SENSITIVE = [:troubleshooting_text]
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the control.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the control.
    #   @return [String]
    #
    # @!attribute [rw] testing_information
    #   The steps to follow to determine if the control is satisfied.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_title
    #   The title of the action plan for remediating the control.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_instructions
    #   The recommended actions to carry out if the control isn't
    #   fulfilled.
    #   @return [String]
    #
    # @!attribute [rw] control_mapping_sources
    #   The data mapping sources for the control.
    #   @return [Array<Types::CreateControlMappingSource>]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the control.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateControlRequest AWS API Documentation
    #
    class CreateControlRequest < Struct.new(
      :name,
      :description,
      :testing_information,
      :action_plan_title,
      :action_plan_instructions,
      :control_mapping_sources,
      :tags)
      SENSITIVE = [:description, :testing_information, :action_plan_title, :action_plan_instructions]
      include Aws::Structure
    end

    # @!attribute [rw] control
    #   The new control that the `CreateControl` API returned.
    #   @return [Types::Control]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateControlResponse AWS API Documentation
    #
    class CreateControlResponse < Struct.new(
      :control)
      SENSITIVE = []
      include Aws::Structure
    end

    # A collection of attributes that's used to create a delegation for an
    # assessment in Audit Manager.
    #
    # @!attribute [rw] comment
    #   A comment that's related to the delegation request.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] role_arn
    #   The Amazon Resource Name (ARN) of the IAM role.
    #   @return [String]
    #
    # @!attribute [rw] role_type
    #   The type of customer persona.
    #
    #   <note markdown="1"> In `CreateAssessment`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `UpdateSettings`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `BatchCreateDelegationByAssessment`, `roleType` can only be
    #   `RESOURCE_OWNER`.
    #
    #    </note>
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/CreateDelegationRequest AWS API Documentation
    #
    class CreateDelegationRequest < Struct.new(
      :comment,
      :control_set_id,
      :role_arn,
      :role_type)
      SENSITIVE = [:comment]
      include Aws::Structure
    end

    # The default s3 bucket where Audit Manager saves the files that you
    # export from evidence finder.
    #
    # @!attribute [rw] destination_type
    #   The destination type, such as Amazon S3.
    #   @return [String]
    #
    # @!attribute [rw] destination
    #   The destination bucket where Audit Manager stores exported files.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DefaultExportDestination AWS API Documentation
    #
    class DefaultExportDestination < Struct.new(
      :destination_type,
      :destination)
      SENSITIVE = []
      include Aws::Structure
    end

    # The assignment of a control set to a delegate for review.
    #
    # @!attribute [rw] id
    #   The unique identifier for the delegation.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the assessment that's associated with the delegation.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment that's associated with the
    #   delegation.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The status of the delegation.
    #   @return [String]
    #
    # @!attribute [rw] role_arn
    #   The Amazon Resource Name (ARN) of the IAM role.
    #   @return [String]
    #
    # @!attribute [rw] role_type
    #   The type of customer persona.
    #
    #   <note markdown="1"> In `CreateAssessment`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `UpdateSettings`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `BatchCreateDelegationByAssessment`, `roleType` can only be
    #   `RESOURCE_OWNER`.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the delegation was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated
    #   Specifies when the delegation was last updated.
    #   @return [Time]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set that's associated with the
    #   delegation.
    #   @return [String]
    #
    # @!attribute [rw] comment
    #   The comment that's related to the delegation.
    #   @return [String]
    #
    # @!attribute [rw] created_by
    #   The user or role that created the delegation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Delegation AWS API Documentation
    #
    class Delegation < Struct.new(
      :id,
      :assessment_name,
      :assessment_id,
      :status,
      :role_arn,
      :role_type,
      :creation_time,
      :last_updated,
      :control_set_id,
      :comment,
      :created_by)
      SENSITIVE = [:assessment_name, :comment, :created_by]
      include Aws::Structure
    end

    # The metadata that's associated with the delegation.
    #
    # @!attribute [rw] id
    #   The unique identifier for the delegation.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the associated assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the delegation.
    #   @return [String]
    #
    # @!attribute [rw] role_arn
    #   The Amazon Resource Name (ARN) of the IAM role.
    #   @return [String]
    #
    # @!attribute [rw] creation_time
    #   Specifies when the delegation was created.
    #   @return [Time]
    #
    # @!attribute [rw] control_set_name
    #   Specifies the name of the control set that was delegated for review.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DelegationMetadata AWS API Documentation
    #
    class DelegationMetadata < Struct.new(
      :id,
      :assessment_name,
      :assessment_id,
      :status,
      :role_arn,
      :creation_time,
      :control_set_name)
      SENSITIVE = [:assessment_name]
      include Aws::Structure
    end

    # @!attribute [rw] framework_id
    #   The identifier for the custom framework.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentFrameworkRequest AWS API Documentation
    #
    class DeleteAssessmentFrameworkRequest < Struct.new(
      :framework_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentFrameworkResponse AWS API Documentation
    #
    class DeleteAssessmentFrameworkResponse < Aws::EmptyStructure; end

    # @!attribute [rw] request_id
    #   The unique identifier for the share request to be deleted.
    #   @return [String]
    #
    # @!attribute [rw] request_type
    #   Specifies whether the share request is a sent request or a received
    #   request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentFrameworkShareRequest AWS API Documentation
    #
    class DeleteAssessmentFrameworkShareRequest < Struct.new(
      :request_id,
      :request_type)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentFrameworkShareResponse AWS API Documentation
    #
    class DeleteAssessmentFrameworkShareResponse < Aws::EmptyStructure; end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_report_id
    #   The unique identifier for the assessment report.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentReportRequest AWS API Documentation
    #
    class DeleteAssessmentReportRequest < Struct.new(
      :assessment_id,
      :assessment_report_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentReportResponse AWS API Documentation
    #
    class DeleteAssessmentReportResponse < Aws::EmptyStructure; end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentRequest AWS API Documentation
    #
    class DeleteAssessmentRequest < Struct.new(
      :assessment_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteAssessmentResponse AWS API Documentation
    #
    class DeleteAssessmentResponse < Aws::EmptyStructure; end

    # @!attribute [rw] control_id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteControlRequest AWS API Documentation
    #
    class DeleteControlRequest < Struct.new(
      :control_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeleteControlResponse AWS API Documentation
    #
    class DeleteControlResponse < Aws::EmptyStructure; end

    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeregisterAccountRequest AWS API Documentation
    #
    class DeregisterAccountRequest < Aws::EmptyStructure; end

    # @!attribute [rw] status
    #   The registration status of the account.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeregisterAccountResponse AWS API Documentation
    #
    class DeregisterAccountResponse < Struct.new(
      :status)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] admin_account_id
    #   The identifier for the administrator account.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeregisterOrganizationAdminAccountRequest AWS API Documentation
    #
    class DeregisterOrganizationAdminAccountRequest < Struct.new(
      :admin_account_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeregisterOrganizationAdminAccountResponse AWS API Documentation
    #
    class DeregisterOrganizationAdminAccountResponse < Aws::EmptyStructure; end

    # The deregistration policy for the data that's stored in Audit
    # Manager. You can use this attribute to determine how your data is
    # handled when you [deregister Audit Manager][1].
    #
    # By default, Audit Manager retains evidence data for two years from the
    # time of its creation. Other Audit Manager resources (including
    # assessments, custom controls, and custom frameworks) remain in Audit
    # Manager indefinitely, and are available if you [re-register Audit
    # Manager][2] in the future. For more information about data retention,
    # see [Data Protection][3] in the *Audit Manager User Guide*.
    #
    # If you choose to delete all data, this action permanently deletes all
    # evidence data in your account within seven days. It also deletes all
    # of the Audit Manager resources that you created, including
    # assessments, custom controls, and custom frameworks. Your data will
    # not be available if you re-register Audit Manager in the future.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_DeregisterAccount.html
    # [2]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_RegisterAccount.html
    # [3]: https://docs.aws.amazon.com/audit-manager/latest/userguide/data-protection.html
    #
    # @!attribute [rw] delete_resources
    #   Specifies which Audit Manager data will be deleted when you
    #   deregister Audit Manager.
    #
    #   * If you set the value to `ALL`, all of your data is deleted within
    #     seven days of deregistration.
    #
    #   * If you set the value to `DEFAULT`, none of your data is deleted at
    #     the time of deregistration. However, keep in mind that the Audit
    #     Manager data retention policy still applies. As a result, any
    #     evidence data will be deleted two years after its creation date.
    #     Your other Audit Manager resources will continue to exist
    #     indefinitely.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DeregistrationPolicy AWS API Documentation
    #
    class DeregistrationPolicy < Struct.new(
      :delete_resources)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The unique identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DisassociateAssessmentReportEvidenceFolderRequest AWS API Documentation
    #
    class DisassociateAssessmentReportEvidenceFolderRequest < Struct.new(
      :assessment_id,
      :evidence_folder_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/DisassociateAssessmentReportEvidenceFolderResponse AWS API Documentation
    #
    class DisassociateAssessmentReportEvidenceFolderResponse < Aws::EmptyStructure; end

    # A record that contains the information needed to demonstrate
    # compliance with the requirements specified by a control. Examples of
    # evidence include change activity invoked by a user, or a system
    # configuration snapshot.
    #
    # @!attribute [rw] data_source
    #   The data source where the evidence was collected from.
    #   @return [String]
    #
    # @!attribute [rw] evidence_aws_account_id
    #   The identifier for the Amazon Web Services account.
    #   @return [String]
    #
    # @!attribute [rw] time
    #   The timestamp that represents when the evidence was collected.
    #   @return [Time]
    #
    # @!attribute [rw] event_source
    #   The Amazon Web Service that the evidence is collected from.
    #   @return [String]
    #
    # @!attribute [rw] event_name
    #   The name of the evidence event.
    #   @return [String]
    #
    # @!attribute [rw] evidence_by_type
    #   The type of automated evidence.
    #   @return [String]
    #
    # @!attribute [rw] resources_included
    #   The list of resources that are assessed to generate the evidence.
    #   @return [Array<Types::Resource>]
    #
    # @!attribute [rw] attributes
    #   The names and values that are used by the evidence event. This
    #   includes an attribute name (such as `allowUsersToChangePassword`)
    #   and value (such as `true` or `false`).
    #   @return [Hash<String,String>]
    #
    # @!attribute [rw] iam_id
    #   The unique identifier for the user or role that's associated with
    #   the evidence.
    #   @return [String]
    #
    # @!attribute [rw] compliance_check
    #   The evaluation status for automated evidence that falls under the
    #   compliance check category.
    #
    #   * Audit Manager classes evidence as non-compliant if Security Hub
    #     reports a *Fail* result, or if Config reports a *Non-compliant*
    #     result.
    #
    #   * Audit Manager classes evidence as compliant if Security Hub
    #     reports a *Pass* result, or if Config reports a *Compliant*
    #     result.
    #
    #   * If a compliance check isn't available or applicable, then no
    #     compliance evaluation can be made for that evidence. This is the
    #     case if the evidence uses Config or Security Hub as the underlying
    #     data source type, but those services aren't enabled. This is also
    #     the case if the evidence uses an underlying data source type that
    #     doesn't support compliance checks (such as manual evidence,
    #     Amazon Web Services API calls, or CloudTrail).
    #   @return [String]
    #
    # @!attribute [rw] aws_organization
    #   The Amazon Web Services account that the evidence is collected from,
    #   and its organization path.
    #   @return [String]
    #
    # @!attribute [rw] aws_account_id
    #   The identifier for the Amazon Web Services account.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The identifier for the evidence.
    #   @return [String]
    #
    # @!attribute [rw] assessment_report_selection
    #   Specifies whether the evidence is included in the assessment report.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Evidence AWS API Documentation
    #
    class Evidence < Struct.new(
      :data_source,
      :evidence_aws_account_id,
      :time,
      :event_source,
      :event_name,
      :evidence_by_type,
      :resources_included,
      :attributes,
      :iam_id,
      :compliance_check,
      :aws_organization,
      :aws_account_id,
      :evidence_folder_id,
      :id,
      :assessment_report_selection)
      SENSITIVE = []
      include Aws::Structure
    end

    # The settings object that specifies whether evidence finder is enabled.
    # This object also describes the related event data store, and the
    # backfill status for populating the event data store with evidence
    # data.
    #
    # @!attribute [rw] event_data_store_arn
    #   The Amazon Resource Name (ARN) of the CloudTrail Lake event data
    #   store that’s used by evidence finder. The event data store is the
    #   lake of evidence data that evidence finder runs queries against.
    #   @return [String]
    #
    # @!attribute [rw] enablement_status
    #   The current status of the evidence finder feature and the related
    #   event data store.
    #
    #   * `ENABLE_IN_PROGRESS` means that you requested to enable evidence
    #     finder. An event data store is currently being created to support
    #     evidence finder queries.
    #
    #   * `ENABLED` means that an event data store was successfully created
    #     and evidence finder is enabled. We recommend that you wait 7 days
    #     until the event data store is backfilled with your past two years’
    #     worth of evidence data. You can use evidence finder in the
    #     meantime, but not all data might be available until the backfill
    #     is complete.
    #
    #   * `DISABLE_IN_PROGRESS` means that you requested to disable evidence
    #     finder, and your request is pending the deletion of the event data
    #     store.
    #
    #   * `DISABLED` means that you have permanently disabled evidence
    #     finder and the event data store has been deleted. You can't
    #     re-enable evidence finder after this point.
    #   @return [String]
    #
    # @!attribute [rw] backfill_status
    #   The current status of the evidence data backfill process.
    #
    #   The backfill starts after you enable evidence finder. During this
    #   task, Audit Manager populates an event data store with your past two
    #   years’ worth of evidence data so that your evidence can be queried.
    #
    #   * `NOT_STARTED` means that the backfill hasn’t started yet.
    #
    #   * `IN_PROGRESS` means that the backfill is in progress. This can
    #     take up to 7 days to complete, depending on the amount of evidence
    #     data.
    #
    #   * `COMPLETED` means that the backfill is complete. All of your past
    #     evidence is now queryable.
    #   @return [String]
    #
    # @!attribute [rw] error
    #   Represents any errors that occurred when enabling or disabling
    #   evidence finder.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/EvidenceFinderEnablement AWS API Documentation
    #
    class EvidenceFinderEnablement < Struct.new(
      :event_data_store_arn,
      :enablement_status,
      :backfill_status,
      :error)
      SENSITIVE = []
      include Aws::Structure
    end

    # A breakdown of the latest compliance check status for the evidence in
    # your Audit Manager assessments.
    #
    # @!attribute [rw] noncompliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as non-compliant. This includes evidence that was
    #   collected from Security Hub with a *Fail* ruling, or collected from
    #   Config with a *Non-compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] compliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as compliant. This includes evidence that was collected
    #   from Security Hub with a *Pass* ruling, or collected from Config
    #   with a *Compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] inconclusive_evidence_count
    #   The number of evidence that a compliance check ruling isn't
    #   available for. Evidence is inconclusive when the associated control
    #   uses Security Hub or Config as a data source but you didn't enable
    #   those services. This is also the case when a control uses a data
    #   source that doesn’t support compliance checks (for example, manual
    #   evidence, API calls, or CloudTrail).
    #
    #   <note markdown="1"> If evidence has a compliance check status of *not applicable* in the
    #   console, it's classified as *inconclusive* in `EvidenceInsights`
    #   data.
    #
    #    </note>
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/EvidenceInsights AWS API Documentation
    #
    class EvidenceInsights < Struct.new(
      :noncompliant_evidence_count,
      :compliant_evidence_count,
      :inconclusive_evidence_count)
      SENSITIVE = []
      include Aws::Structure
    end

    # The file that's used to structure and automate Audit Manager
    # assessments for a given compliance standard.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the framework.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the framework.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the framework.
    #   @return [String]
    #
    # @!attribute [rw] type
    #   Specifies whether the framework is a standard framework or a custom
    #   framework.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The compliance type that the framework supports, such as CIS or
    #   HIPAA.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the framework.
    #   @return [String]
    #
    # @!attribute [rw] logo
    #   The logo that's associated with the framework.
    #   @return [String]
    #
    # @!attribute [rw] control_sources
    #   The control data sources where Audit Manager collects evidence from.
    #   @return [String]
    #
    # @!attribute [rw] control_sets
    #   The control sets that are associated with the framework.
    #   @return [Array<Types::ControlSet>]
    #
    # @!attribute [rw] created_at
    #   The time when the framework was created.
    #   @return [Time]
    #
    # @!attribute [rw] last_updated_at
    #   The time when the framework was most recently updated.
    #   @return [Time]
    #
    # @!attribute [rw] created_by
    #   The user or role that created the framework.
    #   @return [String]
    #
    # @!attribute [rw] last_updated_by
    #   The user or role that most recently updated the framework.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the framework.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Framework AWS API Documentation
    #
    class Framework < Struct.new(
      :arn,
      :id,
      :name,
      :type,
      :compliance_type,
      :description,
      :logo,
      :control_sources,
      :control_sets,
      :created_at,
      :last_updated_at,
      :created_by,
      :last_updated_by,
      :tags)
      SENSITIVE = [:compliance_type, :control_sets, :created_by, :last_updated_by]
      include Aws::Structure
    end

    # The metadata of a framework, such as the name, ID, or description.
    #
    # @!attribute [rw] name
    #   The name of the framework.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the framework.
    #   @return [String]
    #
    # @!attribute [rw] logo
    #   The logo that's associated with the framework.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The compliance standard that's associated with the framework. For
    #   example, this could be PCI DSS or HIPAA.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/FrameworkMetadata AWS API Documentation
    #
    class FrameworkMetadata < Struct.new(
      :name,
      :description,
      :logo,
      :compliance_type)
      SENSITIVE = [:name, :compliance_type]
      include Aws::Structure
    end

    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAccountStatusRequest AWS API Documentation
    #
    class GetAccountStatusRequest < Aws::EmptyStructure; end

    # @!attribute [rw] status
    #   The status of the Amazon Web Services account.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAccountStatusResponse AWS API Documentation
    #
    class GetAccountStatusResponse < Struct.new(
      :status)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework_id
    #   The identifier for the framework.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentFrameworkRequest AWS API Documentation
    #
    class GetAssessmentFrameworkRequest < Struct.new(
      :framework_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework
    #   The framework that the `GetAssessmentFramework` API returned.
    #   @return [Types::Framework]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentFrameworkResponse AWS API Documentation
    #
    class GetAssessmentFrameworkResponse < Struct.new(
      :framework)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_report_id
    #   The unique identifier for the assessment report.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentReportUrlRequest AWS API Documentation
    #
    class GetAssessmentReportUrlRequest < Struct.new(
      :assessment_report_id,
      :assessment_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] pre_signed_url
    #   Short for uniform resource locator. A URL is used as a unique
    #   identifier to locate a resource on the internet.
    #   @return [Types::URL]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentReportUrlResponse AWS API Documentation
    #
    class GetAssessmentReportUrlResponse < Struct.new(
      :pre_signed_url)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentRequest AWS API Documentation
    #
    class GetAssessmentRequest < Struct.new(
      :assessment_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment
    #   An entity that defines the scope of audit evidence collected by
    #   Audit Manager. An Audit Manager assessment is an implementation of
    #   an Audit Manager framework.
    #   @return [Types::Assessment]
    #
    # @!attribute [rw] user_role
    #   The wrapper that contains the Audit Manager role information of the
    #   current user. This includes the role type and IAM Amazon Resource
    #   Name (ARN).
    #   @return [Types::Role]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetAssessmentResponse AWS API Documentation
    #
    class GetAssessmentResponse < Struct.new(
      :assessment,
      :user_role)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetChangeLogsRequest AWS API Documentation
    #
    class GetChangeLogsRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :control_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] change_logs
    #   The list of user activity for the control.
    #   @return [Array<Types::ChangeLog>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetChangeLogsResponse AWS API Documentation
    #
    class GetChangeLogsResponse < Struct.new(
      :change_logs,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_id
    #   The identifier for the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetControlRequest AWS API Documentation
    #
    class GetControlRequest < Struct.new(
      :control_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control
    #   The details of the control that the `GetControl` API returned.
    #   @return [Types::Control]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetControlResponse AWS API Documentation
    #
    class GetControlResponse < Struct.new(
      :control)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetDelegationsRequest AWS API Documentation
    #
    class GetDelegationsRequest < Struct.new(
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] delegations
    #   The list of delegations that the `GetDelegations` API returned.
    #   @return [Array<Types::DelegationMetadata>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetDelegationsResponse AWS API Documentation
    #
    class GetDelegationsResponse < Struct.new(
      :delegations,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The unique identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceByEvidenceFolderRequest AWS API Documentation
    #
    class GetEvidenceByEvidenceFolderRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :evidence_folder_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence
    #   The list of evidence that the `GetEvidenceByEvidenceFolder` API
    #   returned.
    #   @return [Array<Types::Evidence>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceByEvidenceFolderResponse AWS API Documentation
    #
    class GetEvidenceByEvidenceFolderResponse < Struct.new(
      :evidence,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] file_name
    #   The file that you want to upload. For a list of supported file
    #   formats, see [Supported file types for manual evidence][1] in the
    #   *Audit Manager User Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/userguide/upload-evidence.html#supported-manual-evidence-files
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFileUploadUrlRequest AWS API Documentation
    #
    class GetEvidenceFileUploadUrlRequest < Struct.new(
      :file_name)
      SENSITIVE = [:file_name]
      include Aws::Structure
    end

    # @!attribute [rw] evidence_file_name
    #   The name of the uploaded manual evidence file that the presigned URL
    #   was generated for.
    #   @return [String]
    #
    # @!attribute [rw] upload_url
    #   The presigned URL that was generated.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFileUploadUrlResponse AWS API Documentation
    #
    class GetEvidenceFileUploadUrlResponse < Struct.new(
      :evidence_file_name,
      :upload_url)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The unique identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFolderRequest AWS API Documentation
    #
    class GetEvidenceFolderRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :evidence_folder_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence_folder
    #   The folder that the evidence is stored in.
    #   @return [Types::AssessmentEvidenceFolder]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFolderResponse AWS API Documentation
    #
    class GetEvidenceFolderResponse < Struct.new(
      :evidence_folder)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_id
    #   The identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFoldersByAssessmentControlRequest AWS API Documentation
    #
    class GetEvidenceFoldersByAssessmentControlRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :control_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence_folders
    #   The list of evidence folders that the
    #   `GetEvidenceFoldersByAssessmentControl` API returned.
    #   @return [Array<Types::AssessmentEvidenceFolder>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFoldersByAssessmentControlResponse AWS API Documentation
    #
    class GetEvidenceFoldersByAssessmentControlResponse < Struct.new(
      :evidence_folders,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFoldersByAssessmentRequest AWS API Documentation
    #
    class GetEvidenceFoldersByAssessmentRequest < Struct.new(
      :assessment_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence_folders
    #   The list of evidence folders that the
    #   `GetEvidenceFoldersByAssessment` API returned.
    #   @return [Array<Types::AssessmentEvidenceFolder>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceFoldersByAssessmentResponse AWS API Documentation
    #
    class GetEvidenceFoldersByAssessmentResponse < Struct.new(
      :evidence_folders,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] evidence_folder_id
    #   The unique identifier for the folder that the evidence is stored in.
    #   @return [String]
    #
    # @!attribute [rw] evidence_id
    #   The unique identifier for the evidence.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceRequest AWS API Documentation
    #
    class GetEvidenceRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :evidence_folder_id,
      :evidence_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] evidence
    #   The evidence that the `GetEvidence` API returned.
    #   @return [Types::Evidence]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetEvidenceResponse AWS API Documentation
    #
    class GetEvidenceResponse < Struct.new(
      :evidence)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetInsightsByAssessmentRequest AWS API Documentation
    #
    class GetInsightsByAssessmentRequest < Struct.new(
      :assessment_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] insights
    #   The assessment analytics data that the `GetInsightsByAssessment` API
    #   returned.
    #   @return [Types::InsightsByAssessment]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetInsightsByAssessmentResponse AWS API Documentation
    #
    class GetInsightsByAssessmentResponse < Struct.new(
      :insights)
      SENSITIVE = []
      include Aws::Structure
    end

    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetInsightsRequest AWS API Documentation
    #
    class GetInsightsRequest < Aws::EmptyStructure; end

    # @!attribute [rw] insights
    #   The analytics data that the `GetInsights` API returned.
    #   @return [Types::Insights]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetInsightsResponse AWS API Documentation
    #
    class GetInsightsResponse < Struct.new(
      :insights)
      SENSITIVE = []
      include Aws::Structure
    end

    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetOrganizationAdminAccountRequest AWS API Documentation
    #
    class GetOrganizationAdminAccountRequest < Aws::EmptyStructure; end

    # @!attribute [rw] admin_account_id
    #   The identifier for the administrator account.
    #   @return [String]
    #
    # @!attribute [rw] organization_id
    #   The identifier for the organization.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetOrganizationAdminAccountResponse AWS API Documentation
    #
    class GetOrganizationAdminAccountResponse < Struct.new(
      :admin_account_id,
      :organization_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetServicesInScopeRequest AWS API Documentation
    #
    class GetServicesInScopeRequest < Aws::EmptyStructure; end

    # @!attribute [rw] service_metadata
    #   The metadata that's associated with the Amazon Web Service.
    #   @return [Array<Types::ServiceMetadata>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetServicesInScopeResponse AWS API Documentation
    #
    class GetServicesInScopeResponse < Struct.new(
      :service_metadata)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] attribute
    #   The list of setting attribute enum values.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetSettingsRequest AWS API Documentation
    #
    class GetSettingsRequest < Struct.new(
      :attribute)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] settings
    #   The settings object that holds all supported Audit Manager settings.
    #   @return [Types::Settings]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/GetSettingsResponse AWS API Documentation
    #
    class GetSettingsResponse < Struct.new(
      :settings)
      SENSITIVE = []
      include Aws::Structure
    end

    # A summary of the latest analytics data for all your active
    # assessments.
    #
    # This summary is a snapshot of the data that your active assessments
    # collected on the `lastUpdated` date. It’s important to understand that
    # the following totals are daily counts based on this date — they aren’t
    # a total sum to date.
    #
    # The `Insights` data is eventually consistent. This means that, when
    # you read data from `Insights`, the response might not instantly
    # reflect the results of a recently completed write or update operation.
    # If you repeat your read request after a few hours, the response should
    # return the latest data.
    #
    # <note markdown="1"> If you delete an assessment or change its status to inactive,
    # `InsightsByAssessment` includes data for that assessment as follows.
    #
    #  * **Inactive assessments** - If Audit Manager collected evidence for
    #   your assessment before you changed it inactive, that evidence is
    #   included in the `InsightsByAssessment` counts for that day.
    #
    # * **Deleted assessments** - If Audit Manager collected evidence for
    #   your assessment before you deleted it, that evidence isn't included
    #   in the `InsightsByAssessment` counts for that day.
    #
    #  </note>
    #
    # @!attribute [rw] active_assessments_count
    #   The number of active assessments in Audit Manager.
    #   @return [Integer]
    #
    # @!attribute [rw] noncompliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as non-compliant on the `lastUpdated` date. This includes
    #   evidence that was collected from Security Hub with a *Fail* ruling,
    #   or collected from Config with a *Non-compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] compliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as compliant on the `lastUpdated` date. This includes
    #   evidence that was collected from Security Hub with a *Pass* ruling,
    #   or collected from Config with a *Compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] inconclusive_evidence_count
    #   The number of evidence without a compliance check ruling. Evidence
    #   is inconclusive when the associated control uses Security Hub or
    #   Config as a data source but you didn't enable those services. This
    #   is also the case when a control uses a data source that doesn’t
    #   support compliance checks (for example: manual evidence, API calls,
    #   or CloudTrail).
    #
    #   <note markdown="1"> If evidence has a compliance check status of *not applicable*, it's
    #   classed as *inconclusive* in `Insights` data.
    #
    #    </note>
    #   @return [Integer]
    #
    # @!attribute [rw] assessment_controls_count_by_noncompliant_evidence
    #   The number of assessment controls that collected non-compliant
    #   evidence on the `lastUpdated` date.
    #   @return [Integer]
    #
    # @!attribute [rw] total_assessment_controls_count
    #   The total number of controls across all active assessments.
    #   @return [Integer]
    #
    # @!attribute [rw] last_updated
    #   The time when the cross-assessment insights were last updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Insights AWS API Documentation
    #
    class Insights < Struct.new(
      :active_assessments_count,
      :noncompliant_evidence_count,
      :compliant_evidence_count,
      :inconclusive_evidence_count,
      :assessment_controls_count_by_noncompliant_evidence,
      :total_assessment_controls_count,
      :last_updated)
      SENSITIVE = []
      include Aws::Structure
    end

    # A summary of the latest analytics data for a specific active
    # assessment.
    #
    # This summary is a snapshot of the data that was collected on the
    # `lastUpdated` date. It’s important to understand that the totals in
    # `InsightsByAssessment` are daily counts based on this date — they
    # aren’t a total sum to date.
    #
    # The `InsightsByAssessment` data is eventually consistent. This means
    # that when you read data from `InsightsByAssessment`, the response
    # might not instantly reflect the results of a recently completed write
    # or update operation. If you repeat your read request after a few
    # hours, the response returns the latest data.
    #
    # <note markdown="1"> If you delete an assessment or change its status to inactive,
    # `InsightsByAssessment` includes data for that assessment as follows.
    #
    #  * **Inactive assessments** - If Audit Manager collected evidence for
    #   your assessment before you changed it inactive, that evidence is
    #   included in the `InsightsByAssessment` counts for that day.
    #
    # * **Deleted assessments** - If Audit Manager collected evidence for
    #   your assessment before you deleted it, that evidence isn't included
    #   in the `InsightsByAssessment` counts for that day.
    #
    #  </note>
    #
    # @!attribute [rw] noncompliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as non-compliant. This includes evidence that was
    #   collected from Security Hub with a *Fail* ruling, or collected from
    #   Config with a *Non-compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] compliant_evidence_count
    #   The number of compliance check evidence that Audit Manager
    #   classified as compliant. This includes evidence that was collected
    #   from Security Hub with a *Pass* ruling, or collected from Config
    #   with a *Compliant* ruling.
    #   @return [Integer]
    #
    # @!attribute [rw] inconclusive_evidence_count
    #   The amount of evidence without a compliance check ruling. Evidence
    #   is inconclusive if the associated control uses Security Hub or
    #   Config as a data source and you didn't enable those services. This
    #   is also the case if a control uses a data source that doesn’t
    #   support compliance checks (for example, manual evidence, API calls,
    #   or CloudTrail).
    #
    #   <note markdown="1"> If evidence has a compliance check status of *not applicable*, it's
    #   classified as *inconclusive* in `InsightsByAssessment` data.
    #
    #    </note>
    #   @return [Integer]
    #
    # @!attribute [rw] assessment_controls_count_by_noncompliant_evidence
    #   The number of assessment controls that collected non-compliant
    #   evidence on the `lastUpdated` date.
    #   @return [Integer]
    #
    # @!attribute [rw] total_assessment_controls_count
    #   The total number of controls in the assessment.
    #   @return [Integer]
    #
    # @!attribute [rw] last_updated
    #   The time when the assessment insights were last updated.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/InsightsByAssessment AWS API Documentation
    #
    class InsightsByAssessment < Struct.new(
      :noncompliant_evidence_count,
      :compliant_evidence_count,
      :inconclusive_evidence_count,
      :assessment_controls_count_by_noncompliant_evidence,
      :total_assessment_controls_count,
      :last_updated)
      SENSITIVE = []
      include Aws::Structure
    end

    # An internal service error occurred during the processing of your
    # request. Try again later.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/InternalServerException AWS API Documentation
    #
    class InternalServerException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_domain_id
    #   The unique identifier for the control domain.
    #
    #   Audit Manager supports the control domains that are provided by
    #   Amazon Web Services Control Catalog. For information about how to
    #   find a list of available control domains, see [ `ListDomains` ][1]
    #   in the Amazon Web Services Control Catalog API Reference.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListDomains.html
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The unique identifier for the active assessment.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentControlInsightsByControlDomainRequest AWS API Documentation
    #
    class ListAssessmentControlInsightsByControlDomainRequest < Struct.new(
      :control_domain_id,
      :assessment_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_insights_by_assessment
    #   The assessment control analytics data that the
    #   `ListAssessmentControlInsightsByControlDomain` API returned.
    #   @return [Array<Types::ControlInsightsMetadataByAssessmentItem>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentControlInsightsByControlDomainResponse AWS API Documentation
    #
    class ListAssessmentControlInsightsByControlDomainResponse < Struct.new(
      :control_insights_by_assessment,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] request_type
    #   Specifies whether the share request is a sent request or a received
    #   request.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentFrameworkShareRequestsRequest AWS API Documentation
    #
    class ListAssessmentFrameworkShareRequestsRequest < Struct.new(
      :request_type,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_framework_share_requests
    #   The list of share requests that the
    #   `ListAssessmentFrameworkShareRequests` API returned.
    #   @return [Array<Types::AssessmentFrameworkShareRequest>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentFrameworkShareRequestsResponse AWS API Documentation
    #
    class ListAssessmentFrameworkShareRequestsResponse < Struct.new(
      :assessment_framework_share_requests,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework_type
    #   The type of framework, such as a standard framework or a custom
    #   framework.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentFrameworksRequest AWS API Documentation
    #
    class ListAssessmentFrameworksRequest < Struct.new(
      :framework_type,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework_metadata_list
    #   A list of metadata that the `ListAssessmentFrameworks` API returns
    #   for each framework.
    #   @return [Array<Types::AssessmentFrameworkMetadata>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentFrameworksResponse AWS API Documentation
    #
    class ListAssessmentFrameworksResponse < Struct.new(
      :framework_metadata_list,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentReportsRequest AWS API Documentation
    #
    class ListAssessmentReportsRequest < Struct.new(
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_reports
    #   The list of assessment reports that the `ListAssessmentReports` API
    #   returned.
    #   @return [Array<Types::AssessmentReportMetadata>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentReportsResponse AWS API Documentation
    #
    class ListAssessmentReportsResponse < Struct.new(
      :assessment_reports,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] status
    #   The current status of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentsRequest AWS API Documentation
    #
    class ListAssessmentsRequest < Struct.new(
      :status,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_metadata
    #   The metadata that the `ListAssessments` API returns for each
    #   assessment.
    #   @return [Array<Types::AssessmentMetadataItem>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListAssessmentsResponse AWS API Documentation
    #
    class ListAssessmentsResponse < Struct.new(
      :assessment_metadata,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the active assessment.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlDomainInsightsByAssessmentRequest AWS API Documentation
    #
    class ListControlDomainInsightsByAssessmentRequest < Struct.new(
      :assessment_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_domain_insights
    #   The control domain analytics data that the
    #   `ListControlDomainInsightsByAssessment` API returned.
    #   @return [Array<Types::ControlDomainInsights>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlDomainInsightsByAssessmentResponse AWS API Documentation
    #
    class ListControlDomainInsightsByAssessmentResponse < Struct.new(
      :control_domain_insights,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlDomainInsightsRequest AWS API Documentation
    #
    class ListControlDomainInsightsRequest < Struct.new(
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_domain_insights
    #   The control domain analytics data that the
    #   `ListControlDomainInsights` API returned.
    #   @return [Array<Types::ControlDomainInsights>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlDomainInsightsResponse AWS API Documentation
    #
    class ListControlDomainInsightsResponse < Struct.new(
      :control_domain_insights,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_domain_id
    #   The unique identifier for the control domain.
    #
    #   Audit Manager supports the control domains that are provided by
    #   Amazon Web Services Control Catalog. For information about how to
    #   find a list of available control domains, see [ `ListDomains` ][1]
    #   in the Amazon Web Services Control Catalog API Reference.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListDomains.html
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlInsightsByControlDomainRequest AWS API Documentation
    #
    class ListControlInsightsByControlDomainRequest < Struct.new(
      :control_domain_id,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_insights_metadata
    #   The control analytics data that the
    #   `ListControlInsightsByControlDomain` API returned.
    #   @return [Array<Types::ControlInsightsMetadataItem>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlInsightsByControlDomainResponse AWS API Documentation
    #
    class ListControlInsightsByControlDomainResponse < Struct.new(
      :control_insights_metadata,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_type
    #   A filter that narrows the list of controls to a specific type.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   The maximum number of results on a page or for an API request call.
    #   @return [Integer]
    #
    # @!attribute [rw] control_catalog_id
    #   A filter that narrows the list of controls to a specific resource
    #   from the Amazon Web Services Control Catalog.
    #
    #   To use this parameter, specify the ARN of the Control Catalog
    #   resource. You can specify either a control domain, a control
    #   objective, or a common control. For information about how to find
    #   the ARNs for these resources, see [ `ListDomains` ][1], [
    #   `ListObjectives` ][2], and [ `ListCommonControls` ][3].
    #
    #   <note markdown="1"> You can only filter by one Control Catalog resource at a time.
    #   Specifying multiple resource ARNs isn’t currently supported. If you
    #   want to filter by more than one ARN, we recommend that you run the
    #   `ListControls` operation separately for each ARN.
    #
    #    </note>
    #
    #   Alternatively, specify `UNCATEGORIZED` to list controls that aren't
    #   mapped to a Control Catalog resource. For example, this operation
    #   might return a list of custom controls that don't belong to any
    #   control domain or control objective.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListDomains.html
    #   [2]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListObjectives.html
    #   [3]: https://docs.aws.amazon.com/controlcatalog/latest/APIReference/API_ListCommonControls.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlsRequest AWS API Documentation
    #
    class ListControlsRequest < Struct.new(
      :control_type,
      :next_token,
      :max_results,
      :control_catalog_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_metadata_list
    #   A list of metadata that the `ListControls` API returns for each
    #   control.
    #   @return [Array<Types::ControlMetadata>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListControlsResponse AWS API Documentation
    #
    class ListControlsResponse < Struct.new(
      :control_metadata_list,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] source
    #   The control mapping data source that the keywords apply to.
    #   @return [String]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListKeywordsForDataSourceRequest AWS API Documentation
    #
    class ListKeywordsForDataSourceRequest < Struct.new(
      :source,
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] keywords
    #   The list of keywords for the control mapping source.
    #   @return [Array<String>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListKeywordsForDataSourceResponse AWS API Documentation
    #
    class ListKeywordsForDataSourceResponse < Struct.new(
      :keywords,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @!attribute [rw] max_results
    #   Represents the maximum number of results on a page or for an API
    #   request call.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListNotificationsRequest AWS API Documentation
    #
    class ListNotificationsRequest < Struct.new(
      :next_token,
      :max_results)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] notifications
    #   The returned list of notifications.
    #   @return [Array<Types::Notification>]
    #
    # @!attribute [rw] next_token
    #   The pagination token that's used to fetch the next set of results.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListNotificationsResponse AWS API Documentation
    #
    class ListNotificationsResponse < Struct.new(
      :notifications,
      :next_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListTagsForResourceRequest AWS API Documentation
    #
    class ListTagsForResourceRequest < Struct.new(
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] tags
    #   The list of tags that the `ListTagsForResource` API returned.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ListTagsForResourceResponse AWS API Documentation
    #
    class ListTagsForResourceResponse < Struct.new(
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # Evidence that's manually added to a control in Audit Manager.
    # `manualEvidence` can be one of the following: `evidenceFileName`,
    # `s3ResourcePath`, or `textResponse`.
    #
    # @!attribute [rw] s3_resource_path
    #   The S3 URL of the object that's imported as manual evidence.
    #   @return [String]
    #
    # @!attribute [rw] text_response
    #   The plain text response that's entered and saved as manual
    #   evidence.
    #   @return [String]
    #
    # @!attribute [rw] evidence_file_name
    #   The name of the file that's uploaded as manual evidence. This name
    #   is populated using the `evidenceFileName` value from the [
    #   `GetEvidenceFileUploadUrl` ][1] API response.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_GetEvidenceFileUploadUrl.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ManualEvidence AWS API Documentation
    #
    class ManualEvidence < Struct.new(
      :s3_resource_path,
      :text_response,
      :evidence_file_name)
      SENSITIVE = [:text_response, :evidence_file_name]
      include Aws::Structure
    end

    # The notification that informs a user of an update in Audit Manager.
    # For example, this includes the notification that's sent when a
    # control set is delegated for review.
    #
    # @!attribute [rw] id
    #   The unique identifier for the notification.
    #   @return [String]
    #
    # @!attribute [rw] assessment_id
    #   The identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the related assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_set_name
    #   Specifies the name of the control set that the notification is
    #   about.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the notification.
    #   @return [String]
    #
    # @!attribute [rw] event_time
    #   The time when the notification was sent.
    #   @return [Time]
    #
    # @!attribute [rw] source
    #   The sender of the notification.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Notification AWS API Documentation
    #
    class Notification < Struct.new(
      :id,
      :assessment_id,
      :assessment_name,
      :control_set_id,
      :control_set_name,
      :description,
      :event_time,
      :source)
      SENSITIVE = [:assessment_name]
      include Aws::Structure
    end

    # @!attribute [rw] kms_key
    #   The KMS key details.
    #   @return [String]
    #
    # @!attribute [rw] delegated_admin_account
    #   The delegated administrator account for Audit Manager.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/RegisterAccountRequest AWS API Documentation
    #
    class RegisterAccountRequest < Struct.new(
      :kms_key,
      :delegated_admin_account)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] status
    #   The status of the account registration request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/RegisterAccountResponse AWS API Documentation
    #
    class RegisterAccountResponse < Struct.new(
      :status)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] admin_account_id
    #   The identifier for the delegated administrator account.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/RegisterOrganizationAdminAccountRequest AWS API Documentation
    #
    class RegisterOrganizationAdminAccountRequest < Struct.new(
      :admin_account_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] admin_account_id
    #   The identifier for the delegated administrator account.
    #   @return [String]
    #
    # @!attribute [rw] organization_id
    #   The identifier for the organization.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/RegisterOrganizationAdminAccountResponse AWS API Documentation
    #
    class RegisterOrganizationAdminAccountResponse < Struct.new(
      :admin_account_id,
      :organization_id)
      SENSITIVE = []
      include Aws::Structure
    end

    # A system asset that's evaluated in an Audit Manager assessment.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) for the resource.
    #   @return [String]
    #
    # @!attribute [rw] value
    #   The value of the resource.
    #   @return [String]
    #
    # @!attribute [rw] compliance_check
    #   The evaluation status for a resource that was assessed when
    #   collecting compliance check evidence.
    #
    #   * Audit Manager classes the resource as non-compliant if Security
    #     Hub reports a *Fail* result, or if Config reports a
    #     *Non-compliant* result.
    #
    #   * Audit Manager classes the resource as compliant if Security Hub
    #     reports a *Pass* result, or if Config reports a *Compliant*
    #     result.
    #
    #   * If a compliance check isn't available or applicable, then no
    #     compliance evaluation can be made for that resource. This is the
    #     case if a resource assessment uses Config or Security Hub as the
    #     underlying data source type, but those services aren't enabled.
    #     This is also the case if the resource assessment uses an
    #     underlying data source type that doesn't support compliance
    #     checks (such as manual evidence, Amazon Web Services API calls, or
    #     CloudTrail).
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Resource AWS API Documentation
    #
    class Resource < Struct.new(
      :arn,
      :value,
      :compliance_check)
      SENSITIVE = []
      include Aws::Structure
    end

    # The resource that's specified in the request can't be found.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @!attribute [rw] resource_id
    #   The unique identifier for the resource.
    #   @return [String]
    #
    # @!attribute [rw] resource_type
    #   The type of resource that's affected by the error.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ResourceNotFoundException AWS API Documentation
    #
    class ResourceNotFoundException < Struct.new(
      :message,
      :resource_id,
      :resource_type)
      SENSITIVE = []
      include Aws::Structure
    end

    # The wrapper that contains the Audit Manager role information of the
    # current user. This includes the role type and IAM Amazon Resource Name
    # (ARN).
    #
    # @!attribute [rw] role_type
    #   The type of customer persona.
    #
    #   <note markdown="1"> In `CreateAssessment`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `UpdateSettings`, `roleType` can only be `PROCESS_OWNER`.
    #
    #    In `BatchCreateDelegationByAssessment`, `roleType` can only be
    #   `RESOURCE_OWNER`.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] role_arn
    #   The Amazon Resource Name (ARN) of the IAM role.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Role AWS API Documentation
    #
    class Role < Struct.new(
      :role_type,
      :role_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # The wrapper that contains the Amazon Web Services accounts that are in
    # scope for the assessment.
    #
    # <note markdown="1"> You no longer need to specify which Amazon Web Services are in scope
    # when you create or update an assessment. Audit Manager infers the
    # services in scope by examining your assessment controls and their data
    # sources, and then mapping this information to the relevant Amazon Web
    # Services.
    #
    #  If an underlying data source changes for your assessment, we
    # automatically update the services scope as needed to reflect the
    # correct Amazon Web Services. This ensures that your assessment
    # collects accurate and comprehensive evidence about all of the relevant
    # services in your AWS environment.
    #
    #  </note>
    #
    # @!attribute [rw] aws_accounts
    #   The Amazon Web Services accounts that are included in the scope of
    #   the assessment.
    #   @return [Array<Types::AWSAccount>]
    #
    # @!attribute [rw] aws_services
    #   The Amazon Web Services services that are included in the scope of
    #   the assessment.
    #
    #   This API parameter is no longer supported. If you use this parameter
    #   to specify one or more Amazon Web Services, Audit Manager ignores
    #   this input. Instead, the value for `awsServices` will show as empty.
    #   @return [Array<Types::AWSService>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Scope AWS API Documentation
    #
    class Scope < Struct.new(
      :aws_accounts,
      :aws_services)
      SENSITIVE = [:aws_accounts]
      include Aws::Structure
    end

    # The metadata that's associated with the Amazon Web Service.
    #
    # @!attribute [rw] name
    #   The name of the Amazon Web Service.
    #   @return [String]
    #
    # @!attribute [rw] display_name
    #   The display name of the Amazon Web Service.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the Amazon Web Service.
    #   @return [String]
    #
    # @!attribute [rw] category
    #   The category that the Amazon Web Service belongs to, such as
    #   compute, storage, or database.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ServiceMetadata AWS API Documentation
    #
    class ServiceMetadata < Struct.new(
      :name,
      :display_name,
      :description,
      :category)
      SENSITIVE = []
      include Aws::Structure
    end

    # You've reached your account quota for this resource type. To perform
    # the requested action, delete some existing resources or [request a
    # quota increase][1] from the Service Quotas console. For a list of
    # Audit Manager service quotas, see [Quotas and restrictions for Audit
    # Manager][2].
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/general/latest/gr/aws_service_limits.html
    # [2]: https://docs.aws.amazon.com/audit-manager/latest/userguide/service-quotas.html
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ServiceQuotaExceededException AWS API Documentation
    #
    class ServiceQuotaExceededException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The settings object that holds all supported Audit Manager settings.
    #
    # @!attribute [rw] is_aws_org_enabled
    #   Specifies whether Organizations is enabled.
    #   @return [Boolean]
    #
    # @!attribute [rw] sns_topic
    #   The designated Amazon Simple Notification Service (Amazon SNS)
    #   topic.
    #   @return [String]
    #
    # @!attribute [rw] default_assessment_reports_destination
    #   The default S3 destination bucket for storing assessment reports.
    #   @return [Types::AssessmentReportsDestination]
    #
    # @!attribute [rw] default_process_owners
    #   The designated default audit owners.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] kms_key
    #   The KMS key details.
    #   @return [String]
    #
    # @!attribute [rw] evidence_finder_enablement
    #   The current evidence finder status and event data store details.
    #   @return [Types::EvidenceFinderEnablement]
    #
    # @!attribute [rw] deregistration_policy
    #   The deregistration policy for your Audit Manager data. You can use
    #   this attribute to determine how your data is handled when you
    #   deregister Audit Manager.
    #   @return [Types::DeregistrationPolicy]
    #
    # @!attribute [rw] default_export_destination
    #   The default S3 destination bucket for storing evidence finder
    #   exports.
    #   @return [Types::DefaultExportDestination]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/Settings AWS API Documentation
    #
    class Settings < Struct.new(
      :is_aws_org_enabled,
      :sns_topic,
      :default_assessment_reports_destination,
      :default_process_owners,
      :kms_key,
      :evidence_finder_enablement,
      :deregistration_policy,
      :default_export_destination)
      SENSITIVE = [:sns_topic, :default_assessment_reports_destination, :default_process_owners]
      include Aws::Structure
    end

    # 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*:
    #
    # * [Config rules supported by Audit Manager][1]
    #
    # * [Security Hub controls supported by Audit Manager][2]
    #
    # * [API calls supported by Audit Manager][3]
    #
    # * [CloudTrail event names supported by Audit Manager][4]
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-config.html
    # [2]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-ash.html
    # [3]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-api.html
    # [4]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-cloudtrail.html
    #
    # @!attribute [rw] keyword_input_type
    #   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.
    #   @return [String]
    #
    # @!attribute [rw] keyword_value
    #   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][1], you can use the rule identifier as the
    #     `keywordValue`. You can find the rule identifier from the [list of
    #     Config managed rules][2]. 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:
    #
    #     * Managed rule name: [s3-bucket-acl-prohibited][3]
    #
    #       `keywordValue`: `S3_BUCKET_ACL_PROHIBITED`
    #
    #   * For [custom rules][4], 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][5], 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][6].
    #
    #       * 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][7] 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][8].
    #
    #   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][9].
    #
    #   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][10].
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/config/latest/developerguide/evaluate-config_use-managed-rules.html
    #   [2]: https://docs.aws.amazon.com/config/latest/developerguide/managed-rules-by-aws-config.html
    #   [3]: https://docs.aws.amazon.com/config/latest/developerguide/s3-bucket-acl-prohibited.html
    #   [4]: https://docs.aws.amazon.com/config/latest/developerguide/evaluate-config_develop-rules.html
    #   [5]: https://docs.aws.amazon.com/config/latest/developerguide/service-linked-awsconfig-rules.html
    #   [6]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-config.html
    #   [7]: https://console.aws.amazon.com/config/
    #   [8]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-ash.html
    #   [9]: https://docs.aws.amazon.com/audit-manager/latest/userguide/control-data-sources-api.html
    #   [10]: https://docs.aws.amazon.com/service-authorization/latest/reference/reference_policies_actions-resources-contextkeys.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/SourceKeyword AWS API Documentation
    #
    class SourceKeyword < Struct.new(
      :keyword_input_type,
      :keyword_value)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework_id
    #   The unique identifier for the custom framework to be shared.
    #   @return [String]
    #
    # @!attribute [rw] destination_account
    #   The Amazon Web Services account of the recipient.
    #   @return [String]
    #
    # @!attribute [rw] destination_region
    #   The Amazon Web Services Region of the recipient.
    #   @return [String]
    #
    # @!attribute [rw] comment
    #   An optional comment from the sender about the share request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/StartAssessmentFrameworkShareRequest AWS API Documentation
    #
    class StartAssessmentFrameworkShareRequest < Struct.new(
      :framework_id,
      :destination_account,
      :destination_region,
      :comment)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_framework_share_request
    #   The share request that's created by the
    #   `StartAssessmentFrameworkShare` API.
    #   @return [Types::AssessmentFrameworkShareRequest]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/StartAssessmentFrameworkShareResponse AWS API Documentation
    #
    class StartAssessmentFrameworkShareResponse < Struct.new(
      :assessment_framework_share_request)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   The tags that are associated with the resource.
    #   @return [Hash<String,String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/TagResourceRequest AWS API Documentation
    #
    class TagResourceRequest < Struct.new(
      :resource_arn,
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/TagResourceResponse AWS API Documentation
    #
    class TagResourceResponse < Aws::EmptyStructure; end

    # The request was denied due to request throttling.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ThrottlingException AWS API Documentation
    #
    class ThrottlingException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # Short for uniform resource locator. A URL is used as a unique
    # identifier to locate a resource on the internet.
    #
    # @!attribute [rw] hyperlink_name
    #   The name or word that's used as a hyperlink to the URL.
    #   @return [String]
    #
    # @!attribute [rw] link
    #   The unique identifier for the internet resource.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/URL AWS API Documentation
    #
    class URL < Struct.new(
      :hyperlink_name,
      :link)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the specified resource.
    #   @return [String]
    #
    # @!attribute [rw] tag_keys
    #   The name or key of the tag.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UntagResourceRequest AWS API Documentation
    #
    class UntagResourceRequest < Struct.new(
      :resource_arn,
      :tag_keys)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UntagResourceResponse AWS API Documentation
    #
    class UntagResourceResponse < Aws::EmptyStructure; end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] control_id
    #   The unique identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] control_status
    #   The status of the control.
    #   @return [String]
    #
    # @!attribute [rw] comment_body
    #   The comment body text for the control.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentControlRequest AWS API Documentation
    #
    class UpdateAssessmentControlRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :control_id,
      :control_status,
      :comment_body)
      SENSITIVE = [:comment_body]
      include Aws::Structure
    end

    # @!attribute [rw] control
    #   The name of the updated control set that the
    #   `UpdateAssessmentControl` API returned.
    #   @return [Types::AssessmentControl]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentControlResponse AWS API Documentation
    #
    class UpdateAssessmentControlResponse < Struct.new(
      :control)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] control_set_id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The status of the control set that's being updated.
    #   @return [String]
    #
    # @!attribute [rw] comment
    #   The comment that's related to the status update.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentControlSetStatusRequest AWS API Documentation
    #
    class UpdateAssessmentControlSetStatusRequest < Struct.new(
      :assessment_id,
      :control_set_id,
      :status,
      :comment)
      SENSITIVE = [:comment]
      include Aws::Structure
    end

    # @!attribute [rw] control_set
    #   The name of the updated control set that the
    #   `UpdateAssessmentControlSetStatus` API returned.
    #   @return [Types::AssessmentControlSet]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentControlSetStatusResponse AWS API Documentation
    #
    class UpdateAssessmentControlSetStatusResponse < Struct.new(
      :control_set)
      SENSITIVE = []
      include Aws::Structure
    end

    # A `controlSet` entity that represents a collection of controls in
    # Audit Manager. This doesn't contain the control set ID.
    #
    # @!attribute [rw] id
    #   The unique identifier for the control set.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the control set.
    #   @return [String]
    #
    # @!attribute [rw] controls
    #   The list of controls that are contained within the control set.
    #   @return [Array<Types::CreateAssessmentFrameworkControl>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentFrameworkControlSet AWS API Documentation
    #
    class UpdateAssessmentFrameworkControlSet < Struct.new(
      :id,
      :name,
      :controls)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] framework_id
    #   The unique identifier for the framework.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the framework to be updated.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The description of the updated framework.
    #   @return [String]
    #
    # @!attribute [rw] compliance_type
    #   The compliance type that the new custom framework supports, such as
    #   CIS or HIPAA.
    #   @return [String]
    #
    # @!attribute [rw] control_sets
    #   The control sets that are associated with the framework.
    #   @return [Array<Types::UpdateAssessmentFrameworkControlSet>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentFrameworkRequest AWS API Documentation
    #
    class UpdateAssessmentFrameworkRequest < Struct.new(
      :framework_id,
      :name,
      :description,
      :compliance_type,
      :control_sets)
      SENSITIVE = [:compliance_type]
      include Aws::Structure
    end

    # @!attribute [rw] framework
    #   The name of the framework.
    #   @return [Types::Framework]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentFrameworkResponse AWS API Documentation
    #
    class UpdateAssessmentFrameworkResponse < Struct.new(
      :framework)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] request_id
    #   The unique identifier for the share request.
    #   @return [String]
    #
    # @!attribute [rw] request_type
    #   Specifies whether the share request is a sent request or a received
    #   request.
    #   @return [String]
    #
    # @!attribute [rw] action
    #   Specifies the update action for the share request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentFrameworkShareRequest AWS API Documentation
    #
    class UpdateAssessmentFrameworkShareRequest < Struct.new(
      :request_id,
      :request_type,
      :action)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_framework_share_request
    #   The updated share request that's returned by the
    #   `UpdateAssessmentFrameworkShare` operation.
    #   @return [Types::AssessmentFrameworkShareRequest]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentFrameworkShareResponse AWS API Documentation
    #
    class UpdateAssessmentFrameworkShareResponse < Struct.new(
      :assessment_framework_share_request)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] assessment_name
    #   The name of the assessment to be updated.
    #   @return [String]
    #
    # @!attribute [rw] assessment_description
    #   The description of the assessment.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   The scope of the assessment.
    #   @return [Types::Scope]
    #
    # @!attribute [rw] assessment_reports_destination
    #   The assessment report storage destination for the assessment that's
    #   being updated.
    #   @return [Types::AssessmentReportsDestination]
    #
    # @!attribute [rw] roles
    #   The list of roles for the assessment.
    #   @return [Array<Types::Role>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentRequest AWS API Documentation
    #
    class UpdateAssessmentRequest < Struct.new(
      :assessment_id,
      :assessment_name,
      :assessment_description,
      :scope,
      :assessment_reports_destination,
      :roles)
      SENSITIVE = [:assessment_name, :assessment_description, :scope, :assessment_reports_destination, :roles]
      include Aws::Structure
    end

    # @!attribute [rw] assessment
    #   The response object for the `UpdateAssessment` API. This is the name
    #   of the updated assessment.
    #   @return [Types::Assessment]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentResponse AWS API Documentation
    #
    class UpdateAssessmentResponse < Struct.new(
      :assessment)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment_id
    #   The unique identifier for the assessment.
    #   @return [String]
    #
    # @!attribute [rw] status
    #   The current status of the assessment.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentStatusRequest AWS API Documentation
    #
    class UpdateAssessmentStatusRequest < Struct.new(
      :assessment_id,
      :status)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] assessment
    #   The name of the updated assessment that the `UpdateAssessmentStatus`
    #   API returned.
    #   @return [Types::Assessment]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateAssessmentStatusResponse AWS API Documentation
    #
    class UpdateAssessmentStatusResponse < Struct.new(
      :assessment)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] control_id
    #   The identifier for the control.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the updated control.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   The optional description of the control.
    #   @return [String]
    #
    # @!attribute [rw] testing_information
    #   The steps that you should follow to determine if the control is met.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_title
    #   The title of the action plan for remediating the control.
    #   @return [String]
    #
    # @!attribute [rw] action_plan_instructions
    #   The recommended actions to carry out if the control isn't
    #   fulfilled.
    #   @return [String]
    #
    # @!attribute [rw] control_mapping_sources
    #   The data mapping sources for the control.
    #   @return [Array<Types::ControlMappingSource>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateControlRequest AWS API Documentation
    #
    class UpdateControlRequest < Struct.new(
      :control_id,
      :name,
      :description,
      :testing_information,
      :action_plan_title,
      :action_plan_instructions,
      :control_mapping_sources)
      SENSITIVE = [:description, :testing_information, :action_plan_title, :action_plan_instructions]
      include Aws::Structure
    end

    # @!attribute [rw] control
    #   The name of the updated control set that the `UpdateControl` API
    #   returned.
    #   @return [Types::Control]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateControlResponse AWS API Documentation
    #
    class UpdateControlResponse < Struct.new(
      :control)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] sns_topic
    #   The Amazon Simple Notification Service (Amazon SNS) topic that Audit
    #   Manager sends notifications to.
    #   @return [String]
    #
    # @!attribute [rw] default_assessment_reports_destination
    #   The default S3 destination bucket for storing assessment reports.
    #   @return [Types::AssessmentReportsDestination]
    #
    # @!attribute [rw] default_process_owners
    #   A list of the default audit owners.
    #   @return [Array<Types::Role>]
    #
    # @!attribute [rw] kms_key
    #   The KMS key details.
    #   @return [String]
    #
    # @!attribute [rw] evidence_finder_enabled
    #   Specifies whether the evidence finder feature is enabled. Change
    #   this attribute to enable or disable evidence finder.
    #
    #   When you use this attribute to disable evidence finder, Audit
    #   Manager deletes the event data store that’s used to query your
    #   evidence data. As a result, you can’t re-enable evidence finder and
    #   use the feature again. Your only alternative is to [deregister][1]
    #   and then [re-register][2] Audit Manager.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_DeregisterAccount.html
    #   [2]: https://docs.aws.amazon.com/audit-manager/latest/APIReference/API_RegisterAccount.html
    #   @return [Boolean]
    #
    # @!attribute [rw] deregistration_policy
    #   The deregistration policy for your Audit Manager data. You can use
    #   this attribute to determine how your data is handled when you
    #   deregister Audit Manager.
    #   @return [Types::DeregistrationPolicy]
    #
    # @!attribute [rw] default_export_destination
    #   The default S3 destination bucket for storing evidence finder
    #   exports.
    #   @return [Types::DefaultExportDestination]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateSettingsRequest AWS API Documentation
    #
    class UpdateSettingsRequest < Struct.new(
      :sns_topic,
      :default_assessment_reports_destination,
      :default_process_owners,
      :kms_key,
      :evidence_finder_enabled,
      :deregistration_policy,
      :default_export_destination)
      SENSITIVE = [:default_assessment_reports_destination, :default_process_owners]
      include Aws::Structure
    end

    # @!attribute [rw] settings
    #   The current list of settings.
    #   @return [Types::Settings]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/UpdateSettingsResponse AWS API Documentation
    #
    class UpdateSettingsResponse < Struct.new(
      :settings)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] s3_relative_path
    #   The relative path of the Amazon S3 bucket that the assessment report
    #   is stored in.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ValidateAssessmentReportIntegrityRequest AWS API Documentation
    #
    class ValidateAssessmentReportIntegrityRequest < Struct.new(
      :s3_relative_path)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] signature_valid
    #   Specifies whether the signature key is valid.
    #   @return [Boolean]
    #
    # @!attribute [rw] signature_algorithm
    #   The signature algorithm that's used to code sign the assessment
    #   report file.
    #   @return [String]
    #
    # @!attribute [rw] signature_date_time
    #   The date and time signature that specifies when the assessment
    #   report was created.
    #   @return [String]
    #
    # @!attribute [rw] signature_key_id
    #   The unique identifier for the validation signature key.
    #   @return [String]
    #
    # @!attribute [rw] validation_errors
    #   Represents any errors that occurred when validating the assessment
    #   report.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ValidateAssessmentReportIntegrityResponse AWS API Documentation
    #
    class ValidateAssessmentReportIntegrityResponse < Struct.new(
      :signature_valid,
      :signature_algorithm,
      :signature_date_time,
      :signature_key_id,
      :validation_errors)
      SENSITIVE = []
      include Aws::Structure
    end

    # The request has invalid or missing parameters.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @!attribute [rw] reason
    #   The reason the request failed validation.
    #   @return [String]
    #
    # @!attribute [rw] fields
    #   The fields that caused the error, if applicable.
    #   @return [Array<Types::ValidationExceptionField>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ValidationException AWS API Documentation
    #
    class ValidationException < Struct.new(
      :message,
      :reason,
      :fields)
      SENSITIVE = []
      include Aws::Structure
    end

    # Indicates that the request has invalid or missing parameters for the
    # field.
    #
    # @!attribute [rw] name
    #   The name of the validation error.
    #   @return [String]
    #
    # @!attribute [rw] message
    #   The body of the error message.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/auditmanager-2017-07-25/ValidationExceptionField AWS API Documentation
    #
    class ValidationExceptionField < Struct.new(
      :name,
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

  end
end