Skip to content

brenns10/slacksoc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

97 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

slacksoc GoDoc

This is a new, and maybe improved Slack bot library for Go.

Features:

  • Plugin based architecture, providing built-in documentation for users
  • Configure plugins through a single YAML file
  • Entire Slack API exposed to plugins
  • Bot operations are thread-safe, allowing plugins to leverage concurrency

Included Plugins:

  • Triggers / responses, like the original Slackbot
  • Send CWRU/Yelp Love
  • Create GitHub issues

Usage

If all you would like to do is use the included plugins, usage is simple. First, install the slacksoc binary:

go get github.com/brenns10/slacksoc/slacksoc

Create a YAML configuration file - see sample.yaml for an example. Be sure that, at a minimum, the config contains your Slack API token, and an entry with appropriate configuration for each plugin you want to use. Finally, run the bot like this:

slacksoc config.yaml

Using External Plugins

If you would like to implement your own plugins, or use a third-party plugin (if they ever exist), you will need to write a small amount of boilerplate code. This is because Go has no support for dynamic module loading, and therefore plugins need to be registered with the bot before they can be used. Here is a sample:

package main

import "github.com/brenns10/slacksoc/lib"
import "github.com/brenns10/slacksoc/plugins"

func main() {
    plugins.Register()
    lib.Register("plugin name", PluginConstructor)
    lib.Run()
}

Developing Plugins

This slack bot implementation focuses on providing a simple and powerful experience for plugin developers. Currently, the plugin interface is still in flux, but it will soon stabilize. Documentation on plugin development can be found in the Wiki.

Contributing

Contributions to this repository are welcomed! Changes ought to be tested on a real Slack team before being submitted. Plugin contributions will be accepted at my (Stephen's) sole discretion, since custom plugins are easy to use without being part of the core plugin set. See the Github issues for suggestions on bugs, features, and plugins I'm interested in.

Please make sure that when you do development, you install the pre-commit hooks:

$ pip install --user pre-commit
$ pre-commit install

This ensures well-formatted code. You need only do this the first time you check out the repository.

About

Slack bot framework. Runs on YAML and procrastination.

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Languages