lib/aws/generated/config.ex

# WARNING: DO NOT EDIT, AUTO-GENERATED CODE!
# See https://github.com/aws-beam/aws-codegen for more details.

defmodule AWS.Config do
  @moduledoc """
  Config

  Config provides a way to keep track of the configurations of all the Amazon Web
  Services resources associated with your Amazon Web Services account.

  You can use Config to get the current and historical configurations of each
  Amazon Web Services resource and also to get information about the relationship
  between the resources. An Amazon Web Services resource can be an Amazon Compute
  Cloud (Amazon EC2) instance, an Elastic Block Store (EBS) volume, an elastic
  network Interface (ENI), or a security group. For a complete list of resources
  currently supported by Config, see [Supported Amazon Web Services resources](https://docs.aws.amazon.com/config/latest/developerguide/resource-config-reference.html#supported-resources).

  You can access and manage Config through the Amazon Web Services Management
  Console, the Amazon Web Services Command Line Interface (Amazon Web Services
  CLI), the Config API, or the Amazon Web Services SDKs for Config. This reference
  guide contains documentation for the Config API and the Amazon Web Services CLI
  commands that you can use to manage Config. The Config API uses the Signature
  Version 4 protocol for signing requests. For more information about how to sign
  a request with this protocol, see [Signature Version 4 Signing Process](https://docs.aws.amazon.com/general/latest/gr/signature-version-4.html).
  For detailed information about Config features and their associated actions or
  commands, as well as how to work with Amazon Web Services Management Console,
  see [What Is Config](https://docs.aws.amazon.com/config/latest/developerguide/WhatIsConfig.html)
  in the *Config Developer Guide*.
  """

  alias AWS.Client
  alias AWS.Request

  def metadata do
    %AWS.ServiceMetadata{
      abbreviation: "Config Service",
      api_version: "2014-11-12",
      content_type: "application/x-amz-json-1.1",
      credential_scope: nil,
      endpoint_prefix: "config",
      global?: false,
      protocol: "json",
      service_id: "Config Service",
      signature_version: "v4",
      signing_name: "config",
      target_prefix: "StarlingDoveService"
    }
  end

  @doc """
  Returns the current configuration items for resources that are present in your
  Config aggregator.

  The operation also returns a list of resources that are not processed in the
  current request. If there are no unprocessed resources, the operation returns an
  empty `unprocessedResourceIdentifiers` list.

     The API does not return results for deleted resources.

     The API does not return tags and relationships.
  """
  def batch_get_aggregate_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "BatchGetAggregateResourceConfig", input, options)
  end

  @doc """
  Returns the `BaseConfigurationItem` for one or more requested resources.

  The operation also returns a list of resources that are not processed in the
  current request. If there are no unprocessed resources, the operation returns an
  empty unprocessedResourceKeys list.

     The API does not return results for deleted resources.

     The API does not return any tags for the requested resources. This
  information is filtered out of the supplementaryConfiguration section of the API
  response.
  """
  def batch_get_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "BatchGetResourceConfig", input, options)
  end

  @doc """
  Deletes the authorization granted to the specified configuration aggregator
  account in a specified region.
  """
  def delete_aggregation_authorization(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteAggregationAuthorization", input, options)
  end

  @doc """
  Deletes the specified Config rule and all of its evaluation results.

  Config sets the state of a rule to `DELETING` until the deletion is complete.
  You cannot update a rule while it is in this state. If you make a
  `PutConfigRule` or `DeleteConfigRule` request for the rule, you will receive a
  `ResourceInUseException`.

  You can check the state of a rule by using the `DescribeConfigRules` request.
  """
  def delete_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteConfigRule", input, options)
  end

  @doc """
  Deletes the specified configuration aggregator and the aggregated data
  associated with the aggregator.
  """
  def delete_configuration_aggregator(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteConfigurationAggregator", input, options)
  end

  @doc """
  Deletes the configuration recorder.

  After the configuration recorder is deleted, Config will not record resource
  configuration changes until you create a new configuration recorder.

  This action does not delete the configuration information that was previously
  recorded. You will be able to access the previously recorded information by
  using the `GetResourceConfigHistory` action, but you will not be able to access
  this information in the Config console until you create a new configuration
  recorder.
  """
  def delete_configuration_recorder(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteConfigurationRecorder", input, options)
  end

  @doc """
  Deletes the specified conformance pack and all the Config rules, remediation
  actions, and all evaluation results within that conformance pack.

  Config sets the conformance pack to `DELETE_IN_PROGRESS` until the deletion is
  complete. You cannot update a conformance pack while it is in this state.
  """
  def delete_conformance_pack(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteConformancePack", input, options)
  end

  @doc """
  Deletes the delivery channel.

  Before you can delete the delivery channel, you must stop the configuration
  recorder by using the `StopConfigurationRecorder` action.
  """
  def delete_delivery_channel(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteDeliveryChannel", input, options)
  end

  @doc """
  Deletes the evaluation results for the specified Config rule.

  You can specify one Config rule per request. After you delete the evaluation
  results, you can call the `StartConfigRulesEvaluation` API to start evaluating
  your Amazon Web Services resources against the rule.
  """
  def delete_evaluation_results(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteEvaluationResults", input, options)
  end

  @doc """
  Deletes the specified organization config rule and all of its evaluation results
  from all member accounts in that organization.

  Only a master account and a delegated administrator account can delete an
  organization config rule. When calling this API with a delegated administrator,
  you must ensure Organizations `ListDelegatedAdministrator` permissions are
  added.

  Config sets the state of a rule to DELETE_IN_PROGRESS until the deletion is
  complete. You cannot update a rule while it is in this state.
  """
  def delete_organization_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteOrganizationConfigRule", input, options)
  end

  @doc """
  Deletes the specified organization conformance pack and all of the config rules
  and remediation actions from all member accounts in that organization.

  Only a master account or a delegated administrator account can delete an
  organization conformance pack. When calling this API with a delegated
  administrator, you must ensure Organizations `ListDelegatedAdministrator`
  permissions are added.

  Config sets the state of a conformance pack to DELETE_IN_PROGRESS until the
  deletion is complete. You cannot update a conformance pack while it is in this
  state.
  """
  def delete_organization_conformance_pack(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteOrganizationConformancePack", input, options)
  end

  @doc """
  Deletes pending authorization requests for a specified aggregator account in a
  specified region.
  """
  def delete_pending_aggregation_request(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeletePendingAggregationRequest", input, options)
  end

  @doc """
  Deletes the remediation configuration.
  """
  def delete_remediation_configuration(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteRemediationConfiguration", input, options)
  end

  @doc """
  Deletes one or more remediation exceptions mentioned in the resource keys.

  Config generates a remediation exception when a problem occurs executing a
  remediation action to a specific resource. Remediation exceptions blocks
  auto-remediation until the exception is cleared.
  """
  def delete_remediation_exceptions(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteRemediationExceptions", input, options)
  end

  @doc """
  Records the configuration state for a custom resource that has been deleted.

  This API records a new ConfigurationItem with a ResourceDeleted status. You can
  retrieve the ConfigurationItems recorded for this resource in your Config
  History.
  """
  def delete_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteResourceConfig", input, options)
  end

  @doc """
  Deletes the retention configuration.
  """
  def delete_retention_configuration(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteRetentionConfiguration", input, options)
  end

  @doc """
  Deletes the stored query for a single Amazon Web Services account and a single
  Amazon Web Services Region.
  """
  def delete_stored_query(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeleteStoredQuery", input, options)
  end

  @doc """
  Schedules delivery of a configuration snapshot to the Amazon S3 bucket in the
  specified delivery channel.

  After the delivery has started, Config sends the following notifications using
  an Amazon SNS topic that you have specified.

    * Notification of the start of the delivery.

    * Notification of the completion of the delivery, if the delivery
  was successfully completed.

    * Notification of delivery failure, if the delivery failed.
  """
  def deliver_config_snapshot(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DeliverConfigSnapshot", input, options)
  end

  @doc """
  Returns a list of compliant and noncompliant rules with the number of resources
  for compliant and noncompliant rules.

  Does not display rules that do not have compliance results.

  The results can return an empty result page, but if you have a `nextToken`, the
  results are displayed on the next page.
  """
  def describe_aggregate_compliance_by_config_rules(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeAggregateComplianceByConfigRules",
      input,
      options
    )
  end

  @doc """
  Returns a list of the conformance packs and their associated compliance status
  with the count of compliant and noncompliant Config rules within each
  conformance pack.

  Also returns the total rule count which includes compliant rules, noncompliant
  rules, and rules that cannot be evaluated due to insufficient data.

  The results can return an empty result page, but if you have a `nextToken`, the
  results are displayed on the next page.
  """
  def describe_aggregate_compliance_by_conformance_packs(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeAggregateComplianceByConformancePacks",
      input,
      options
    )
  end

  @doc """
  Returns a list of authorizations granted to various aggregator accounts and
  regions.
  """
  def describe_aggregation_authorizations(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeAggregationAuthorizations", input, options)
  end

  @doc """
  Indicates whether the specified Config rules are compliant.

  If a rule is noncompliant, this action returns the number of Amazon Web Services
  resources that do not comply with the rule.

  A rule is compliant if all of the evaluated resources comply with it. It is
  noncompliant if any of these resources do not comply.

  If Config has no current evaluation results for the rule, it returns
  `INSUFFICIENT_DATA`. This result might indicate one of the following conditions:

    * Config has never invoked an evaluation for the rule. To check
  whether it has, use the `DescribeConfigRuleEvaluationStatus` action to get the
  `LastSuccessfulInvocationTime` and `LastFailedInvocationTime`.

    * The rule's Lambda function is failing to send evaluation results
  to Config. Verify that the role you assigned to your configuration recorder
  includes the `config:PutEvaluations` permission. If the rule is a custom rule,
  verify that the Lambda execution role includes the `config:PutEvaluations`
  permission.

    * The rule's Lambda function has returned `NOT_APPLICABLE` for all
  evaluation results. This can occur if the resources were deleted or removed from
  the rule's scope.
  """
  def describe_compliance_by_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeComplianceByConfigRule", input, options)
  end

  @doc """
  Indicates whether the specified Amazon Web Services resources are compliant.

  If a resource is noncompliant, this action returns the number of Config rules
  that the resource does not comply with.

  A resource is compliant if it complies with all the Config rules that evaluate
  it. It is noncompliant if it does not comply with one or more of these rules.

  If Config has no current evaluation results for the resource, it returns
  `INSUFFICIENT_DATA`. This result might indicate one of the following conditions
  about the rules that evaluate the resource:

    * Config has never invoked an evaluation for the rule. To check
  whether it has, use the `DescribeConfigRuleEvaluationStatus` action to get the
  `LastSuccessfulInvocationTime` and `LastFailedInvocationTime`.

    * The rule's Lambda function is failing to send evaluation results
  to Config. Verify that the role that you assigned to your configuration recorder
  includes the `config:PutEvaluations` permission. If the rule is a custom rule,
  verify that the Lambda execution role includes the `config:PutEvaluations`
  permission.

    * The rule's Lambda function has returned `NOT_APPLICABLE` for all
  evaluation results. This can occur if the resources were deleted or removed from
  the rule's scope.
  """
  def describe_compliance_by_resource(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeComplianceByResource", input, options)
  end

  @doc """
  Returns status information for each of your Config managed rules.

  The status includes information such as the last time Config invoked the rule,
  the last time Config failed to invoke the rule, and the related error for the
  last failure.
  """
  def describe_config_rule_evaluation_status(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConfigRuleEvaluationStatus", input, options)
  end

  @doc """
  Returns details about your Config rules.
  """
  def describe_config_rules(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConfigRules", input, options)
  end

  @doc """
  Returns status information for sources within an aggregator.

  The status includes information about the last time Config verified
  authorization between the source account and an aggregator account. In case of a
  failure, the status contains the related error code or message.
  """
  def describe_configuration_aggregator_sources_status(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeConfigurationAggregatorSourcesStatus",
      input,
      options
    )
  end

  @doc """
  Returns the details of one or more configuration aggregators.

  If the configuration aggregator is not specified, this action returns the
  details for all the configuration aggregators associated with the account.
  """
  def describe_configuration_aggregators(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConfigurationAggregators", input, options)
  end

  @doc """
  Returns the current status of the specified configuration recorder.

  If a configuration recorder is not specified, this action returns the status of
  all configuration recorders associated with the account.

  Currently, you can specify only one configuration recorder per region in your
  account.
  """
  def describe_configuration_recorder_status(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeConfigurationRecorderStatus",
      input,
      options
    )
  end

  @doc """
  Returns the details for the specified configuration recorders.

  If the configuration recorder is not specified, this action returns the details
  for all configuration recorders associated with the account.

  Currently, you can specify only one configuration recorder per region in your
  account.
  """
  def describe_configuration_recorders(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConfigurationRecorders", input, options)
  end

  @doc """
  Returns compliance details for each rule in that conformance pack.

  You must provide exact rule names.
  """
  def describe_conformance_pack_compliance(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConformancePackCompliance", input, options)
  end

  @doc """
  Provides one or more conformance packs deployment status.

  If there are no conformance packs then you will see an empty result.
  """
  def describe_conformance_pack_status(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConformancePackStatus", input, options)
  end

  @doc """
  Returns a list of one or more conformance packs.
  """
  def describe_conformance_packs(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeConformancePacks", input, options)
  end

  @doc """
  Returns the current status of the specified delivery channel.

  If a delivery channel is not specified, this action returns the current status
  of all delivery channels associated with the account.

  Currently, you can specify only one delivery channel per region in your account.
  """
  def describe_delivery_channel_status(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeDeliveryChannelStatus", input, options)
  end

  @doc """
  Returns details about the specified delivery channel.

  If a delivery channel is not specified, this action returns the details of all
  delivery channels associated with the account.

  Currently, you can specify only one delivery channel per region in your account.
  """
  def describe_delivery_channels(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeDeliveryChannels", input, options)
  end

  @doc """
  Provides organization config rule deployment status for an organization.

  The status is not considered successful until organization config rule is
  successfully deployed in all the member accounts with an exception of excluded
  accounts.

  When you specify the limit and the next token, you receive a paginated response.
  Limit and next token are not applicable if you specify organization config rule
  names. It is only applicable, when you request all the organization config
  rules.
  """
  def describe_organization_config_rule_statuses(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeOrganizationConfigRuleStatuses",
      input,
      options
    )
  end

  @doc """
  Returns a list of organization config rules.

  When you specify the limit and the next token, you receive a paginated response.
  Limit and next token are not applicable if you specify organization config rule
  names. It is only applicable, when you request all the organization config
  rules.
  """
  def describe_organization_config_rules(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeOrganizationConfigRules", input, options)
  end

  @doc """
  Provides organization conformance pack deployment status for an organization.

  The status is not considered successful until organization conformance pack is
  successfully deployed in all the member accounts with an exception of excluded
  accounts.

  When you specify the limit and the next token, you receive a paginated response.
  Limit and next token are not applicable if you specify organization conformance
  pack names. They are only applicable, when you request all the organization
  conformance packs.
  """
  def describe_organization_conformance_pack_statuses(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeOrganizationConformancePackStatuses",
      input,
      options
    )
  end

  @doc """
  Returns a list of organization conformance packs.

  When you specify the limit and the next token, you receive a paginated response.

  Limit and next token are not applicable if you specify organization conformance
  packs names. They are only applicable, when you request all the organization
  conformance packs.
  """
  def describe_organization_conformance_packs(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "DescribeOrganizationConformancePacks",
      input,
      options
    )
  end

  @doc """
  Returns a list of all pending aggregation requests.
  """
  def describe_pending_aggregation_requests(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribePendingAggregationRequests", input, options)
  end

  @doc """
  Returns the details of one or more remediation configurations.
  """
  def describe_remediation_configurations(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeRemediationConfigurations", input, options)
  end

  @doc """
  Returns the details of one or more remediation exceptions.

  A detailed view of a remediation exception for a set of resources that includes
  an explanation of an exception and the time when the exception will be deleted.
  When you specify the limit and the next token, you receive a paginated response.

  Config generates a remediation exception when a problem occurs executing a
  remediation action to a specific resource. Remediation exceptions blocks
  auto-remediation until the exception is cleared.

  When you specify the limit and the next token, you receive a paginated response.

  Limit and next token are not applicable if you request resources in batch. It is
  only applicable, when you request all resources.
  """
  def describe_remediation_exceptions(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeRemediationExceptions", input, options)
  end

  @doc """
  Provides a detailed view of a Remediation Execution for a set of resources
  including state, timestamps for when steps for the remediation execution occur,
  and any error messages for steps that have failed.

  When you specify the limit and the next token, you receive a paginated response.
  """
  def describe_remediation_execution_status(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeRemediationExecutionStatus", input, options)
  end

  @doc """
  Returns the details of one or more retention configurations.

  If the retention configuration name is not specified, this action returns the
  details for all the retention configurations for that account.

  Currently, Config supports only one retention configuration per region in your
  account.
  """
  def describe_retention_configurations(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "DescribeRetentionConfigurations", input, options)
  end

  @doc """
  Returns the evaluation results for the specified Config rule for a specific
  resource in a rule.

  The results indicate which Amazon Web Services resources were evaluated by the
  rule, when each resource was last evaluated, and whether each resource complies
  with the rule.

  The results can return an empty result page. But if you have a `nextToken`, the
  results are displayed on the next page.
  """
  def get_aggregate_compliance_details_by_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetAggregateComplianceDetailsByConfigRule",
      input,
      options
    )
  end

  @doc """
  Returns the number of compliant and noncompliant rules for one or more accounts
  and regions in an aggregator.

  The results can return an empty result page, but if you have a nextToken, the
  results are displayed on the next page.
  """
  def get_aggregate_config_rule_compliance_summary(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetAggregateConfigRuleComplianceSummary",
      input,
      options
    )
  end

  @doc """
  Returns the count of compliant and noncompliant conformance packs across all
  Amazon Web Services accounts and Amazon Web Services Regions in an aggregator.

  You can filter based on Amazon Web Services account ID or Amazon Web Services
  Region.

  The results can return an empty result page, but if you have a nextToken, the
  results are displayed on the next page.
  """
  def get_aggregate_conformance_pack_compliance_summary(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetAggregateConformancePackComplianceSummary",
      input,
      options
    )
  end

  @doc """
  Returns the resource counts across accounts and regions that are present in your
  Config aggregator.

  You can request the resource counts by providing filters and GroupByKey.

  For example, if the input contains accountID 12345678910 and region us-east-1 in
  filters, the API returns the count of resources in account ID 12345678910 and
  region us-east-1. If the input contains ACCOUNT_ID as a GroupByKey, the API
  returns resource counts for all source accounts that are present in your
  aggregator.
  """
  def get_aggregate_discovered_resource_counts(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetAggregateDiscoveredResourceCounts",
      input,
      options
    )
  end

  @doc """
  Returns configuration item that is aggregated for your specific resource in a
  specific source account and region.
  """
  def get_aggregate_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetAggregateResourceConfig", input, options)
  end

  @doc """
  Returns the evaluation results for the specified Config rule.

  The results indicate which Amazon Web Services resources were evaluated by the
  rule, when each resource was last evaluated, and whether each resource complies
  with the rule.
  """
  def get_compliance_details_by_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetComplianceDetailsByConfigRule", input, options)
  end

  @doc """
  Returns the evaluation results for the specified Amazon Web Services resource.

  The results indicate which Config rules were used to evaluate the resource, when
  each rule was last used, and whether the resource complies with each rule.
  """
  def get_compliance_details_by_resource(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetComplianceDetailsByResource", input, options)
  end

  @doc """
  Returns the number of Config rules that are compliant and noncompliant, up to a
  maximum of 25 for each.
  """
  def get_compliance_summary_by_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetComplianceSummaryByConfigRule", input, options)
  end

  @doc """
  Returns the number of resources that are compliant and the number that are
  noncompliant.

  You can specify one or more resource types to get these numbers for each
  resource type. The maximum number returned is 100.
  """
  def get_compliance_summary_by_resource_type(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetComplianceSummaryByResourceType", input, options)
  end

  @doc """
  Returns compliance details of a conformance pack for all Amazon Web Services
  resources that are monitered by conformance pack.
  """
  def get_conformance_pack_compliance_details(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetConformancePackComplianceDetails",
      input,
      options
    )
  end

  @doc """
  Returns compliance details for the conformance pack based on the cumulative
  compliance results of all the rules in that conformance pack.
  """
  def get_conformance_pack_compliance_summary(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetConformancePackComplianceSummary",
      input,
      options
    )
  end

  @doc """
  Returns the resource types, the number of each resource type, and the total
  number of resources that Config is recording in this region for your Amazon Web
  Services account.

  ## Example

    1. Config is recording three resource types in the US East (Ohio)
  Region for your account: 25 EC2 instances, 20 IAM users, and 15 S3 buckets.

    2. You make a call to the `GetDiscoveredResourceCounts` action and
  specify that you want all resource types.

    3. Config returns the following:

      * The resource types (EC2 instances, IAM users, and S3
  buckets).

      * The number of each resource type (25, 20, and 15).

      * The total number of all resources (60).

  The response is paginated. By default, Config lists 100 `ResourceCount` objects
  on each page. You can customize this number with the `limit` parameter. The
  response includes a `nextToken` string. To get the next page of results, run the
  request again and specify the string for the `nextToken` parameter.

  If you make a call to the `GetDiscoveredResourceCounts` action, you might not
  immediately receive resource counts in the following situations:

     You are a new Config customer.

     You just enabled resource recording.

  It might take a few minutes for Config to record and count your resources. Wait
  a few minutes and then retry the `GetDiscoveredResourceCounts` action.
  """
  def get_discovered_resource_counts(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetDiscoveredResourceCounts", input, options)
  end

  @doc """
  Returns detailed status for each member account within an organization for a
  given organization config rule.
  """
  def get_organization_config_rule_detailed_status(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetOrganizationConfigRuleDetailedStatus",
      input,
      options
    )
  end

  @doc """
  Returns detailed status for each member account within an organization for a
  given organization conformance pack.
  """
  def get_organization_conformance_pack_detailed_status(%Client{} = client, input, options \\ []) do
    Request.request_post(
      client,
      metadata(),
      "GetOrganizationConformancePackDetailedStatus",
      input,
      options
    )
  end

  @doc """
  Returns a list of `ConfigurationItems` for the specified resource.

  The list contains details about each state of the resource during the specified
  time interval. If you specified a retention period to retain your
  `ConfigurationItems` between a minimum of 30 days and a maximum of 7 years (2557
  days), Config returns the `ConfigurationItems` for the specified retention
  period.

  The response is paginated. By default, Config returns a limit of 10
  configuration items per page. You can customize this number with the `limit`
  parameter. The response includes a `nextToken` string. To get the next page of
  results, run the request again and specify the string for the `nextToken`
  parameter.

  Each call to the API is limited to span a duration of seven days. It is likely
  that the number of records returned is smaller than the specified `limit`. In
  such cases, you can make another call, using the `nextToken`.
  """
  def get_resource_config_history(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetResourceConfigHistory", input, options)
  end

  @doc """
  Returns the details of a specific stored query.
  """
  def get_stored_query(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "GetStoredQuery", input, options)
  end

  @doc """
  Accepts a resource type and returns a list of resource identifiers that are
  aggregated for a specific resource type across accounts and regions.

  A resource identifier includes the resource type, ID, (if available) the custom
  resource name, source account, and source region. You can narrow the results to
  include only resources that have specific resource IDs, or a resource name, or
  source account ID, or source region.

  For example, if the input consists of accountID 12345678910 and the region is
  us-east-1 for resource type `AWS::EC2::Instance` then the API returns all the
  EC2 instance identifiers of accountID 12345678910 and region us-east-1.
  """
  def list_aggregate_discovered_resources(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "ListAggregateDiscoveredResources", input, options)
  end

  @doc """
  Accepts a resource type and returns a list of resource identifiers for the
  resources of that type.

  A resource identifier includes the resource type, ID, and (if available) the
  custom resource name. The results consist of resources that Config has
  discovered, including those that Config is not currently recording. You can
  narrow the results to include only resources that have specific resource IDs or
  a resource name.

  You can specify either resource IDs or a resource name, but not both, in the
  same request.

  The response is paginated. By default, Config lists 100 resource identifiers on
  each page. You can customize this number with the `limit` parameter. The
  response includes a `nextToken` string. To get the next page of results, run the
  request again and specify the string for the `nextToken` parameter.
  """
  def list_discovered_resources(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "ListDiscoveredResources", input, options)
  end

  @doc """
  Lists the stored queries for a single Amazon Web Services account and a single
  Amazon Web Services Region.

  The default is 100.
  """
  def list_stored_queries(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "ListStoredQueries", input, options)
  end

  @doc """
  List the tags for Config resource.
  """
  def list_tags_for_resource(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "ListTagsForResource", input, options)
  end

  @doc """
  Authorizes the aggregator account and region to collect data from the source
  account and region.
  """
  def put_aggregation_authorization(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutAggregationAuthorization", input, options)
  end

  @doc """
  Adds or updates an Config rule for evaluating whether your Amazon Web Services
  resources comply with your desired configurations.

  You can use this action for custom Config rules and Config managed rules. A
  custom Config rule is a rule that you develop and maintain. An Config managed
  rule is a customizable, predefined rule that Config provides.

  If you are adding a new custom Config rule, you must first create the Lambda
  function that the rule invokes to evaluate your resources. When you use the
  `PutConfigRule` action to add the rule to Config, you must specify the Amazon
  Resource Name (ARN) that Lambda assigns to the function. Specify the ARN for the
  `SourceIdentifier` key. This key is part of the `Source` object, which is part
  of the `ConfigRule` object.

  If you are adding an Config managed rule, specify the rule's identifier for the
  `SourceIdentifier` key. To reference Config managed rule identifiers, see [About Config managed
  rules](https://docs.aws.amazon.com/config/latest/developerguide/evaluate-config_use-managed-rules.html).

  For any new rule that you add, specify the `ConfigRuleName` in the `ConfigRule`
  object. Do not specify the `ConfigRuleArn` or the `ConfigRuleId`. These values
  are generated by Config for new rules.

  If you are updating a rule that you added previously, you can specify the rule
  by `ConfigRuleName`, `ConfigRuleId`, or `ConfigRuleArn` in the `ConfigRule` data
  type that you use in this request.

  The maximum number of rules that Config supports is 150.

  For information about requesting a rule limit increase, see [Config Limits](http://docs.aws.amazon.com/general/latest/gr/aws_service_limits.html#limits_config)
  in the *Amazon Web Services General Reference Guide*.

  For more information about developing and using Config rules, see [Evaluating Amazon Web Services resource Configurations with
  Config](https://docs.aws.amazon.com/config/latest/developerguide/evaluate-config.html)
  in the *Config Developer Guide*.
  """
  def put_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutConfigRule", input, options)
  end

  @doc """
  Creates and updates the configuration aggregator with the selected source
  accounts and regions.

  The source account can be individual account(s) or an organization.

  `accountIds` that are passed will be replaced with existing accounts. If you
  want to add additional accounts into the aggregator, call `DescribeAggregator`
  to get the previous accounts and then append new ones.

  Config should be enabled in source accounts and regions you want to aggregate.

  If your source type is an organization, you must be signed in to the management
  account or a registered delegated administrator and all the features must be
  enabled in your organization. If the caller is a management account, Config
  calls `EnableAwsServiceAccess` API to enable integration between Config and
  Organizations. If the caller is a registered delegated administrator, Config
  calls `ListDelegatedAdministrators` API to verify whether the caller is a valid
  delegated administrator.

  To register a delegated administrator, see [Register a Delegated Administrator](https://docs.aws.amazon.com/config/latest/developerguide/set-up-aggregator-cli.html#register-a-delegated-administrator-cli)
  in the Config developer guide.
  """
  def put_configuration_aggregator(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutConfigurationAggregator", input, options)
  end

  @doc """
  Creates a new configuration recorder to record the selected resource
  configurations.

  You can use this action to change the role `roleARN` or the `recordingGroup` of
  an existing recorder. To change the role, call the action on the existing
  configuration recorder and specify a role.

  Currently, you can specify only one configuration recorder per region in your
  account.

  If `ConfigurationRecorder` does not have the **recordingGroup** parameter
  specified, the default is to record all supported resource types.
  """
  def put_configuration_recorder(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutConfigurationRecorder", input, options)
  end

  @doc """
  Creates or updates a conformance pack.

  A conformance pack is a collection of Config rules that can be easily deployed
  in an account and a region and across Amazon Web Services Organization.

  This API creates a service linked role `AWSServiceRoleForConfigConforms` in your
  account. The service linked role is created only when the role does not exist in
  your account.

  You must specify either the `TemplateS3Uri` or the `TemplateBody` parameter, but
  not both. If you provide both Config uses the `TemplateS3Uri` parameter and
  ignores the `TemplateBody` parameter.
  """
  def put_conformance_pack(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutConformancePack", input, options)
  end

  @doc """
  Creates a delivery channel object to deliver configuration information to an
  Amazon S3 bucket and Amazon SNS topic.

  Before you can create a delivery channel, you must create a configuration
  recorder.

  You can use this action to change the Amazon S3 bucket or an Amazon SNS topic of
  the existing delivery channel. To change the Amazon S3 bucket or an Amazon SNS
  topic, call this action and specify the changed values for the S3 bucket and the
  SNS topic. If you specify a different value for either the S3 bucket or the SNS
  topic, this action will keep the existing value for the parameter that is not
  changed.

  You can have only one delivery channel per region in your account.
  """
  def put_delivery_channel(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutDeliveryChannel", input, options)
  end

  @doc """
  Used by an Lambda function to deliver evaluation results to Config.

  This action is required in every Lambda function that is invoked by an Config
  rule.
  """
  def put_evaluations(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutEvaluations", input, options)
  end

  @doc """
  Add or updates the evaluations for process checks.

  This API checks if the rule is a process check when the name of the Config rule
  is provided.
  """
  def put_external_evaluation(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutExternalEvaluation", input, options)
  end

  @doc """
  Adds or updates organization config rule for your entire organization evaluating
  whether your Amazon Web Services resources comply with your desired
  configurations.

  Only a master account and a delegated administrator can create or update an
  organization config rule. When calling this API with a delegated administrator,
  you must ensure Organizations `ListDelegatedAdministrator` permissions are
  added.

  This API enables organization service access through the
  `EnableAWSServiceAccess` action and creates a service linked role
  `AWSServiceRoleForConfigMultiAccountSetup` in the master or delegated
  administrator account of your organization. The service linked role is created
  only when the role does not exist in the caller account. Config verifies the
  existence of role with `GetRole` action.

  To use this API with delegated administrator, register a delegated administrator
  by calling Amazon Web Services Organization `register-delegated-administrator`
  for `config-multiaccountsetup.amazonaws.com`.

  You can use this action to create both custom Config rules and Config managed
  rules. If you are adding a new custom Config rule, you must first create Lambda
  function in the master account or a delegated administrator that the rule
  invokes to evaluate your resources. You also need to create an IAM role in the
  managed-account that can be assumed by the Lambda function. When you use the
  `PutOrganizationConfigRule` action to add the rule to Config, you must specify
  the Amazon Resource Name (ARN) that Lambda assigns to the function. If you are
  adding an Config managed rule, specify the rule's identifier for the
  `RuleIdentifier` key.

  The maximum number of organization config rules that Config supports is 150 and
  3 delegated administrator per organization.

  Prerequisite: Ensure you call `EnableAllFeatures` API to enable all features in
  an organization.

  Specify either `OrganizationCustomRuleMetadata` or
  `OrganizationManagedRuleMetadata`.
  """
  def put_organization_config_rule(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutOrganizationConfigRule", input, options)
  end

  @doc """
  Deploys conformance packs across member accounts in an Amazon Web Services
  Organization.

  Only a master account and a delegated administrator can call this API. When
  calling this API with a delegated administrator, you must ensure Organizations
  `ListDelegatedAdministrator` permissions are added.

  This API enables organization service access for
  `config-multiaccountsetup.amazonaws.com` through the `EnableAWSServiceAccess`
  action and creates a service linked role
  `AWSServiceRoleForConfigMultiAccountSetup` in the master or delegated
  administrator account of your organization. The service linked role is created
  only when the role does not exist in the caller account. To use this API with
  delegated administrator, register a delegated administrator by calling Amazon
  Web Services Organization `register-delegate-admin` for
  `config-multiaccountsetup.amazonaws.com`.

  Prerequisite: Ensure you call `EnableAllFeatures` API to enable all features in
  an organization.

  You must specify either the `TemplateS3Uri` or the `TemplateBody` parameter, but
  not both. If you provide both Config uses the `TemplateS3Uri` parameter and
  ignores the `TemplateBody` parameter.

  Config sets the state of a conformance pack to CREATE_IN_PROGRESS and
  UPDATE_IN_PROGRESS until the conformance pack is created or updated. You cannot
  update a conformance pack while it is in this state.

  You can create 50 conformance packs with 25 Config rules in each pack and 3
  delegated administrator per organization.
  """
  def put_organization_conformance_pack(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutOrganizationConformancePack", input, options)
  end

  @doc """
  Adds or updates the remediation configuration with a specific Config rule with
  the selected target or action.

  The API creates the `RemediationConfiguration` object for the Config rule. The
  Config rule must already exist for you to add a remediation configuration. The
  target (SSM document) must exist and have permissions to use the target.

  If you make backward incompatible changes to the SSM document, you must call
  this again to ensure the remediations can run.

  This API does not support adding remediation configurations for service-linked
  Config Rules such as Organization Config rules, the rules deployed by
  conformance packs, and rules deployed by Amazon Web Services Security Hub.
  """
  def put_remediation_configurations(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutRemediationConfigurations", input, options)
  end

  @doc """
  A remediation exception is when a specific resource is no longer considered for
  auto-remediation.

  This API adds a new exception or updates an existing exception for a specific
  resource with a specific Config rule.

  Config generates a remediation exception when a problem occurs executing a
  remediation action to a specific resource. Remediation exceptions blocks
  auto-remediation until the exception is cleared.
  """
  def put_remediation_exceptions(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutRemediationExceptions", input, options)
  end

  @doc """
  Records the configuration state for the resource provided in the request.

  The configuration state of a resource is represented in Config as Configuration
  Items. Once this API records the configuration item, you can retrieve the list
  of configuration items for the custom resource type using existing Config APIs.

  The custom resource type must be registered with CloudFormation. This API
  accepts the configuration item registered with CloudFormation.

  When you call this API, Config only stores configuration state of the resource
  provided in the request. This API does not change or remediate the configuration
  of the resource.

  Write-only schema properites are not recorded as part of the published
  configuration item.
  """
  def put_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutResourceConfig", input, options)
  end

  @doc """
  Creates and updates the retention configuration with details about retention
  period (number of days) that Config stores your historical information.

  The API creates the `RetentionConfiguration` object and names the object as
  **default**. When you have a `RetentionConfiguration` object named **default**,
  calling the API modifies the default object.

  Currently, Config supports only one retention configuration per region in your
  account.
  """
  def put_retention_configuration(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutRetentionConfiguration", input, options)
  end

  @doc """
  Saves a new query or updates an existing saved query.

  The `QueryName` must be unique for a single Amazon Web Services account and a
  single Amazon Web Services Region. You can create upto 300 queries in a single
  Amazon Web Services account and a single Amazon Web Services Region.
  """
  def put_stored_query(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "PutStoredQuery", input, options)
  end

  @doc """
  Accepts a structured query language (SQL) SELECT command and an aggregator to
  query configuration state of Amazon Web Services resources across multiple
  accounts and regions, performs the corresponding search, and returns resource
  configurations matching the properties.

  For more information about query components, see the [ ## Query Components
  ](https://docs.aws.amazon.com/config/latest/developerguide/query-components.html)
  section in the Config Developer Guide.

  If you run an aggregation query (i.e., using `GROUP BY` or using aggregate
  functions such as `COUNT`; e.g., `SELECT resourceId, COUNT(*) WHERE resourceType
  = 'AWS::IAM::Role' GROUP BY resourceId`) and do not specify the `MaxResults` or
  the `Limit` query parameters, the default page size is set to 500.

  If you run a non-aggregation query (i.e., not using `GROUP BY` or aggregate
  function; e.g., `SELECT * WHERE resourceType = 'AWS::IAM::Role'`) and do not
  specify the `MaxResults` or the `Limit` query parameters, the default page size
  is set to 25.
  """
  def select_aggregate_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "SelectAggregateResourceConfig", input, options)
  end

  @doc """
  Accepts a structured query language (SQL) `SELECT` command, performs the
  corresponding search, and returns resource configurations matching the
  properties.

  For more information about query components, see the [ ## Query Components
  ](https://docs.aws.amazon.com/config/latest/developerguide/query-components.html)
  section in the Config Developer Guide.
  """
  def select_resource_config(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "SelectResourceConfig", input, options)
  end

  @doc """
  Runs an on-demand evaluation for the specified Config rules against the last
  known configuration state of the resources.

  Use `StartConfigRulesEvaluation` when you want to test that a rule you updated
  is working as expected. `StartConfigRulesEvaluation` does not re-record the
  latest configuration state for your resources. It re-runs an evaluation against
  the last known state of your resources.

  You can specify up to 25 Config rules per request.

  An existing `StartConfigRulesEvaluation` call for the specified rules must
  complete before you can call the API again. If you chose to have Config stream
  to an Amazon SNS topic, you will receive a `ConfigRuleEvaluationStarted`
  notification when the evaluation starts.

  You don't need to call the `StartConfigRulesEvaluation` API to run an evaluation
  for a new rule. When you create a rule, Config evaluates your resources against
  the rule automatically.

  The `StartConfigRulesEvaluation` API is useful if you want to run on-demand
  evaluations, such as the following example:

    1. You have a custom rule that evaluates your IAM resources every 24
  hours.

    2. You update your Lambda function to add additional conditions to
  your rule.

    3. Instead of waiting for the next periodic evaluation, you call the
  `StartConfigRulesEvaluation` API.

    4. Config invokes your Lambda function and evaluates your IAM
  resources.

    5. Your custom rule will still run periodic evaluations every 24
  hours.
  """
  def start_config_rules_evaluation(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "StartConfigRulesEvaluation", input, options)
  end

  @doc """
  Starts recording configurations of the Amazon Web Services resources you have
  selected to record in your Amazon Web Services account.

  You must have created at least one delivery channel to successfully start the
  configuration recorder.
  """
  def start_configuration_recorder(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "StartConfigurationRecorder", input, options)
  end

  @doc """
  Runs an on-demand remediation for the specified Config rules against the last
  known remediation configuration.

  It runs an execution against the current state of your resources. Remediation
  execution is asynchronous.

  You can specify up to 100 resource keys per request. An existing
  StartRemediationExecution call for the specified resource keys must complete
  before you can call the API again.
  """
  def start_remediation_execution(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "StartRemediationExecution", input, options)
  end

  @doc """
  Stops recording configurations of the Amazon Web Services resources you have
  selected to record in your Amazon Web Services account.
  """
  def stop_configuration_recorder(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "StopConfigurationRecorder", input, options)
  end

  @doc """
  Associates the specified tags to a resource with the specified resourceArn.

  If existing tags on a resource are not specified in the request parameters, they
  are not changed. When a resource is deleted, the tags associated with that
  resource are deleted as well.
  """
  def tag_resource(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "TagResource", input, options)
  end

  @doc """
  Deletes specified tags from a resource.
  """
  def untag_resource(%Client{} = client, input, options \\ []) do
    Request.request_post(client, metadata(), "UntagResource", input, options)
  end
end