Class: Anthropic::Models::Message

Inherits:
Internal::Type::BaseModel show all
Defined in:
lib/anthropic/models/message.rb

Overview

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods inherited from Internal::Type::BaseModel

==, #==, #[], coerce, #deconstruct_keys, #deep_to_h, dump, fields, hash, #hash, inherited, inspect, #inspect, known_fields, optional, recursively_to_h, required, #to_h, #to_json, #to_s, to_sorbet_type, #to_yaml

Methods included from Internal::Type::Converter

#coerce, coerce, #dump, dump, inspect, #inspect, meta_info, new_coerce_state, type_info

Methods included from Internal::Util::SorbetRuntimeSupport

#const_missing, #define_sorbet_constant!, #sorbet_constant_defined?, #to_sorbet_type, to_sorbet_type

Constructor Details

#initialize(id:, content:, model:, stop_reason:, stop_sequence:, usage:, role: :assistant, type: :message) ⇒ Object

Some parameter documentations has been truncated, see Anthropic::Models::Message for more details.

Parameters:



# File 'lib/anthropic/models/message.rb', line 139

Instance Attribute Details

#contentArray<Anthropic::Models::TextBlock, Anthropic::Models::ThinkingBlock, Anthropic::Models::RedactedThinkingBlock, Anthropic::Models::ToolUseBlock, Anthropic::Models::ServerToolUseBlock, Anthropic::Models::WebSearchToolResultBlock>

Content generated by the model.

This is an array of content blocks, each of which has a type that determines its shape.

Example:

“‘json

{ “type”: “text”, “text”: “Hi, I’m Claude.” }

“‘

If the request input messages ended with an assistant turn, then the response content will continue directly from that last turn. You can use this to constrain the model’s output.

For example, if the input messages were:

“‘json [

{
  "role": "user",
  "content": "What's the Greek name for Sun? (A) Sol (B) Helios (C) Sun"
},
{ "role": "assistant", "content": "The best answer is (" }

] “‘

Then the response content might be:

“‘json

{ “type”: “text”, “text”: “B)” }

“‘



52
# File 'lib/anthropic/models/message.rb', line 52

required :content, -> { Anthropic::Internal::Type::ArrayOf[union: Anthropic::ContentBlock] }

#idString

Unique object identifier.

The format and length of IDs may change over time.

Returns:

  • (String)


15
# File 'lib/anthropic/models/message.rb', line 15

required :id, String

#modelSymbol, ...

The model that will complete your prompt.nnSee [models](docs.anthropic.com/en/docs/models-overview) for additional details and options.

Returns:



72
# File 'lib/anthropic/models/message.rb', line 72

required :model, union: -> { Anthropic::Model }

#roleSymbol, :assistant

Conversational role of the generated message.

This will always be ‘“assistant”`.

Returns:

  • (Symbol, :assistant)


80
# File 'lib/anthropic/models/message.rb', line 80

required :role, const: :assistant

#stop_reasonSymbol, ...

The reason that we stopped.

This may be one the following values:

  • ‘“end_turn”`: the model reached a natural stopping point

  • ‘“max_tokens”`: we exceeded the requested max_tokens or the model’s maximum

  • ‘“stop_sequence”`: one of your provided custom stop_sequences was generated

  • ‘“tool_use”`: the model invoked one or more tools

  • ‘“pause_turn”`: we paused a long-running turn. You may provide the response back as-is in a subsequent request to let the model continue.

  • ‘“refusal”`: when streaming classifiers intervene to handle potential policy violations

In non-streaming mode this value is always non-null. In streaming mode, it is null in the message_start event and non-null otherwise.

Returns:



100
# File 'lib/anthropic/models/message.rb', line 100

required :stop_reason, enum: -> { Anthropic::StopReason }, nil?: true

#stop_sequenceString?

Which custom stop sequence was generated, if any.

This value will be a non-null string if one of your custom stop sequences was generated.

Returns:

  • (String, nil)


109
# File 'lib/anthropic/models/message.rb', line 109

required :stop_sequence, String, nil?: true

#typeSymbol, :message

Object type.

For Messages, this is always ‘“message”`.

Returns:

  • (Symbol, :message)


117
# File 'lib/anthropic/models/message.rb', line 117

required :type, const: :message

#usageAnthropic::Models::Usage

Billing and rate-limit usage.

Anthropic’s API bills and rate-limits by token counts, as tokens represent the underlying cost to our systems.

Under the hood, the API transforms requests into a format suitable for the model. The model’s output then goes through a parsing stage before becoming an API response. As a result, the token counts in usage will not match one-to-one with the exact visible content of an API request or response.

For example, output_tokens will be non-zero, even for an empty string response from Claude.

Total input tokens in a request is the summation of input_tokens, cache_creation_input_tokens, and cache_read_input_tokens.



137
# File 'lib/anthropic/models/message.rb', line 137

required :usage, -> { Anthropic::Usage }

Instance Method Details

#parsed_outputObject?

Parsed value of response when a JSON output schema object has been specified via :output_config

Returns:

  • (Object, nil)


57
58
59
60
61
62
63
64
# File 'lib/anthropic/models/message.rb', line 57

def parsed_output
  case content
  in [*, {parsed:}]
    parsed
  else
    nil
  end
end