256 lines
6.1 KiB
Elixir
256 lines
6.1 KiB
Elixir
defmodule Hunter.Status do
|
|
@moduledoc """
|
|
Status entity
|
|
|
|
## Fields
|
|
|
|
* `id` - The ID of the status
|
|
* `uri` - A Fediverse-unique resource ID
|
|
* `url` - URL to the status page (can be remote)
|
|
* `account` - The `Hunter.Account` which posted the status
|
|
* `in_reply_to_id` - `nil` or the ID of the status it replies to
|
|
* `in_reply_to_account_id` - `nil` or the ID of the account it replies to
|
|
* `reblog` - `nil` or the reblogged `Hunter.Status`
|
|
* `content` - Body of the status; this will contain HTML (remote HTML already sanitized)
|
|
* `created_at` - The time the status was created
|
|
* `reblogs_count` - The number of reblogs for the status
|
|
* `favourites_count` - The number of favourites for the status
|
|
* `reblogged` - Whether the authenticated user has reblogged the status
|
|
* `favourited` - Whether the authenticated user has favourited the status
|
|
* `sensitive` - Whether media attachments should be hidden by default
|
|
* `spoiler_text` - If not empty, warning text that should be displayed before the actual content
|
|
* `visibility` - One of: `public`, `unlisted`, `private`, `direct`
|
|
* `media_attachments` - A list of `Hunter.Attachment`
|
|
* `mentions` - A list of `Hunter.Mention`
|
|
* `tags` - A list of `Hunter.Tag`
|
|
* `application` - `Hunter.Application` from which the status was posted
|
|
|
|
"""
|
|
@hunter_api Application.get_env(:hunter, :hunter_api)
|
|
|
|
@type t :: %__MODULE__{
|
|
id: non_neg_integer,
|
|
uri: URI.t,
|
|
url: URI.t,
|
|
account: Hunter.Account.t,
|
|
in_reply_to_id: non_neg_integer,
|
|
reblog: Hunter.Status.t | nil,
|
|
content: String.t,
|
|
created_at: String.t,
|
|
reblogs_count: non_neg_integer,
|
|
favourites_count: non_neg_integer,
|
|
reblogged: boolean,
|
|
favourited: boolean,
|
|
sensitive: boolean,
|
|
spoiler_text: String.t,
|
|
media_attachments: [Hunter.Attachment.t],
|
|
mentions: [Hunter.Mention.t],
|
|
tags: [Hunter.Tag.t],
|
|
application: Hunter.Application.t
|
|
}
|
|
|
|
@derive [Poison.Encoder]
|
|
defstruct [:id,
|
|
:uri,
|
|
:url,
|
|
:account,
|
|
:in_reply_to_id,
|
|
:in_reply_to_account_id,
|
|
:reblog,
|
|
:content,
|
|
:created_at,
|
|
:reblogs_count,
|
|
:favourites_count,
|
|
:reblogged,
|
|
:favourited,
|
|
:sensitive,
|
|
:spoiler_text,
|
|
:visibility,
|
|
:media_attachments,
|
|
:mentions,
|
|
:tags,
|
|
:application]
|
|
|
|
@doc """
|
|
Create new status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - connection credentials
|
|
* `text` - [String]
|
|
* `in_reply_to_id` - [Integer]
|
|
* `media_ids` - [Array<Integer>]
|
|
|
|
"""
|
|
@spec create_status(Hunter.Client.t, String.t, non_neg_integer, [non_neg_integer]) :: Hunter.Status.t
|
|
def create_status(conn, text, in_reply_to_id \\ nil, media_ids \\ []) do
|
|
@hunter_api.create_status(conn, text, in_reply_to_id, media_ids)
|
|
end
|
|
|
|
@doc """
|
|
Retrieve status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` [Integer]
|
|
|
|
"""
|
|
@spec status(Hunter.Client.t, non_neg_integer) :: Hunter.Status.t
|
|
def status(conn, id) do
|
|
@hunter_api.status(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Destroy status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` [Integer]
|
|
|
|
"""
|
|
@spec destroy_status(Hunter.Client.t, non_neg_integer) :: boolean
|
|
def destroy_status(conn, id) do
|
|
@hunter_api.destroy_status(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Reblog a status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` - [Integer]
|
|
|
|
"""
|
|
@spec reblog(Hunter.Client.t, non_neg_integer) :: Hunter.Status.t
|
|
def reblog(conn, id) do
|
|
@hunter_api.reblog(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Undo a reblog of a status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` - [Integer]
|
|
|
|
"""
|
|
@spec unreblog(Hunter.Client.t, non_neg_integer) :: Hunter.Status.t
|
|
def unreblog(conn, id) do
|
|
@hunter_api.unreblog(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Favorite a status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` - [Integer]
|
|
|
|
"""
|
|
@spec favourite(Hunter.Client.t, non_neg_integer) :: Hunter.Status.t
|
|
def favourite(conn, id) do
|
|
@hunter_api.favourite(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Undo a favorite of a status
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `id` - [Integer]
|
|
|
|
"""
|
|
@spec unfavourite(Hunter.Client.t, non_neg_integer) :: Hunter.Status.t
|
|
def unfavourite(conn, id) do
|
|
@hunter_api.unfavourite(conn, id)
|
|
end
|
|
|
|
@doc """
|
|
Get a list of statuses by a user
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `account_id` [Integer]
|
|
* `options` - options
|
|
|
|
## Options
|
|
|
|
* `max_id` - [Integer]
|
|
* `since_id` - [Integer]
|
|
* `limit` - [Integer]
|
|
|
|
"""
|
|
@spec statuses(Hunter.Client.t, non_neg_integer, Keyword.t) :: [Hunter.Status.t]
|
|
def statuses(conn, account_id, options \\ []) do
|
|
@hunter_api.statuses(conn, account_id, options)
|
|
end
|
|
|
|
@doc """
|
|
Retrieve statuses from the home timeline
|
|
|
|
## Parameters
|
|
|
|
* `conn` - Connection credentials
|
|
* `options` - option list
|
|
|
|
## Options
|
|
|
|
* `conn` - Connection credentials
|
|
* `max_id` - [Integer]
|
|
* `since_id` - [Integer]
|
|
* `limit` - [Integer]
|
|
|
|
"""
|
|
@spec home_timeline(Hunter.Client.t, Keyword.t) :: [Hunter.Status.t]
|
|
def home_timeline(conn, options \\ []) do
|
|
@hunter_api.home_timeline(conn, options)
|
|
end
|
|
|
|
@doc """
|
|
Retrieve statuses from the public timeline
|
|
|
|
## Parametes
|
|
|
|
* `conn` - Connection credentials
|
|
* `options` - option list
|
|
|
|
## Options
|
|
|
|
* `max_id` - [Integer]
|
|
* `since_id` - [Integer]
|
|
* `limit` - [Integer]
|
|
|
|
"""
|
|
@spec public_timeline(Hunter.Client.t, Keyword.t) :: [Hunter.Status.t]
|
|
def public_timeline(conn, options \\ []) do
|
|
@hunter_api.public_timeline(conn, options)
|
|
end
|
|
|
|
@doc """
|
|
Retrieve statuses from a hashtag
|
|
|
|
## Parameters
|
|
|
|
* `conn` - connection credentials
|
|
* `hashtag` - string list
|
|
|
|
## Options
|
|
|
|
* `max_id` - [Integer]
|
|
* `since_id` - [Integer]
|
|
* `limit` - [Integer]
|
|
|
|
"""
|
|
@spec hashtag_timeline(Hunter.Client.t, Keyword.t) :: [Hunter.Status.t]
|
|
def hashtag_timeline(conn, hashtag, options \\ []) do
|
|
@hunter_api.hashtag_timeline(conn, hashtag, options)
|
|
end
|
|
end
|