#slack #webhook #messaging #hook

slack-hook

A rust crate for sending messages to Slack via webhooks

14 releases (8 breaking)

Uses old Rust 2015

0.8.0 Oct 23, 2018
0.6.0 Sep 26, 2017
0.5.0 Jul 24, 2017
0.3.0 Feb 26, 2017
0.0.1 Dec 30, 2014

#1514 in Web programming

Download history 918/week @ 2024-03-14 1043/week @ 2024-03-21 1045/week @ 2024-03-28 748/week @ 2024-04-04 939/week @ 2024-04-11 916/week @ 2024-04-18 1031/week @ 2024-04-25 1098/week @ 2024-05-02 1143/week @ 2024-05-09 1060/week @ 2024-05-16 883/week @ 2024-05-23 1325/week @ 2024-05-30 1446/week @ 2024-06-06 1169/week @ 2024-06-13 935/week @ 2024-06-20 688/week @ 2024-06-27

4,430 downloads per month
Used in 6 crates (5 directly)

MIT/Apache

41KB
882 lines

rust-slack

Travis Build Status Documentation crates.io MIT licensed Apache licensed

A rust crate for sending messages to Slack via webhooks.

Slack is a messaging platform for team collaboration.

Upgrading? See the CHANGELOG.

Requires rust 1.17 or newer.

Usage

Add this to your Cargo.toml:

[dependencies]
slack-hook = "0.7"

Add the crate to your existing project:

extern crate slack_hook;
use slack_hook::{Slack, PayloadBuilder};

fn main() {
    let slack = Slack::new("https://hooks.slack.com/services/abc/123/45z").unwrap();
    let p = PayloadBuilder::new()
      .text("test message")
      .channel("#testing")
      .username("My Bot")
      .icon_emoji(":chart_with_upwards_trend:")
      .build()
      .unwrap();

    let res = slack.send(&p);
    match res {
        Ok(()) => println!("ok"),
        Err(x) => println!("ERR: {:?}",x)
    }
}

Attachments

To create a payload with just an attachment:

extern crate slack_hook;
use slack_hook::{PayloadBuilder, AttachmentBuilder};

fn main() {
  let _ = PayloadBuilder::new()
    .attachments(vec![AttachmentBuilder::new("my text").color("#b13d41").build().unwrap()])
    .build()
    .unwrap();
}

Slack messaging API permits you to send links within text. However, given the different formatting rules, these text fragments need to be specified as follows:

extern crate slack_hook;
use slack_hook::{PayloadBuilder, SlackTextContent, SlackLink};
use slack_hook::SlackTextContent::{Text, Link};

fn main() {
  let _ = PayloadBuilder::new()
    .text(vec![
      Text("Hello".into()),
      Link(SlackLink::new("https://google.com", "Google")),
      Text(", nice to know you.".into())
    ].as_slice())
    .build()
    .unwrap();
}

Sending this payload will print the following in slack (note: each element of the Vec has been space-separated):

      Hello Google, nice to know you.

This technique can be used for any function that has the Into<SlackText> trait bound.

License

This library is distributed under similar terms to Rust: dual licensed under the MIT license and the Apache license (version 2.0).

See LICENSE-APACHE, LICENSE-MIT, and COPYRIGHT for details.

Dependencies

~24MB
~510K SLoC