#slack-client #slack #kit #morphism #api-bindings #com #events

slack-morphism

Slack Morphism is a modern client library for Slack Web/Events API/Socket Mode and Block Kit

109 releases (47 stable)

2.11.0 Apr 21, 2025
2.10.1 Mar 19, 2025
2.10.0 Feb 23, 2025
2.7.0 Dec 9, 2024
0.3.1 Oct 20, 2020

#6 in Video

Download history 32982/week @ 2025-01-09 15476/week @ 2025-01-16 10223/week @ 2025-01-23 10107/week @ 2025-01-30 13214/week @ 2025-02-06 8566/week @ 2025-02-13 11400/week @ 2025-02-20 13533/week @ 2025-02-27 10493/week @ 2025-03-06 13594/week @ 2025-03-13 12236/week @ 2025-03-20 12730/week @ 2025-03-27 14407/week @ 2025-04-03 18305/week @ 2025-04-10 14115/week @ 2025-04-17 10596/week @ 2025-04-24

59,807 downloads per month
Used in 12 crates (6 directly)

Apache-2.0

410KB
10K SLoC

Cargo tests and formatting security audit

Slack Morphism for Rust

Slack Morphism is a modern client library for Slack Web/Events API/Socket Mode and Block Kit.

Documentation

Please follow to the official website: https://slack-rust.abdolence.dev.

Examples

https://github.com/abdolence/slack-morphism-rust/tree/master/examples

The examples require to work the following environment variables (from your Slack bot profile in api.slack.com):

  • SLACK_TEST_TOKEN - for Slack client example
  • SLACK_TEST_APP_TOKEN - for Slack client with Socket Mode example
  • SLACK_CLIENT_ID, SLACK_CLIENT_SECRET, SLACK_BOT_SCOPE, SLACK_REDIRECT_HOST - for OAuth routes for Events API example
  • SLACK_SIGNING_SECRET for all routes for Events API example

To run example use with environment variables:

# SLACK_... cargo run --example <client|events_api_server|axum_events_api_server|socket_mode> --all-features

Routes for this example are available on http://:8080:

  • /auth/install - to begin OAuth installation
  • /auth/callback - a callback endpoint for Slack OAuth profile config
  • /push - for Slack Push Events
  • /interaction - for Slack Interaction Events
  • /command - for Slack Command Events

Testing Events API with ngrok

For development/testing purposes you can use ngrok:

ngrok http 8080

and copy the URL it gives for you to the example parameters for SLACK_REDIRECT_HOST.

Example testing with ngrok:

SLACK_CLIENT_ID=<your-client-id> \
SLACK_CLIENT_SECRET=<your-client-secret> \
SLACK_BOT_SCOPE=app_mentions:read,incoming-webhook \
SLACK_REDIRECT_HOST=https://<your-ngrok-url>.ngrok.io \
SLACK_SIGNING_SECRET=<your-signing-secret> \
cargo run --example events_api_server  --all-features

Licence

Apache Software License (ASL)

Author

Abdulla Abdurakhmanov

with the great help of contributors, particularly:

  • Naoki Ikeguchi (@siketyan)
  • David Rousselie (@dax)

and many others

Dependencies

~9–22MB
~325K SLoC