$orig{message} = $msg;
$nuh = $nuh{$who};
$uh = (split /\!/, $nuh)[1];
+ $h = (split /\@/, $uh)[1];
$addressed = 1;
$msgType = 'chat';
&status("End of motd. Now lets join some channels...");
if (!scalar @joinchan) {
- &WARN("joinchan array is empty!!!");
+ &WARN("joinchan array is empty!");
@joinchan = &getJoinChans(1);
}
+ # ok, we're free to do whatever we want now. go for it!
+ $running = 1;
+
# unfortunately, Net::IRC does not implement this :(
# invalid command... what is it?
# &rawout("NOTIFY $ident");
$ircstats{'DisconnectTime'} = time();
$ircstats{'DisconnectReason'} = $what;
$ircstats{'DisconnectCount'}++;
- $ircstats{'TotalTime'} += time() - $ircstats{'ConnectTime'};
+ $ircstats{'TotalTime'} += time() - $ircstats{'ConnectTime'}
+ if ($ircstats{'ConnectTime'});
# clear any variables on reconnection.
$nickserv = 0;
+ &DEBUG("on_disconnect: 1");
&clearIRCVars();
+ &DEBUG("on_disconnect: 2");
+
+ if (!defined $self) {
+ &WARN("on_disconnect: self is undefined! WTF");
+ &DEBUG("running function irc... lets hope this works.");
+ &irc();
+ return;
+ }
+
if (!$self->connect()) {
+ &DEBUG("on_disconnect: 3");
&WARN("not connected? help me. gonna call ircCheck() in 60s");
+ &clearIRCVars();
&ScheduleThis(1, "ircCheck");
-# &ScheduleThis(10, "ircCheck");
-# &ScheduleThis(30, "ircCheck");
}
}
### TODO: join key.
if (exists $chanconf{$chan}) {
+ # it's still buggy :/
if (&validChan($chan)) {
&msg($who, "i'm already in \002$chan\002.");
- next;
+# return;
}
&status("invited to $b_blue$chan$ob by $b_cyan$nick$ob");
$chan = lc( ($event->to)[0] ); # CASING!!!!
$who = $event->nick();
$msgType = "public";
+ my $i = scalar(keys %{ $channels{$chan} });
+ my $j = $cache{maxpeeps}{$chan} || 0;
$chanstats{$chan}{'Join'}++;
$userstats{lc $who}{'Join'} = time() if (&IsChanConf("seenStats"));
+ $cache{maxpeeps}{$chan} = $i if ($i > $j);
&joinfloodCheck($who, $chan, $event->userhost);
if (defined( my $whojoin = $cache{join}{$chan} )) {
&msg($chan, "Okay, I'm here. (courtesy of $whojoin)");
delete $cache{join}{$chan};
+ &joinNextChan(); # hack.
}
### TODO: move this to &joinchan()?
$uh = $event->userhost();
$nuh = $nick."!".$uh;
$msgtime = time();
+ $h = $host;
if ($nick eq $ident) { # hopefully ourselves.
if ($msg eq "TEST") {
sub on_ping_reply {
my ($self, $event) = @_;
- my $nick = $event->nick;
- my $lag = time() - ($event->args)[1];
+ my $nick = $event->nick;
+ my $t = ($event->args)[1];
+ if (!defined $t) {
+ &WARN("on_ping_reply: t == undefined.");
+ return;
+ }
+
+ my $lag = time() - $t;
&status(">>> ${b_green}CTCP PING$ob reply from $b_cyan$nick$ob: $lag sec.");
}
$msgType = "public";
# todo: move this out of hookMsg to here?
($user,$host) = split(/\@/, $uh);
+ $h = $host;
# rare case should this happen - catch it just in case.
if ($bot_pid != $$) {
);
- &dbReplace("stats", %hash);
+ &dbReplace("stats", "nick", %hash);
# does not work, atleast with old mysql!!! :(
# &dbReplace("stats", (nick => $who, type => $x, -counter => "counter+1") );
}
### $chan = $reason; # no.
my $count = 0;
- foreach (keys %channels) {
+ foreach (grep !/^_default$/, keys %channels) {
# fixes inconsistent chanstats bug #1.
if (!&IsNickInChan($nick,$_)) {
$count++;
}
if (grep /^\Q$nick\E$/i, @vernick) {
- &WARN("nick $nick found in vernick; skipping.");
+ &WARN("nick $nick found in vernick ($ver); skipping.");
return;
}
push(@vernick, $nick);
} elsif ($ver =~ /irssi/i) {
$ver{irssi}{$nick} = $ver;
- } elsif ($ver =~ /epic/i) {
+ } elsif ($ver =~ /epic|(Third Eye)/i) {
$ver{epic}{$nick} = $ver;
+ } elsif ($ver =~ /ircII|PhoEniX/i) {
+ $ver{ircII}{$nick} = $ver;
+
} elsif ($ver =~ /mirc/i) {
- &DEBUG("verstats: mirc: $nick => '$ver'.");
+# &DEBUG("verstats: mirc: $nick => '$ver'.");
$ver{mirc}{$nick} = $ver;
+# ok... then we get to the lesser known/used clients.
} elsif ($ver =~ /ircle/i) {
$ver{ircle}{$nick} = $ver;
- } elsif ($ver =~ /ircII/i) {
- $ver{ircII}{$nick} = $ver;
+ } elsif ($ver =~ /chatzilla/i) {
+ $ver{chatzilla}{$nick} = $ver;
+
+ } elsif ($ver =~ /pirch/i) {
+ $ver{pirch}{$nick} = $ver;
} elsif ($ver =~ /sirc /i) {
$ver{sirc}{$nick} = $ver;
my ($self, $event) = @_;
my @args = $event->args;
- &DEBUG("on_chanfull: args => @args");
+ &status(">>> chanfull/$b_blue$args[1]$ob");
+
&joinNextChan();
}
my ($self, $event) = @_;
my @args = $event->args;
- &DEBUG("on_inviteonly: args => @args");
+ &status(">>> inviteonly/$b_cyan$args[1]$ob");
+
&joinNextChan();
}
sub on_banned {
my ($self, $event) = @_;
my @args = $event->args;
+ my $chan = $args[1];
+
+ &status(">>> banned/$b_blue$chan$ob $b_cyan$args[0]$ob");
- &DEBUG("on_banned: args => @args");
&joinNextChan();
}
&joinNextChan();
}
+sub on_useronchan {
+ my ($self, $event) = @_;
+ my @args = $event->args;
+
+ &DEBUG("on_useronchan: args => @args");
+ &joinNextChan();
+}
+
1;