0.5.0 • Published 9 years ago

ferd v0.5.0

Weekly downloads
1
License
MIT
Repository
github
Last release
9 years ago

A modular slackbot

Build Status

Ferd is a modular Slack Bot. It abstracts away the complexity of the Slack Real-Time Messaging API. Use this repo as an open source project to build your own bots, or check out FerdX for some fun.

To Run

Uses ES6. Runs using node --harmony

var ferdModule = require('ferdModule');
var Ferd = require('ferd');

var ferd = new Ferd(); //create new ferd instance
ferd.addModule(ferdModule); //inject module into ferd
ferd.login(); //bot starts listening
ferd.logout(); //bot stops listening

Creating Ferd Modules

To create modules, use the following syntax:

/* All variables in this closure are accessible by all bots using this module */
var randomYo = ["whats up? ", "hey ", "yo "];
var getRandomYo = function() {
  return randomYo[Math.floor(Math.random() * randomYo.length)];
};

module.exports = function(ferd) {
  /* All variables in this closure are accessible to all listeners in this module */
  var yoCount = 0;

  /* Listens to all messages */
  ferd.listen(/(.*) is (.*)/, function(response) {
    var sender = response.getMessageSender();
    response.send("No, " + sender.name + ", you " + "aren't " + response.match[2]);
  });

  /* Listens to messages tagged with bot's name or mentions bot */
  var listener = ferd.respond(/yo/i, function(response) {
    var sender = response.getMessageSender();
    response.send(getRandomYo() + sender.name);
    yoCount++;
  });

  /* Stops listening on specific listener */
  ferd.ignore(listener);

  /* Say 'hello' to join session and 'goodbye' to leave session.
   * Use to create poker and trivia games.
   */
  ferd.session(/hello/, /goodbye/, function(response) {
    response.send("I hear you... " + response.getMessageSender().name);
  });

  /*  Get all mentions of `yo` since bot's initialization */
  ferd.listen(/how many yo?/ function(response) {
    response.send(yoCount);
  });
};

Slack types

For more information on Slack types, check out https://api.slack.com/types.

Contributing

For contributing, see the contributing guidelines.

Style Guide

If you're contributing, make sure to check out the style guide.

Team

License

MIT

0.5.0

9 years ago

0.4.2

9 years ago

0.4.1

9 years ago

0.4.0

9 years ago

0.3.0

9 years ago

0.2.2

9 years ago

0.0.3

9 years ago

0.2.1

9 years ago

0.2.0

9 years ago