Bonfire.Messages (Bonfire v1.0.0-social-rc.3.22)

View Source

An extension for Bonfire that handles:

  • DM
  • Group messaging

Handy commands

Copyright (c) 2023 Bonfire Contributors

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.

Summary

Functions

ap_publish_activity(subject, verb, message)

Publishes an activity to the ActivityPub.

Examples

iex> Bonfire.Messages.ap_publish_activity(subject, verb, message)

changeset(atom, attrs, opts \\ [])

draft(context, attrs)

Save a new message as a draft (without sending it).

Examples

iex> Bonfire.Messages.draft(creator, attrs)
{:ok, %Message{}}

filter(atom, arg2, query)

list(current_user, with_user \\ nil, opts \\ [])

Lists messages sent by the user or sent to them, excluding replies.

Options

  • latest_in_threads (boolean): return only the last reply in each thread (or the first message if the thread only has one)

Examples

iex> Bonfire.Messages.list(current_user)
[%Message{}]

list(current_user, with_user, cursor_before, preloads)

maybe_index_message(object, context)

maybe_spam_check(changeset, attrs, context)

read(message_id, opts)

Attempt to read a message by its ID.

Examples

iex> Bonfire.Messages.read(message_id, current_user: me)
%Message{}

schema_module()

Callback implementation for Bonfire.Common.ContextModule.schema_module/0.

send(sender_or_context, attrs, to \\ nil)

Sends a message to the specified recipients.

Examples

iex> Bonfire.Messages.send(me, %{post_content: %{html_body: "test message"}}, to_user_id)