• This repository has been archived on 15/Nov/2017
  • Stars
    star
    116
  • Rank 303,894 (Top 6 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created over 13 years ago
  • Updated over 8 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A plugin-based HipChat bot written in Node.js.

wobot

A plugin-based HipChat bot written in Node.js.

Installation

The easiest way to obtain Wobot is through npm:

npm install wobot

Keep in mind this module depends on node-xmpp which cannot be built without:

  • libexpat1-dev: apt-get install libexpat1-dev
  • libicu-dev: apt-get install libicu-dev

Your First Bot

Instantiate the wobot.Bot class by passing it a hash containing:

  • jid: Jabber ID followed by /bot
  • password: The account's password
  • Optional caps_ver: Name and version of the bot. Defaults to Wobot:x.x.
  • Optional debug: When set to true, XMPP traffic will be printed.
  • Optional host: The hostname of the server. Defaults to jid host.
var wobot = require('wobot');

var bot = new wobot.Bot({
  jid: '[email protected]/bot',
  password: '??????'
});

bot.connect();

Events

The following events can be binded to:

onConnect(callback)

Emitted whenever the bot connects to the server.

onMessage(condition, callback)

Emitted whenever a message is sent to a channel the bot is in.

  • condition is either a RegExp or a string which must match the message for the callback to be triggered.
  • callback in the form of function(channel, from, message[, matches]).

condition can also be omitted i.e. onMessage(callback).

onPrivateMessage(condition, callback)

Emitted whenever a message is sent privately to the bot.

  • condition is either a RegExp or a string which must match the message for the callback to be triggered.
  • callback in the form of function(from, message[, matches]).

condition can also be omitted i.e. onPrivateMessage(callback).

onInvite(callback)

Emitted whenever invited to a room.

  • callback in the form of function(roomJid, fromJid, reason).

onPing(callback)

Emitted everytime the bot pings the server (roughly every 30 seconds.)

onError(callback)

Emitted whenever an error occurs. disconnect will be emitted afterwards.

  • callback in the form of function(condition, text, stanza)
    • condition is a string containing the XMPP stream error condition.
    • text is a string containing a human-readable error message.
    • stanza is an instance of xmpp.Element, when available.

onDisconnect(callback)

Emitted whenever the bot disconnects from the server.

Public API

Instances of wobot.Bot have the following methods:

join(roomJid, historyStanzas)

Join a channel.

  • roomJid is in the following format: [email protected].
  • historyStanzas: Max number of history entries to request (default=0).

part(roomJid)

Part a channel.

message(targetJid, message)

Send a message to either a channel or a user.

getRoster(callback)

Fetches the roster (buddy list).

  • callback in the form of function(err, roster, stanza)
    • err is a string representation of the error, if any.
    • roster is an array of objects containing user data.
    • stanza is the full response stanza, an xmpp.Element.

Example return value for roster:

[
  { name: 'Christian Joudrey', jid: '[email protected]', mention_name: 'ChristianJoudrey' },
  { name: 'The Bot', jid: '[email protected]', mention_name: 'TheBot' }
]

getRooms(callback)

Fetches the rooms available to the bot user. This is equivalent to what would show up in the HipChat lobby.

  • callback: Function to be triggered: function (err, items, stanza)
    • err: Error condition (string) if any
    • rooms: Array of objects containing room data
    • stanza: Full response stanza, an xmpp.Element

connect()

Connect to the server.

disconnect()

Disconnect from the server.

loadPlugin(identifier, plugin, options)

Load a plugin.

  • identifier: A unique string that identifies the plugin. This will be used to unload it.
  • plugin: Object with a load function as so: function load (bot).
  • options: Will be passed as the second argument to load.

sendIq(stanza, callback)

Sends an IQ stanza and stores a callback to be called when its response is received.

  • stanza is the xmpp.Element to send.
  • callback in the form of function (err, stanza).
    • err is a string representation of the error, if any.
    • stanza is the full response stanza, an xmpp.Element.

Legal stuff

Copyright (c) 2011 Christian Joudrey. See LICENSE for details.

Node.js is an official trademark of Joyent. This module is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.