GitXplorerGitXplorer
m

ircb

public
68 stars
6 forks
3 issues

Commits

List of commits on branch master.
Unverified
21eb437aa6a2934994cd52bb18c4d8bd939ef527

Merge pull request #12 from julianduque/whois

mmmalecki committed 10 years ago
Unverified
ac39f054a634c56589b7f262c97c602764835abd

Remove events which were removed by the refactor

mmmalecki committed 10 years ago
Unverified
9a1ed6972d32c2182b327cc6cf8c714469335167

Merge pull request #16 from mmalecki/stream

mmmalecki committed 10 years ago
Unverified
75c7a3d8925e4a69a02cca27a77fe021d8c00e08

Merge pull request #17 from ralphtheninja/master

mmmalecki committed 10 years ago
Unverified
9829d74f3c6257d20c83587e8e6e3eef3e8883f5

update README

rralphtheninja committed 10 years ago
Unverified
067108da8fedf02370e5274a97675436df0422f7

Make `IRCb` a `Duplex` stream

mmmalecki committed 11 years ago

README

The README file for this repository.

ircb

Name courtesy of @isaacs.

An IRC library which I like.

Usage

Creating a client

var tls = require('tls');
var ircb = require('ircb');

var irc = ircb({
  username: 'ircbexample',
  realName: 'ircbexample',
  nick: 'ircbexample',
  channels: ['#nodebombrange']
}, function () {
  irc.on('names', function (channel, names) {
    console.log(channel + ': ' + names.join(', '));
  });

  irc.on('message', function (from, to, msg) {
    console.log(from, '->', to + ': ' + msg)
  })
});

irc.pipe(tls.connect({
  host: 'chat.freenode.net',
  port: 6697
})).pipe(irc);

Joining a channel

irc.join('#node.js');

Saying stuff

To a channel

irc.say('#node.js', 'hello world');

To a person

irc.say('mmalecki', 'hello world');

Getting list of people from a channel

irc.names('#node.js', function (err, names) {
  if (err) throw err;
  console.log('There are ' + names.length + ' people in #node.js channel');
});

API

ircb(options, callback)

  • options (Object)
    • options.nick (string, required) - IRC nick
    • options.password (string) - IRC password
    • options.username (string) - IRC username
    • options.realName (string) - IRC real name
    • options.channels (array of string, default: []) - channels to join. If specified, calls callback after joining all the channels.
  • callback (function) - called after identifying and joining all the channels specified

Returns a Duplex stream, which should be used like that:

connection.pipe(ircb()).pipe(connection);

Events

ircb returns an event emitter which emits the following events:

  • register - emitted when instance is connected, identified and joined all the specified channels
  • message(from, to, message) - emitted when a message is received
  • names(channel, names) - emitted when a list of names for channel is received
  • join(prefix, channel) - emitted when someone joins a channel. prefix is of the format <nick>!<id>@<host>
  • part(prefix, channel, message) - emitted when someone leaves a channel
  • kick(prefix, channel, user, reason) - emitted when someone is kicked from a channel. prefix (see above) kicked user for a reason (defaults to user if no reason was given)
  • motd(text) - emitted when the message of the day is received