AWS CLI version 2, the latest major version of AWS CLI, is now stable and recommended for general use. To view this page for the AWS CLI version 2, click here. For more information see the AWS CLI version 2 installation instructions and migration guide.
Creates an Automated Reasoning policy for Amazon Bedrock Guardrails. Automated Reasoning policies use mathematical techniques to detect hallucinations, suggest corrections, and highlight unstated assumptions in the responses of your GenAI application.
To create a policy, you upload a source document that describes the rules that you’re encoding. Automated Reasoning extracts important concepts from the source document that will become variables in the policy and infers policy rules.
See also: AWS API Documentation
create-automated-reasoning-policy
--name <value>
[--description <value>]
[--client-request-token <value>]
[--policy-definition <value>]
[--kms-key-id <value>]
[--tags <value>]
[--cli-input-json <value>]
[--generate-cli-skeleton <value>]
[--debug]
[--endpoint-url <value>]
[--no-verify-ssl]
[--no-paginate]
[--output <value>]
[--query <value>]
[--profile <value>]
[--region <value>]
[--version <value>]
[--color <value>]
[--no-sign-request]
[--ca-bundle <value>]
[--cli-read-timeout <value>]
[--cli-connect-timeout <value>]
--name
(string)
A unique name for the Automated Reasoning policy. The name must be between 1 and 63 characters and can contain letters, numbers, hyphens, and underscores.
--description
(string)
A description of the Automated Reasoning policy. Use this to provide context about the policy’s purpose and the types of validations it performs.
--client-request-token
(string)
A unique, case-sensitive identifier to ensure that the operation completes no more than once. If this token matches a previous request, Amazon Bedrock ignores the request but doesn’t return an error.
--policy-definition
(structure)
The policy definition that contains the formal logic rules, variables, and custom variable types used to validate foundation model responses in your application.
version -> (string)
The version of the policy definition format.types -> (list)
The custom user-defined vairable types used in the policy. Types are enum-based variable types that provide additional context beyond the predefined variable types.
(structure)
Represents a custom user-defined viarble type in an Automated Reasoning policy. Types are enum-based and provide additional context beyond predefined variable types.
name -> (string)
The name of the custom type.description -> (string)
The description of what the custom type represents.values -> (list)
The possible values for this enum-based type, each with its own description.
(structure)
Represents a single value within a custom type definition, including its identifier and description.
value -> (string)
The actual value or identifier for this type value.description -> (string)
A human-readable description explaining what this type value represents and when it should be used.rules -> (list)
The formal logic rules extracted from the source document. Rules define the logical constraints that determine whether model responses are valid, invalid, or satisfiable.
(structure)
Represents a formal logic rule in an Automated Reasoning policy. For example, rules can be expressed as if-then statements that define logical constraints.
id -> (string)
The unique identifier of the rule within the policy.expression -> (string)
The formal logic expression of the rule.alternateExpression -> (string)
The human-readable form of the rule expression, often in natural language or simplified notation.variables -> (list)
The variables that represent concepts in the policy. Variables can have values assigned when translating natural language into formal logic. Their descriptions are crucial for accurate translation.
(structure)
Represents a variable in an Automated Reasoning policy. Variables represent concepts that can have values assigned during natural language translation.
name -> (string)
The name of the variable. Use descriptive names that clearly indicate the concept being represented.type -> (string)
The data type of the variable. Valid types include bool, int, real, enum, and custom types that you can provide.description -> (string)
The description of the variable that explains what it represents and how users might refer to it. Clear and comprehensive descriptions are essential for accurate natural language translation.
JSON Syntax:
{
"version": "string",
"types": [
{
"name": "string",
"description": "string",
"values": [
{
"value": "string",
"description": "string"
}
...
]
}
...
],
"rules": [
{
"id": "string",
"expression": "string",
"alternateExpression": "string"
}
...
],
"variables": [
{
"name": "string",
"type": "string",
"description": "string"
}
...
]
}
--kms-key-id
(string)
The identifier of the KMS key to use for encrypting the automated reasoning policy and its associated artifacts. If you don’t specify a KMS key, Amazon Bedrock uses an KMS managed key for encryption. For enhanced security and control, you can specify a customer managed KMS key.
--tags
(list)
A list of tags to associate with the Automated Reasoning policy. Tags help you organize and manage your policies.
(structure)
Definition of the key/value pair for a tag.
key -> (string)
Key for the tag.value -> (string)
Value for the tag.
Shorthand Syntax:
key=string,value=string ...
JSON Syntax:
[
{
"key": "string",
"value": "string"
}
...
]
--cli-input-json
(string)
Performs service operation based on the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton
. If other arguments are provided on the command line, the CLI values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally.
--generate-cli-skeleton
(string)
Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input
, prints a sample input JSON that can be used as an argument for --cli-input-json
. If provided with the value output
, it validates the command inputs and returns a sample output JSON for that command.
--debug
(boolean)
Turn on debug logging.
--endpoint-url
(string)
Override command’s default URL with the given URL.
--no-verify-ssl
(boolean)
By default, the AWS CLI uses SSL when communicating with AWS services. For each SSL connection, the AWS CLI will verify SSL certificates. This option overrides the default behavior of verifying SSL certificates.
--no-paginate
(boolean)
Disable automatic pagination. If automatic pagination is disabled, the AWS CLI will only make one call, for the first page of results.
--output
(string)
The formatting style for command output.
--query
(string)
A JMESPath query to use in filtering the response data.
--profile
(string)
Use a specific profile from your credential file.
--region
(string)
The region to use. Overrides config/env settings.
--version
(string)
Display the version of this tool.
--color
(string)
Turn on/off color output.
--no-sign-request
(boolean)
Do not sign requests. Credentials will not be loaded if this argument is provided.
--ca-bundle
(string)
The CA certificate bundle to use when verifying SSL certificates. Overrides config/env settings.
--cli-read-timeout
(int)
The maximum socket read time in seconds. If the value is set to 0, the socket read will be blocking and not timeout. The default value is 60 seconds.
--cli-connect-timeout
(int)
The maximum socket connect time in seconds. If the value is set to 0, the socket connect will be blocking and not timeout. The default value is 60 seconds.
policyArn -> (string)
The Amazon Resource Name (ARN) of the Automated Reasoning policy that you created.
version -> (string)
The version number of the newly created Automated Reasoning policy. The initial version is always DRAFT.
name -> (string)
The name of the Automated Reasoning policy.
description -> (string)
The description of the Automated Reasoning policy.
definitionHash -> (string)
The hash of the policy definition. This is used as a concurrency token for creating policy versions that you can use in your application.
createdAt -> (timestamp)
The timestamp when the policy was created.
updatedAt -> (timestamp)
The timestamp when the policy was last updated.