#slack #webhook #messaging #hook

已删除 slack-hook-clux

用于通过webhooks向Slack发送消息的Rust库

使用旧的Rust 2015

0.7.1 2018年10月22日

#72 in #slack


shipcat 中使用

MIT/Apache

39KB
832 代码行

rust-slack

Travis Build Status Documentation crates.io MIT licensed Apache licensed

一个用于通过webhooks向Slack发送消息的Rust库。

Slack 是一个团队协作的即时通讯平台。

正在升级?请查看 变更日志

需要rust 1.17或更高版本。

用法

将此内容添加到您的 Cargo.toml

[dependencies]
slack-hook = "0.7"

将crate添加到您的现有项目中

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)
    }
}

附件

要创建只包含附件的负载

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消息API允许您在文本中发送链接。然而,由于不同的格式化规则,这些文本片段需要按以下方式指定

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();
}

发送此负载将在Slack中打印以下内容(注意:Vec中的每个元素都被空格分隔)

      你好 Google,很高兴认识你。

此技术可用于任何具有Into<SlackText> trait限制的功能。

许可证

此库的发行条款类似于Rust:双重许可,MIT许可证和Apache许可证(版本2.0)。

请参阅LICENSE-APACHELICENSE-MITCOPYRIGHT以获取详细信息。

依赖项

~24MB
~519K SLoC