From 124c24ccc9f1a6d3df51cfaa24add7d8aa87d2ff Mon Sep 17 00:00:00 2001
From: Adhidarma Hadiwinoto <gua@adhisimon.org>
Date: Wed, 25 Nov 2015 22:40:17 +0700
Subject: [PATCH] sasl dan autojoin channel

---
 index.js | 34 ++++++++++++++++++++--------------
 1 file changed, 20 insertions(+), 14 deletions(-)

diff --git a/index.js b/index.js
index 2e367c1..36b838f 100644
--- a/index.js
+++ b/index.js
@@ -1,10 +1,17 @@
 var fs = require('fs');
 var ini = require('ini');
 var config = ini.parse(fs.readFileSync(__dirname + '/config.ini', 'utf-8'));
+var redis = require('redis');
 
 var irc = require('irc');
-var client = new irc.Client(config.globals.irc_server, config.globals.irc_nick);
-var redis = require('redis');
+var options = {
+    userName: config.globals.irc_nick,
+    password: config.globals.nickserv_password,
+    sasl: true,
+    stripColors: true,
+    channels: [config.globals.aaa_pull_channel, config.globals.topup_message_channel]
+};
+var client = new irc.Client(config.globals.irc_server, config.globals.irc_nick, options);
 
 var redisClient = redis.createClient(config.globals.redis_port, config.globals.redis_host);
 
@@ -13,30 +20,31 @@ client.addListener('message', function (from, to, message) {
 });
 
 client.addListener('registered', function () {
-    console.log('onRegistered');
-    client.say('NickServ', 'identify ' + config.globals.nickserv_password);
+    console.log('Connected');
+    //client.say('NickServ', 'identify ' + config.globals.nickserv_password);
 });
 
 client.addListener('join', function (channel, nick, message) { 
     console.log('JOIN ' + channel);
     
-    if (channel == '#' + config.globals.aaa_pull_channel) {
+    if (channel == config.globals.aaa_pull_channel) {
         redisClient.psubscribe('kimochi.*.text');
     } 
-    else if (channel == '#' + config.globals.topup_message_channel) {
+    else if (channel == config.globals.topup_message_channel) {
         redisClient.psubscribe('echi.topup_report.*.message');
     }
 });
 
 client.addListener('notice', function (from, to, message) {
     console.log('NOTICE ' + from + ' => ' + to + ': ' + message);
+    return;
     
     if (from == 'NickServ' && message.match('You are now identified for')) {
-        console.log('Joining #' + config.globals.aaa_pull_channel);
-        client.join('#' + config.globals.aaa_pull_channel);
+        console.log('Joining ' + config.globals.aaa_pull_channel);
+        client.join(config.globals.aaa_pull_channel);
         
-        console.log('Joining #' + config.globals.topup_message_channel);
-        client.join('#' + config.globals.topup_message_channel);
+        console.log('Joining ' + config.globals.topup_message_channel);
+        client.join(config.globals.topup_message_channel);
     }
 });
 
@@ -47,12 +55,10 @@ client.addListener('pm', function (from, message) {
 redisClient.on("pmessage", function (pattern, channel, message) {
     if (channel.match(/^kimochi/)) {
         var gateway = channel.match(/gw:(.*)\.text/)[1];
-        //console.log(message + ' (' + gateway + ')');    
-        client.say('#' + config.globals.aaa_pull_channel, message + ' (' + gateway + ')');
+        client.say(config.globals.aaa_pull_channel, message + ' (' + gateway + ')');
     }
     else if (channel.match(/^echi/)) {
         var gateway = channel.match(/gw:(.*)\.message$/)[1];
-        //console.log(message + ' (' + gateway + ')');
-        client.say('#' + config.globals.topup_message_channel, message + ' (' + gateway + ')');
+        client.say(config.globals.topup_message_channel, message + ' (' + gateway + ')');
     }
 });
-- 
1.9.0