Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/spy16/skit
Build slack bots quickly and easily!
https://github.com/spy16/skit
bot-framework chatbot go golang slack slack-bot
Last synced: about 1 month ago
JSON representation
Build slack bots quickly and easily!
- Host: GitHub
- URL: https://github.com/spy16/skit
- Owner: spy16
- License: mit
- Created: 2018-11-27T18:52:16.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2021-01-14T16:09:40.000Z (about 4 years ago)
- Last Synced: 2024-06-20T08:19:52.215Z (7 months ago)
- Topics: bot-framework, chatbot, go, golang, slack, slack-bot
- Language: Go
- Homepage:
- Size: 49.8 KB
- Stars: 45
- Watchers: 5
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# skit
[![GoDoc](https://godoc.org/github.com/spy16/skit?status.svg)](https://godoc.org/github.com/spy16/skit) [![Build Status](https://travis-ci.org/spy16/skit.svg?branch=master)](https://travis-ci.org/spy16/skit) [![Go Report Card](https://goreportcard.com/badge/github.com/spy16/skit)](https://goreportcard.com/report/github.com/spy16/skit)
Skit is a simple tool/library written in Go (or `Golang`) for building Slack bots.
Skit pre-compiled binary is good enough to build simple slack bots. For more complex
usecases skit can be used as a library as well.## Installation
Simply download the pre-built binary for your platform from the
[Releases](https://github.com/spy16/skit/releases) section.## Usage
### Pre-compiled Binary
Release archive will contain a `skit.toml` file with some sample handlers
setup. To run this default setup:1. Create a bot on slack by following [Documentation](https://api.slack.com/bot-users#creating-bot-user)
2. Set slack token generated for the bot in `skit.toml`
3. Run `skit -c skit.toml`
4. Go to slack and find the bot which you created and chat!#### `skit.toml` configuration file
Following `skit.toml` file can be used to setup a simple slack bot that
passes any message sent to it to a shell script `bot.sh`. The output of
this script will be sent back as the response.```toml
token = "your-token-here"
log_level = "info"[[handlers]]
name = "matcha_all"
type = "command"
match = [
".*"
]
cmd = "./bot.sh"
args = [
"{{ .event.Text }}"
]
```See `examples/` for samples of different handler configurations.
### As a library
Following sample shows how to build a simple bot that echo's everything
you say to it!```go
sk:= skit.New("your-token", logrus.New())
sk.Register("echo_all", skit.SimpleHandler("{{.event.Text}}", ".*"))
sk.Listen(context.Background())
```## Handlers
A handler is an implementation of `skit.Handler` interface. A handler is responsible
for consuming event, processing and responding to it when applicable. Currently 3 types
of handlers are available.### 1. `simple`
- `simple` handler can be used to build simple regex based conversational bot.
- Following sample shows how to configure `simple` handler:```toml
[[handlers]]
name = "simple_bot"
type = "simple"
match = [
"my name is (?P.*)"
]
message = "Hello there {{ .name }}!"
```### 2. `command`
- `command` handler can be used to delegate the message handling responsibility to external command
- This allows building bots which are more complex than the ones built with `simple`
- Following sample shows how to configure `command` handler:```toml
[[handlers]]
name = "external_command"
type = "command"
match = [
".*"
]
cmd = "./hello.sh"
args = [
"{{ .event.Text }}"
]
timeout = "5s"
```### 3. `lua`
- `lua` allows writing handlers using Lua script which will be executed using embedded [Gopher-Lua](https://gitter.im/yuin/gopher-lua)
- Lua code will have access to skit instance and its APIs and can be used build complex bots.
- You can provide paths to be added to `LUA_PATH` as `paths` in the following config.
- In the config sample below, `source` can be any valid lua code. So you can put your handler code
in a file (e.g., `handler.lua`) under one of the `paths` and use `source="require('handler')"` in
the handler config.
- Following sample shows how to configure `lua` handler:```toml
[[handlers]]
name = "lua_handler"
type = "lua"
handler = "handle_event"
paths = []
source = """
function handle_event(ctx, sk, event)
sk:SendText(ctx, "Hello from Lua!", event.Channel)
return true
end
"""
```