Security News
UK Officials Consider Banning Ransomware Payments from Public Entities
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
node-irc is an IRC client library written in JavaScript for Node.
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 we really recommend using npm!
Note that as of version 0.3.8, node-irc supports character set detection using icu. You'll need to install libiconv (if necessary; Linux systems tend to ship this in their glibc) and libicu (and its headers, if necessary) in order to use this feature. If you do not have these libraries or their headers installed, you will receive errors when trying to build these dependencies. However, node-irc will still install (assuming nothing else failed) and you'll be able to use it, just not the character set features.
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 favorite 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) is 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 we'll do our best to accommodate.
You can also visit us on ##node-irc on freenode to discuss issues you're having with the library, pull requests, or anything else related to node-irc.
v0.4.1 (2016-01-27)
Implemented enhancements:
Fixed bugs:
Closed issues:
Merged pull requests:
FAQs
An IRC client library for node
The npm package irc receives a total of 2,564 weekly downloads. As such, irc popularity was classified as popular.
We found that irc demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers 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
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.