lib/spatio/api/conversations.ex

# NOTE: This file is auto generated by OpenAPI Generator 7.22.0 (https://openapi-generator.tech).
# Do not edit this file manually.

defmodule Spatio.Api.Conversations do
  @moduledoc """
  API calls for all endpoints tagged `Conversations`.
  """

  alias Spatio.Connection
  import Spatio.RequestBuilder

  @doc """
  Persist a new LLM conversation.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `opts` (keyword): Optional parameters
    - `:body` (CreateConversationRequest): 

  ### Returns

  - `{:ok, Spatio.Model.Conversation.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec create_conversation(Tesla.Env.client, keyword()) :: {:ok, Spatio.Model.Conversation.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def create_conversation(connection, opts \\ []) do
    optional_params = %{
      :body => :body
    }

    request =
      %{}
      |> method(:post)
      |> url("/v1/conversations")
      |> add_optional_params(optional_params, opts)
      |> ensure_body()
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {201, Spatio.Model.Conversation},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Soft-delete a conversation.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, nil}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec delete_conversation(Tesla.Env.client, String.t, keyword()) :: {:ok, nil} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def delete_conversation(connection, id, _opts \\ []) do
    request =
      %{}
      |> method(:delete)
      |> url("/v1/conversations/#{id}")
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {204, false},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Fetch one conversation.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, Spatio.Model.Conversation.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec get_conversation(Tesla.Env.client, String.t, keyword()) :: {:ok, Spatio.Model.Conversation.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def get_conversation(connection, id, _opts \\ []) do
    request =
      %{}
      |> method(:get)
      |> url("/v1/conversations/#{id}")
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.Conversation},
      {401, Spatio.Model.ApiError},
      {404, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Fetch the most recently active conversation for a given context tag.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `context` (String.t): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, Spatio.Model.Conversation.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec get_latest_conversation_for_context(Tesla.Env.client, String.t, keyword()) :: {:ok, Spatio.Model.Conversation.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def get_latest_conversation_for_context(connection, context, _opts \\ []) do
    request =
      %{}
      |> method(:get)
      |> url("/v1/conversations/latest")
      |> add_param(:query, :context, context)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.Conversation},
      {401, Spatio.Model.ApiError},
      {404, Spatio.Model.ApiError}
    ])
  end

  @doc """
  List messages in a conversation.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `opts` (keyword): Optional parameters
    - `:limit` (integer()): 
    - `:before` (String.t): 

  ### Returns

  - `{:ok, [%ConversationMessage{}, ...]}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec list_conversation_messages(Tesla.Env.client, String.t, keyword()) :: {:ok, [Spatio.Model.ConversationMessage.t]} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def list_conversation_messages(connection, id, opts \\ []) do
    optional_params = %{
      :limit => :query,
      :before => :query
    }

    request =
      %{}
      |> method(:get)
      |> url("/v1/conversations/#{id}/messages")
      |> add_optional_params(optional_params, opts)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.ConversationMessage},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  List the caller's persisted LLM conversations.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `opts` (keyword): Optional parameters
    - `:context` (String.t): 
    - `:limit` (integer()): 

  ### Returns

  - `{:ok, [%Conversation{}, ...]}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec list_conversations(Tesla.Env.client, keyword()) :: {:ok, [Spatio.Model.Conversation.t]} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def list_conversations(connection, opts \\ []) do
    optional_params = %{
      :context => :query,
      :limit => :query
    }

    request =
      %{}
      |> method(:get)
      |> url("/v1/conversations")
      |> add_optional_params(optional_params, opts)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.Conversation},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Append a message to a conversation.

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `save_message_request` (SaveMessageRequest): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, Spatio.Model.ConversationMessage.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec save_conversation_message(Tesla.Env.client, String.t, Spatio.Model.SaveMessageRequest.t, keyword()) :: {:ok, Spatio.Model.ConversationMessage.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def save_conversation_message(connection, id, save_message_request, _opts \\ []) do
    request =
      %{}
      |> method(:post)
      |> url("/v1/conversations/#{id}/messages")
      |> add_param(:body, :body, save_message_request)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {201, Spatio.Model.ConversationMessage},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Update conversation metadata (title, context, cwd, session_id, pinned).

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `update_conversation_request` (UpdateConversationRequest): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, Spatio.Model.Conversation.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec update_conversation(Tesla.Env.client, String.t, Spatio.Model.UpdateConversationRequest.t, keyword()) :: {:ok, Spatio.Model.Conversation.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def update_conversation(connection, id, update_conversation_request, _opts \\ []) do
    request =
      %{}
      |> method(:patch)
      |> url("/v1/conversations/#{id}")
      |> add_param(:body, :body, update_conversation_request)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.Conversation},
      {401, Spatio.Model.ApiError}
    ])
  end

  @doc """
  Patch metadata on an existing message. Body must include the message id (path is the conversation id, not the message). 

  ### Parameters

  - `connection` (Spatio.Connection): Connection to server
  - `id` (String.t): 
  - `update_message_metadata_request` (UpdateMessageMetadataRequest): 
  - `opts` (keyword): Optional parameters

  ### Returns

  - `{:ok, Spatio.Model.ConversationMessage.t}` on success
  - `{:error, Tesla.Env.t}` on failure
  """
  @spec update_conversation_message_metadata(Tesla.Env.client, String.t, Spatio.Model.UpdateMessageMetadataRequest.t, keyword()) :: {:ok, Spatio.Model.ConversationMessage.t} | {:ok, Spatio.Model.ApiError.t} | {:error, Tesla.Env.t}
  def update_conversation_message_metadata(connection, id, update_message_metadata_request, _opts \\ []) do
    request =
      %{}
      |> method(:patch)
      |> url("/v1/conversations/#{id}/messages")
      |> add_param(:body, :body, update_message_metadata_request)
      |> Enum.into([])

    connection
    |> Connection.request(request)
    |> evaluate_response([
      {200, Spatio.Model.ConversationMessage},
      {401, Spatio.Model.ApiError}
    ])
  end
end