#webhook #discord #hook #embed #service #field #blurple

blurple_hook

Discord webhook implementation in Rust

7 releases

0.3.3 Mar 8, 2024
0.3.2 Mar 8, 2024
0.3.1 Feb 19, 2024
0.2.0 Jan 31, 2024
0.1.1 Jan 30, 2024

#1535 in Web programming

32 downloads per month

WTFPL license

23KB
560 lines

Blurple Hook

Discord Webhook implementation built in Rust.

Notice

This is a personal library used for my own projects, This is only intended to work for me, but feel free to fork and make your own versions as you please if this doesn't suit your needs.

This package will probably work for other services that implement similar systems, such as Slack, but is only intended to support Discord currently.

Installation

cargo add blurple_hook

Example

use blurple_hook::{Webhook, Embed, Field, ColourType};

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    let mut webhook = Webhook::new("https://discord.com/webhook/")
            .set_username("Blurple Hook")
            .set_content("Example Content");
    
    let mut embed = Embed::new()
            .set_title("Example")
            .set_timestamp()
            .set_url("https://example.com/")
            .set_colour(ColourType::Hex("#5865F2"))
            .add_fields(vec![
                Field {
                    name: "Field Title 1",
                    value: "Field Value 1",
                    inline: true,
                },
                Field {
                    name: "Field Title 2",
                    value: "Field Value 2",
                    inline: true,
                }
            ]);
    
    webhook.add_embed(embed);
    webhook.send().await?;
    
    Ok(())
}

Some methods such as set_colour have both spellings available for their method names (ie set_colourand set_color), however types are in Australian/British English spelling for now.

Dependencies

~5–18MB
~270K SLoC