Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/slack-go/slack
Slack API in Go, originally by @nlopes; Maintainers needed, contact @parsley42
https://github.com/slack-go/slack
go golang slack
Last synced: 5 days ago
JSON representation
Slack API in Go, originally by @nlopes; Maintainers needed, contact @parsley42
- Host: GitHub
- URL: https://github.com/slack-go/slack
- Owner: slack-go
- License: bsd-2-clause
- Created: 2015-01-24T14:19:00.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2024-11-14T19:49:17.000Z (about 2 months ago)
- Last Synced: 2024-12-30T14:08:35.494Z (12 days ago)
- Topics: go, golang, slack
- Language: Go
- Homepage: https://pkg.go.dev/github.com/slack-go/slack
- Size: 2.23 MB
- Stars: 4,707
- Watchers: 54
- Forks: 1,150
- Open Issues: 121
-
Metadata Files:
- Readme: README.md
- Changelog: history.go
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Audit: audit.go
- Security: security.go
Awesome Lists containing this project
- awesome-go - slack - Slack API in Go. (Third-party APIs / Utility/Miscellaneous)
- awesome-list - slack - community-maintained fork created by the original author, @nlopes | slack-go | 3615 | (Go)
- awesome-go - slack - Slack API in Go. Stars:`4.7K`. (Third-party APIs / Utility/Miscellaneous)
- awesome-golang-repositories - slack - community-maintained fork created by the original author, @nlopes (Repositories)
- awesome-go-extra - slack - community-maintained fork created by the original author, @nlopes|4023|997|92|2015-01-24T14:19:00Z|2022-08-24T16:38:42Z| (Third-party APIs / Fail injection)
- my-awesome - slack-go/slack - 11 star:4.7k fork:1.2k Slack API in Go, originally by @nlopes; Maintainers needed, contact @parsley42 (Go)
- awesome-go - slack - Slack API 的 Go 客户端。 (第三方 API / 爬虫工具)
- awesome-go - slack - Slack API 的 Go 客户端。 (第三方 API / 爬虫工具)
README
Slack API in Go [![Go Reference](https://pkg.go.dev/badge/github.com/slack-go/slack.svg)](https://pkg.go.dev/github.com/slack-go/slack)
===============This is the original Slack library for Go created by Norberto Lopes, transferred to a GitHub organization.
You can also chat with us on the #slack-go, #slack-go-ja Slack channel on the Gophers Slack.
![logo](logo.png "icon")
This library supports most if not all of the `api.slack.com` REST
calls, as well as the Real-Time Messaging protocol over websocket, in
a fully managed way.## Project Status
There is currently no major version released.
Therefore, minor version releases may include backward incompatible changes.See [Releases](https://github.com/slack-go/slack/releases) for more information about the changes.
## Installing
### *go get*
$ go get -u github.com/slack-go/slack
## Example
### Getting all groups
```golang
import (
"fmt""github.com/slack-go/slack"
)func main() {
api := slack.New("YOUR_TOKEN_HERE")
// If you set debugging, it will log all requests to the console
// Useful when encountering issues
// slack.New("YOUR_TOKEN_HERE", slack.OptionDebug(true))
groups, err := api.GetUserGroups(slack.GetUserGroupsOptionIncludeUsers(false))
if err != nil {
fmt.Printf("%s\n", err)
return
}
for _, group := range groups {
fmt.Printf("ID: %s, Name: %s\n", group.ID, group.Name)
}
}
```### Getting User Information
```golang
import (
"fmt""github.com/slack-go/slack"
)func main() {
api := slack.New("YOUR_TOKEN_HERE")
user, err := api.GetUserInfo("U023BECGF")
if err != nil {
fmt.Printf("%s\n", err)
return
}
fmt.Printf("ID: %s, Fullname: %s, Email: %s\n", user.ID, user.Profile.RealName, user.Profile.Email)
}
```## Minimal Socket Mode usage:
See https://github.com/slack-go/slack/blob/master/examples/socketmode/socketmode.go
## Minimal RTM usage:
As mentioned in https://api.slack.com/rtm - for most applications, Socket Mode is a better way to communicate with Slack.
See https://github.com/slack-go/slack/blob/master/examples/websocket/websocket.go
## Minimal EventsAPI usage:
See https://github.com/slack-go/slack/blob/master/examples/eventsapi/events.go
## Socketmode Event Handler (Experimental)
When using socket mode, dealing with an event can be pretty lengthy as it requires you to route the event to the right place.
Instead, you can use `SocketmodeHandler` much like you use an HTTP handler to register which event you would like to listen to and what callback function will process that event when it occurs.
See [./examples/socketmode_handler/socketmode_handler.go](./examples/socketmode_handler/socketmode_handler.go)
## ContributingYou are more than welcome to contribute to this project. Fork and
make a Pull Request, or create an Issue if you see any problem.Before making any Pull Request please run the following:
```
make pr-prep
```This will check/update code formatting, linting and then run all tests
## License
BSD 2 Clause license