Class: OpenAI::Resources::Conversations::Items

Inherits:
Object
  • Object
show all
Defined in:
lib/openai/resources/conversations/items.rb

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ Items

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of Items.

Parameters:



135
136
137
# File 'lib/openai/resources/conversations/items.rb', line 135

def initialize(client:)
  @client = client
end

Instance Method Details

#create(conversation_id, items:, include: nil, request_options: {}) ⇒ OpenAI::Models::Conversations::ConversationItemList

Some parameter documentations has been truncated, see Models::Conversations::ItemCreateParams for more details.

Create items in a conversation with the given ID.

Parameters:

Returns:

See Also:



25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/openai/resources/conversations/items.rb', line 25

def create(conversation_id, params)
  parsed, options = OpenAI::Conversations::ItemCreateParams.dump_request(params)
  query_params = [:include]
  @client.request(
    method: :post,
    path: ["conversations/%1$s/items", conversation_id],
    query: parsed.slice(*query_params),
    body: parsed.except(*query_params),
    model: OpenAI::Conversations::ConversationItemList,
    options: options
  )
end

#delete(item_id, conversation_id:, request_options: {}) ⇒ OpenAI::Models::Conversations::Conversation

Delete an item from a conversation with the given IDs.

Parameters:

  • item_id (String)

    The ID of the item to delete.

  • conversation_id (String)

    The ID of the conversation that contains the item.

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



118
119
120
121
122
123
124
125
126
127
128
129
130
# File 'lib/openai/resources/conversations/items.rb', line 118

def delete(item_id, params)
  parsed, options = OpenAI::Conversations::ItemDeleteParams.dump_request(params)
  conversation_id =
    parsed.delete(:conversation_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :delete,
    path: ["conversations/%1$s/items/%2$s", conversation_id, item_id],
    model: OpenAI::Conversations::Conversation,
    options: options
  )
end

#list(conversation_id, after: nil, include: nil, limit: nil, order: nil, request_options: {}) ⇒ OpenAI::Internal::ConversationCursorPage<OpenAI::Models::Conversations::Message, OpenAI::Models::Responses::ResponseFunctionToolCallItem, OpenAI::Models::Responses::ResponseFunctionToolCallOutputItem, OpenAI::Models::Responses::ResponseFileSearchToolCall, OpenAI::Models::Responses::ResponseFunctionWebSearch, OpenAI::Models::Conversations::ConversationItem::ImageGenerationCall, OpenAI::Models::Responses::ResponseComputerToolCall, OpenAI::Models::Responses::ResponseComputerToolCallOutputItem, OpenAI::Models::Responses::ResponseReasoningItem, OpenAI::Models::Responses::ResponseCodeInterpreterToolCall, OpenAI::Models::Conversations::ConversationItem::LocalShellCall, OpenAI::Models::Conversations::ConversationItem::LocalShellCallOutput, OpenAI::Models::Responses::ResponseFunctionShellToolCall, OpenAI::Models::Responses::ResponseFunctionShellToolCallOutput, OpenAI::Models::Responses::ResponseApplyPatchToolCall, OpenAI::Models::Responses::ResponseApplyPatchToolCallOutput, OpenAI::Models::Conversations::ConversationItem::McpListTools, OpenAI::Models::Conversations::ConversationItem::McpApprovalRequest, OpenAI::Models::Conversations::ConversationItem::McpApprovalResponse, OpenAI::Models::Conversations::ConversationItem::McpCall, OpenAI::Models::Responses::ResponseCustomToolCall, OpenAI::Models::Responses::ResponseCustomToolCallOutput>

Some parameter documentations has been truncated, see Models::Conversations::ItemListParams for more details.

List all items for a conversation with the given ID.

Parameters:

  • conversation_id (String)

    The ID of the conversation to list items for.

  • after (String)

    An item ID to list items after, used in pagination.

  • include (Array<Symbol, OpenAI::Models::Responses::ResponseIncludable>)

    Specify additional output data to include in the model response. Currently suppo

  • limit (Integer)

    A limit on the number of objects to be returned. Limit can range between

  • order (Symbol, OpenAI::Models::Conversations::ItemListParams::Order)

    The order to return the input items in. Default is ‘desc`.

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



93
94
95
96
97
98
99
100
101
102
103
# File 'lib/openai/resources/conversations/items.rb', line 93

def list(conversation_id, params = {})
  parsed, options = OpenAI::Conversations::ItemListParams.dump_request(params)
  @client.request(
    method: :get,
    path: ["conversations/%1$s/items", conversation_id],
    query: parsed,
    page: OpenAI::Internal::ConversationCursorPage,
    model: OpenAI::Conversations::ConversationItem,
    options: options
  )
end

#retrieve(item_id, conversation_id:, include: nil, request_options: {}) ⇒ OpenAI::Models::Conversations::Message, ...

Some parameter documentations has been truncated, see Models::Conversations::ItemRetrieveParams for more details.

Get a single item from a conversation with the given IDs.

Parameters:

  • item_id (String)

    Path param: The ID of the item to retrieve.

  • conversation_id (String)

    Path param: The ID of the conversation that contains the item.

  • include (Array<Symbol, OpenAI::Models::Responses::ResponseIncludable>)

    Query param: Additional fields to include in the response. See the ‘include`

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



56
57
58
59
60
61
62
63
64
65
66
67
68
69
# File 'lib/openai/resources/conversations/items.rb', line 56

def retrieve(item_id, params)
  parsed, options = OpenAI::Conversations::ItemRetrieveParams.dump_request(params)
  conversation_id =
    parsed.delete(:conversation_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :get,
    path: ["conversations/%1$s/items/%2$s", conversation_id, item_id],
    query: parsed,
    model: OpenAI::Conversations::ConversationItem,
    options: options
  )
end