Awesome
<h1 align="center">Joe Bot - Slack Adapter</h1> <p align="center">Connecting joe with the Slack chat application. https://github.com/go-joe/joe</p> <p align="center"> <a href="https://github.com/go-joe/slack-adapter/releases"><img src="https://img.shields.io/github/tag/go-joe/slack-adapter.svg?label=version&color=brightgreen"></a> <a href="https://github.com/go-joe/slack-adapter/actions/workflows/test.yml"><img src="https://github.com/go-joe/slack-adapter/actions/workflows/test.yml/badge.svg"></a> <a href="https://goreportcard.com/report/github.com/go-joe/slack-adapter"><img src="https://goreportcard.com/badge/github.com/go-joe/slack-adapter"></a> <a href="https://codecov.io/gh/go-joe/slack-adapter"><img src="https://codecov.io/gh/go-joe/slack-adapter/branch/master/graph/badge.svg"/></a> <a href="https://pkg.go.dev/github.com/go-joe/slack-adapter"><img src="https://img.shields.io/badge/godoc-reference-blue.svg?color=blue"></a> <a href="https://github.com/go-joe/slack-adapter/blob/master/LICENSE"><img src="https://img.shields.io/badge/license-BSD--3--Clause-blue.svg"></a> </p>This repository contains a module for the Joe Bot library.
Getting Started
This library is packaged as Go module. You can get it via:
go get github.com/go-joe/slack-adapter
Example usage
In order to connect your bot to slack you can simply pass it as module when creating a new bot:
package main
import (
"os"
"github.com/go-joe/joe"
"github.com/go-joe/slack-adapter/v2"
)
func main() {
b := joe.New("example-bot",
slack.Adapter(os.Getenv("SLACK_TOKEN")),
…
)
b.Respond("ping", Pong)
err := b.Run()
if err != nil {
b.Logger.Fatal(err.Error())
}
}
If you want to use the Slack Events API you
need to call the slack.EventsAPIAdapter(…)
function instead.
The adapter will emit the following events to the robot brain:
joe.ReceiveMessageEvent
joe.UserTypingEvent
reactions.Event
Built With
- slack-go/slack - Slack API in Go
- zap - Blazing fast, structured, leveled logging in Go
- testify - A simple unit test library
Contributing
The current implementation is rather minimal and there are many more features that could be implemented on the slack adapter so you are highly encouraged to contribute. If you want to hack on this repository, please read the short CONTRIBUTING.md guide first.
Versioning
We use SemVer for versioning. For the versions available, see the tags on this repository.
Authors
- Friedrich Große - Initial work - fgrosse
See also the list of contributors who participated in this project.
License
This project is licensed under the BSD-3-Clause License - see the LICENSE file for details.