lib/glific/message_conversations.ex

defmodule Glific.MessageConversations do
  @moduledoc """
  The Messages Conversations context.
  """

  require Logger

  alias Glific.{
    Messages.MessageConversation,
    Repo
  }

  @doc """
  Gets a single message conversation

  Raises `Ecto.NoResultsError` if the Message does not exist.

  ## Examples

      iex> get_message_conversation!(123)
      %Message{}

      iex> get_message_conversation!(456)
      ** (Ecto.NoResultsError)

  """
  @spec get_message_conversation!(integer) :: MessageConversation.t()
  def get_message_conversation!(id), do: Repo.get!(MessageConversation, id)

  @doc """
  Creates a message conversation

  ## Examples

      iex> create_message_conversation(%{field: value})
      {:ok, %MessageConversation{}}

      iex> create_message_conversation(%{field: bad_value})
      {:error, %Ecto.Changeset{}}

  """
  @spec create_message_conversation(map()) ::
          {:ok, MessageConversation.t()} | {:error, Ecto.Changeset.t()}
  def create_message_conversation(attrs) do
    %MessageConversation{}
    |> MessageConversation.changeset(attrs)
    |> Repo.insert()
  end

  @doc """
  Updates a message conversation.

  ## Examples

      iex> update_message_conversation(message_conversation, %{field: new_value})
      {:ok, %MessageConversation{}}

      iex> update_message_conversation(message_conversation, %{field: bad_value})
      {:error, %Ecto.Changeset{}}

  """
  @spec update_message_conversation(MessageConversation.t(), map()) ::
          {:ok, MessageConversation.t()} | {:error, Ecto.Changeset.t()}
  def update_message_conversation(%MessageConversation{} = message_conversation, attrs) do
    message_conversation
    |> MessageConversation.changeset(attrs)
    |> Repo.update()
  end

  @doc """
  Deletes a message conversation.

  ## Examples

      iex> delete_message_conversation(message)
      {:ok, %MessageConversation{}}

      iex> delete_message_conversation(message)
      {:error, %Ecto.Changeset{}}

  """
  @spec delete_message_conversation(MessageConversation.t()) ::
          {:ok, MessageConversation.t()} | {:error, Ecto.Changeset.t()}
  def delete_message_conversation(%MessageConversation{} = message_conversation) do
    Repo.delete(message_conversation)
  end
end