Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/satom99/coxir
A modern Elixir wrapper for Discord.
https://github.com/satom99/coxir
discord elixir library
Last synced: 3 months ago
JSON representation
A modern Elixir wrapper for Discord.
- Host: GitHub
- URL: https://github.com/satom99/coxir
- Owner: satom99
- License: apache-2.0
- Created: 2017-12-29T15:28:30.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2022-04-02T20:10:20.000Z (almost 3 years ago)
- Last Synced: 2024-07-31T20:40:45.865Z (5 months ago)
- Topics: discord, elixir, library
- Language: Elixir
- Homepage: https://satom.me/coxir
- Size: 2.43 MB
- Stars: 74
- Watchers: 2
- Forks: 13
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- discord-api-libs - coxir - A modern Elixir wrapper for Discord. (Libraries / Elixir)
- awesome-discord - coxir
README
# coxir
[![License](https://img.shields.io/github/license/satom99/coxir.svg)](https://github.com/satom99/coxir/blob/main/LICENSE)
[![Validation](https://github.com/satom99/coxir/actions/workflows/validation.yml/badge.svg)](https://github.com/satom99/coxir/actions/workflows/validation.yml)
[![Documentation](https://github.com/satom99/coxir/actions/workflows/documentation.yml/badge.svg)](https://github.com/satom99/coxir/actions/workflows/documentation.yml)
[![Join Discord](https://img.shields.io/badge/Discord-join-5865F2.svg)](https://discord.gg/6JrqNEX)A modern high-level Elixir wrapper for [Discord](https://discord.com).
Refer to the [documentation](https://satom.me/coxir) for more information.
### Features
- Support for running multiple bots in a same application
- Configurable adapters that change how the library behaves:
- **Limiter:** handles how rate limit buckets are stored
- **Storage:** handles how entities are cached
- **Sharder:** handles how shards are started
- **Player:** handles the audio sent through voice
- Easy-to-use syntax for interacting with Discord entities### Installation
Add coxir as a dependency to your `mix.exs` file:
```elixir
defp deps do
[{:coxir, git: "https://github.com/satom99/coxir.git"}]
end
```### Quickstart
Before consuming events, coxir must be configured:
```elixir
config :coxir,
token: "",
intents: :non_privileged # optional
```Then a simple consumer can be set up as follows:
```elixir
defmodule Example.Bot do
use Coxir.Gateway
alias Coxir.{User, Message}def handle_event({:MESSAGE_CREATE, %Message{content: "!hello"} = message}) do
%Message{author: author} = Message.preload(message, :author)%User{username: username, discriminator: discriminator} = author
Message.reply(message, content: "Hello #{username}##{discriminator}!")
end
def handle_event(_event) do
:noop
end
end
```Which can then be added to a Supervisor, or started directly:
```elixir
iex(1)> Example.Bot.start_link()
{:ok, #PID<0.301.0>}
```For a complete and working example check out the [`example`](https://github.com/satom99/coxir/tree/main/example) app.
### More
For more information check out the [documentation guides](https://satom.me/coxir).