Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shardlab/discordcr
Minimalist Discord library for Crystal
https://github.com/shardlab/discordcr
crystal discord hacktoberfest
Last synced: 3 months ago
JSON representation
Minimalist Discord library for Crystal
- Host: GitHub
- URL: https://github.com/shardlab/discordcr
- Owner: shardlab
- License: mit
- Created: 2020-11-12T13:31:10.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-07T02:19:30.000Z (about 1 year ago)
- Last Synced: 2024-08-01T15:05:47.812Z (6 months ago)
- Topics: crystal, discord, hacktoberfest
- Language: Crystal
- Homepage:
- Size: 2.98 MB
- Stars: 100
- Watchers: 6
- Forks: 15
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-discord - discordcr
- awesome-discord-bot-tools - discordcr - Minimalist Discord library for Crystal (Libraries / Crystal)
- awesome-discord-bot-tools - discordcr - Minimalist Discord library for Crystal (Libraries / Crystal)
README
[![docs](https://img.shields.io/badge/docs-v0.4.0-green.svg?style=flat-square)](https://dcr.shardlab.dev/v0.4.0/) [![docs](https://img.shields.io/badge/docs-master-red.svg?style=flat-square)](https://dcr.shardlab.dev/master/)
### Important Notice
This is the **new official source of discordcr**!\
The [old repo](https://github.com/discordcr/discordcr) has not been updated for countless months
and new features, along with library breaking changes, are coming fast.\
There is no guarantee any code/updates will be pushed to the old repo again, so as it stands,\
this will be where all new code will be pushed and where all new PRs and Issues should be created.Thanks!
# discordcr
(The "cr" stands for "creative name".)
discordcr is a minimalist [Discord](https://discord.com/) API library for
[Crystal](https://crystal-lang.org/), designed to be a complement to
[discordrb](https://github.com/shardlab/discordrb) for users who want more control
and performance and who care less about ease-of-use.discordcr isn't designed for beginners to the Discord API - while experience
with making bots isn't *required*, it's certainly recommended. If you feel
overwhelmed by the complex documentation, try
[discordrb](https://github.com/shardlab/discordrb) first and then check back.Unlike many other libs which handle a lot of stuff, like caching or resolving,
themselves automatically, discordcr requires the user to do such things
manually. It also doesn't provide any advanced abstractions for REST calls;
the methods perform the HTTP request with the given data but nothing else.
This means that the user has full control over them, but also full
responsibility. discordcr does not support user accounts; it may work but
likely doesn't.## Installation
Add this to your application's `shard.yml`:
```yaml
dependencies:
discordcr:
github: shardlab/discordcr
```## Usage
An example bot can be found
[here](https://github.com/shardlab/discordcr/blob/master/examples/ping.cr). More
examples will come in the future.A short overview of library structure: the `Client` class includes the `REST`
module, which handles the REST parts of Discord's API; the `Client` itself
handles the gateway, i. e. the interactive parts such as receiving messages. It
is possible to use only the REST parts by never calling the `#run` method on a
`Client`, which is what does the actual gateway connection.The example linked above has an example of an event (`on_message_create`) that
is called through the gateway, and of a REST call (`client.create_message`).
Other gateway events and REST calls work much in the same way - see the
documentation for what specific events and REST calls do.Caching is done using a separate `Cache` class that needs to be added into
clients manually:```cr
client = Discord::Client.new # ...
cache = Discord::Cache.new(client)
client.cache = cache
```Resolution requests for objects can now be done on the `cache` object instead of
directly over REST, this ensures that if an object is needed more than once
there will still only be one request to Discord. (There may even be no request
at all, if the requested data has already been obtained over the gateway.)
An example of how to use the cache once it has been instantiated:```cr
# Get the username of the user with ID 66237334693085184
user = cache.resolve_user(66237334693085184_u64)
user = cache.resolve_user(66237334693085184_u64) # won't do a request to Discord
puts user.username
```Apart from this, API documentation is also available, at
https://dcr.shardlab.dev/v0.4.0 for v0.4.0
https://dcr.shardlab.dev/master for latest
## Contributing
1. Fork it (https://github.com/shardlab/discordcr/fork)
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create a new Pull Request## Contributors
- [meew0](https://github.com/meew0) - creator, maintainer
- [RX14](https://github.com/RX14) - Crystal expert, maintainer
- [PixeL](https://github.com/PixelInc) - Maintainer