Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
node-irc
_ is an IRC client library written in JavaScript_ for Node_.
.. _node-irc
: http://node-irc.readthedocs.org/
.. _JavaScript: http://en.wikipedia.org/wiki/JavaScript
.. _Node: http://nodejs.org/
You can access more detailed documentation for this module at Read the Docs
_
The easiest way to get it is via npm_::
npm install irc
If you want to run the latest version (i.e. later than the version available via npm_) you can clone this repo, then use npm_ to link-install it::
npm link /path/to/your/clone
Of course, you can just clone this, and manually point at the library itself, but I really recommend using npm_!
This library provides basic IRC client functionality. In the simplest case you can connect to an IRC server like so::
var irc = require('irc');
var client = new irc.Client('irc.yourserver.com', 'myNick', {
channels: ['#channel'],
});
Of course it's not much use once it's connected if that's all you have!
The client emits a large number of events that correlate to things you'd normally see in your favourite IRC client. Most likely the first one you'll want to use is::
client.addListener('message', function (from, to, message) {
console.log(from + ' => ' + to + ': ' + message);
});
or if you're only interested in messages to the bot itself::
client.addListener('pm', function (from, message) {
console.log(from + ' => ME: ' + message);
});
or to a particular channel::
client.addListener('message#yourchannel', function (from, message) {
console.log(from + ' => #yourchannel: ' + message);
});
At the moment there are functions for joining::
client.join('#yourchannel yourpass');
parting::
client.part('#yourchannel');
talking::
client.say('#yourchannel', "I'm a bot!");
client.say('nonbeliever', "SRSLY, I AM!");
and many others. Check out the API documentation for a complete reference.
For any commands that there aren't methods for you can use the send() method which sends raw messages to the server::
client.send('MODE', '#yourchannel', '+o', 'yournick');
When the client receives errors from the IRC network, it emits an "error"
event. As stated in the Node JS EventEmitter documentation
_ if you don't bind
something to this error, it will cause a fatal stack trace.
The upshot of this is basically that if you bind an error handler to your client, errors will be sent there instead of crashing your program.::
client.addListener('error', function(message) {
console.log('error: ', message);
});
Further documentation (including a complete API reference) are available in
reStructuredText format in the docs/ folder of this project, or online at Read the Docs
_.
If you find any issues with the documentation (or the module) please send a pull request or file an issue and I'll do my best to accommodate.
.. _npm: http://github.com/isaacs/npm
.. _here: http://node-irc.readthedocs.org/en/latest/API.html
.. _Read the Docs
: http://readthedocs.org/docs/node-irc/en/latest/
.. _Node JS EventEmitter documentation
: http://nodejs.org/api/events.html#events_class_events_eventemitter
FAQs
A fork of martynsmith/node-irc that allows address binding
The npm package lib-irc receives a total of 0 weekly downloads. As such, lib-irc popularity was classified as not popular.
We found that lib-irc demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.