Skip to content

muesli/beehive

Folders and files

NameName
Last commit message
Last commit date

Latest commit

8fa9adb Β· Jan 15, 2017
Aug 1, 2014
Feb 3, 2015
Jun 25, 2014
Dec 6, 2016
Jan 15, 2017
Dec 6, 2016
Dec 6, 2016
Jul 29, 2014
Dec 28, 2016
Jun 23, 2014
May 28, 2016
Dec 6, 2016

Repository files navigation

beehive

beehive is an event and agent system, which allows you to create your own agents that perform automated tasks triggered by events and filters. It is modular, flexible and really easy to extend - for anyone. It has modules (we call them bees), so it can interface with, talk to, or retrieve information from Twitter, Tumblr, Email, IRC, Jabber, RSS, Jenkins, Hue - to name just a few. Check out the full list of available bees in our Wiki.

Connecting those bees with each other let's you create immensly useful agents.

Here are just a few examples of things Beehive could do for you:

  • Re-post tweets on your Tumblr blog
  • Forward incoming chat messages to your email account
  • Turn on the heating system if the temperature drops below a certain value
  • Run your own IRC bot that let's you trigger builds on a Jenkins CI
  • Control your Hue lighting system
  • Notify you when a stock's price drops below a certain value

beehive's Logo

Installation

Make sure you have a working Go environment. See the install instructions.

First of all you need to checkout the source code:

git clone git://github.com/muesli/beehive.git
cd beehive

Now we need to get the required dependencies:

go get -v

Let's build beehive:

go build

Run beehive -help to see a full list of options!

Configuration

TL;DR

Take a look at a few chain recipes here. Pick one, edit it to your needs and store it as 'beehive.conf'. beehive looks for this configuration file in its current working directory. Alternatively, you can specify a different config file using the -config option.

Detailed

The configuration file, beehive.conf by default, is a JSON file that consists of two parts: Bees and Chains.

Bees are pieces of Go code that can communicate with some service.

  • you could have a Bee that sits in your IRC channel and responds to certain commands.
  • you could have a Bee that hooks into your Instagram account and auto-tweets all of your photos.
  • you could have a Bee that hooks into cron, and sends an email with a command's status every N hours of the day.

Bees consist of four parts:

  1. "Name" : the name of the Bee that you are creating
  2. "Class" : the Golang class that communicates with the service you want
  3. "Description" : a description of what this Bee will do
  4. "Options" : an array of options to send to the Golang class

Example:

"Bees":[
   {
      "Name":"ircbee_freenode",
      "Class":"ircbee",
      "Description":"ircbee connected to freenode, channel #beehive",
      "Options":[
         {
            "Name":"server",
            "Value":"irc.freenode.net"
         },
         {
            "Name":"nick",
            "Value":"beehive"
         },
         {
            "Name":"channels",
            "Value":["#beehive"]
         }
      ]
   }
],

The above definition creates a Bee that can communicate with IRC channels and can respond to IRC events:

  • "ircbee_freenode" is the name of this Bee.
  • "ircbee" is the name of Golang class that can communicate using the IRC protocol.
  • "Options" are the options to pass to the Golang class "ircbee":
    • The "server" option tells "ircbee" to connect to the IRC server at "irc.freenode.net"
    • The "nick" option tells "ircbee" to use the nickname "beehive"
    • The "channel" option tells "ircbee" to join IRC channel "#beehive".

Chains define what your Bees do, your configuration can have one or more Chains.

Chains consist of four parts:

  1. "Name" : the name of your Chain
  2. "Description" : a description of what this Chain does
  3. "Event" : the Event to "listen" for
  4. "Elements" : an array of Filters to apply to, and Actions to take when your Event occurs

Example:

"Chains":[
   {
      "Name": "filter_chain",
      "Description": "A chain containing various filters",
      "Event":{
         "Bee":"ircbee_freenode",
         "Name":"message"
      },
      "Elements":[
         {
            "Filter":{
               "Name":"contains",
               "Options":[
                  {
                     "Name":"text",
                     "CaseInsensitive":true,
                     "Value":"muesli"
                  }
               ]
            }
         },
         {
            "Action":{
               "Bee":"ircbee_freenode",
               "Name":"send",
               "Options":[
                  {
                     "Name":"channel",
                     "Value":"muesli"
                  },
                  {
                     "Name":"text",
                     "Value":"{{.user}} in {{.channel}} said: {{.text}}"
                  }
               ]
            }
         }
      ]
   }
]

The above definition defines a Chain that responds to the "message" event of the ircbee_freenode Bee. Whenever a "message" event occurs, all of the Filters defined in the Elements array are applied to the data generated by the "message" event. If all of the Filters return true, the "send" Action is executed. Bees generate events and can execute actions.

Each Action specifies its own options, so it would be difficult to cover them all here. In this case however, the "send" action messages the user muesli with the message "{{.user}} in {{.channel}} said: {{.text}}". {{.user}} is replaced by the user who generated the message that contained "muesli", {{.channel}} is replaced by the channel that the user was in when they generated the message, and {{.text}} is replaced by the "message" that was sent.

Development

API docs can be found here.

Continuous integration: Build Status