Anthropic Claude on AWS Messages

Overview

You can use this Snap to generate message responses using the specified Anthropic Claude model and model parameters. Additionally, you can use the Snap to create chat bots or virtual assistant applications.


Anthropic Claude on Messages Overview

Prerequisites

None.

Limitations and known issues

None.

Snap views

View Description Examples of upstream and downstream Snaps
Input This Snap supports a maximum of one binary or document input view. When the input type is a document, you must provide a field to specify the path to the input prompt. The Snap requires a prompt, which can be generated either by the Amazon Bedrock Prompt Generator or any user-desired prompt intended for submission to the Anthropic Claude Messages API.
Output This Snap has at the most one document output view. The Snap provides the result generated by the Anthropic Claude Messages API. Mapper
Error

Error handling is a generic way to handle errors without losing data or failing the Snap execution. You can handle the errors that the Snap might encounter when running the pipeline by choosing one of the following options from the When errors occur list under the Views tab. The available options are:

  • Stop Pipeline Execution Stops the current pipeline execution when the Snap encounters an error.
  • Discard Error Data and Continue Ignores the error, discards that record, and continues with the remaining records.
  • Route Error Data to Error View Routes the error data to an error view without stopping the Snap execution.

Learn more about Error handling in Pipelines.

Snap settings

Note:
  • Suggestion icon (): Indicates a list that is dynamically populated based on the configuration.
  • Expression icon (): Indicates whether the value is an expression (if enabled) or a static value (if disabled). Learn more about Using Expressions in SnapLogic.
  • Add icon (): Indicates that you can add fields in the field set.
  • Remove icon (): Indicates that you can remove fields from the field set.
Field / Field set Type Description
Label String

Required. Specify a unique name for the Snap. Modify this to be more appropriate, especially if more than one of the same Snaps is in the pipeline.

Default value: Anthropic Claude on AWS Messages

Example: Create customer support responses
Model name String/Expression/Suggestion

Required. Specify the model name to use for the chat completion. Learn more about the list of Anthropic Claude models from AWS Bedrock that are compatible with the Messages API.

Default value: N/A

Example: anthropic.claude-3-haiku
Use message payload Checkbox

Select this checkbox to generate responses using the messages specified in the Message payload field.

Note:
  • When you select this checkbox, the Snap hides the Prompt and System prompt fields and the Message payload field is displayed.
  • When the input view is Binary, this field is hidden.

Default status: Deselected

Message payload String/Expression

Appears when you select the Use message payload checkbox.

Required. Specify the prompt to send to the chat completions endpoint as the user message. The expected data type for this field is a list of objects (a list of messages). You can generate this list with the Amazon Bedrock Prompt Generator Snap.

For example,
[
    {
        "content": "You are a helpful assistant",
        "sl_role": "SYSTEM"
    },
    {
        "content": "Who won the world series in 2020?",
        "sl_role": "USER",
        "name": "Snap-User"
    },
    {
        "content": "The Los Angeles Dodgers won the World Series in 2020",
        "sl_role": "ASSISTANT"
    },
    {
        "content": "Where was it played?",
        "sl_role": "USER",
        "name": "Snap-User2"
    }
]
Note:
  • If a message contains an unsupported role (for example, SYSTEM), it is passed as is to the endpoint. This can potentially result in call failure because the role is not supported by the Amazon Bedrock Prompt Generator Snap.
  • If a message being processed contains any field not supported (for example, name field), it is ignored and excluded in the final message sent to the API because the endpoint does not support it. The supported fields are only content and role.

Default value: N/A

Example: $messages
Prompt String/Expression

Appears when you select Document as the Input type under the Views tab.

Required. Specify the prompt to send to the Anthropic Claude Messages endpoint as the user message.

Default value: N/A

Example: $msg
Model parameters Configure the parameters to tune the model runtime.
Maximum tokens Integer/Expression

Required. Specify the maximum number of tokens to generate the message responses.

Minimum value: 0

Maximum value: 4096

Default value: 200

Example: 100

Temperature Decimal/Expression

Specify the sampling temperature to use a decimal value between 0 and 1. If left blank, the endpoint uses the default value 1.

Default value: N/A

Example: 0.2

Top P Decimal/Expression

Specify the nucleus sampling value, a decimal value between 0 and 1. If left blank, the endpoint uses its default value set to 0.999.

Default value: N/A

Example: 0.2

Top K Integer/Expression

Specify a value to limit the number of high-probability tokens considered for each generation step to control the randomness of the output. It is disabled by default.

Minimum value: 0

Maximum value: 500

Default value: N/A

Example: 300

Advanced prompt configuration Configure the advanced prompt settings.
JSON mode Checkbox/Expression

Select this checkbox to enable the model to generate strings that can be parsed into valid JSON objects. The output includes a field named json_output that contains the parsed JSON object, encapsulating the data.

Note:
  • This field does not support input document values from upstream Snaps.
  • When the output from the model is an invalid JSON, the Snap fails indicating that it failed to parse the JSON in the output. However, the Snap provides the full output from the LLM Model in the error view with the error message.
  • When the output from the model indicates that there are not enough tokens, the Snap fails with a reason that it failed to parse the JSON in the output. However, the Snap provides the full output from the LLM Model in the error view.
  • When you select this checkbox and specify a Message payload, the Snap automatically adds an Assistant message at the end of the message payload to ensure the Claude model returns JSON in its response. Therefore, if you use JSON mode and a Message payload, ensure your message list ends with a User message, not an Assistant message, to avoid errors.

Default status: Deselected

System Prompt String/Expression

Specify the prompt (inital instruction). This prompt prepares for the conversation by defining Claude's role, personality, tone, and other relevant details to understand and respond to the user's input.

Note:
  • If you leave this field blank, empty or null, the Snap processes the request without using any system prompt.
  • This field supports input document values from upstream Snap.
  • The output represents the result generated by the Anthropic Claude on AWS Messages Response.

Default value: N/A

Example:
  • Explain the answer to a 6-year-old child.
  • Explain your role as an AI assistant.
Snap execution Dropdown list
Select one of the three modes in which the Snap executes. Available options are:
  • Validate & Execute. Performs limited execution of the Snap and generates a data preview during pipeline validation. Subsequently, performs full execution of the Snap (unlimited records) during pipeline runtime.
  • Execute only. Performs full execution of the Snap during pipeline execution without generating preview data.
  • Disabled. Disables the Snap and all Snaps that are downstream from it.

Default value: Validate & Execute

Example: Execute only

Troubleshooting

Unable to generate JSON response

The tokens are not enough.

Modify the settings and try again.

Unable to parse JSON content string

JSON output is malformed.

Modify the settings and try again.

Examples