if ($message =~ s/^\.//) { # dcc chat commands.
### TODO: make use of &Forker(); here?
- &loadMyModule( $myModules{'UserDCC'} );
+ &loadMyModule('UserDCC');
&DCCBroadcast("#$who# $message","m");
# first time run.
if (!exists $users{_default}) {
&status("!!! First time run... adding _default user.");
- $users{_default}{FLAGS} = "mrt";
+ $users{_default}{FLAGS} = "amrt";
$users{_default}{HOSTS}{"*!*@*"} = 1;
}
}
# end of first time run.
- if (&IsChanConf("wingate")) {
+ if (&IsChanConf('Wingate')) {
my $file = "$bot_base_dir/$param{'ircUser'}.wingate";
open(IN, $file);
while (<IN>) {
my $type = uc( ($event->args)[1] );
my $nick = lc $event->nick();
+ &status("on_dcc type=$type nick=$nick sock=$sock");
+
# pity Net::IRC doesn't store nuh. Here's a hack :)
if (!exists $nuh{lc $nick}) {
$conn->whois($nick);
if ($type eq 'SEND') { # GET for us.
# incoming DCC SEND. we're receiving a file.
my $get = ($event->args)[2];
- open(DCCGET,">$get");
-
- $conn->new_get($event, \*DCCGET);
+ &status("DCC: not Initializing GET from $nick to '$param{tempDir}/$get'");
+ # FIXME: do we want to get anything?
+ return;
+ #open(DCCGET,">$param{tempDir}/$get");
+ #$conn->new_get($event, \*DCCGET);
} elsif ($type eq 'GET') { # SEND for us?
- &status("DCC: Initializing SEND for $nick.");
+ &status("DCC: not Initializing SEND for $nick.");
+ # FIXME: do we want to do anything?
+ return;
$conn->new_send($event->args);
} elsif ($type eq 'CHAT') {
if (exists $dcc{'SEND'}{$nick} and -f "$param{tempDir}/$nick.txt") {
&status("${b_green}DCC SEND$ob close from $b_cyan$nick$ob");
- &status("dcc_close: purging $nick.txt from Debian.pl");
+ &status("dcc_close: purging DCC send $nick.txt");
unlink "$param{tempDir}/$nick.txt";
delete $dcc{'SEND'}{$nick};
my $nick = lc $event->nick();
my $sock = ($event->to)[0];
+ &status("on_dcc_open type=$type nick=$nick sock=$sock");
+
$msgType = 'chat';
$type ||= "???";
### BUG: who is set to bot's nick?
}
} elsif ($type eq 'SEND') {
- &DEBUG("Starting DCC receive.");
+ &status("Starting DCC receive.");
foreach ($event->args) {
- &DEBUG(" => '$_'.");
+ &status(" => '$_'.");
}
} else {
&verifyUser($nick, $nuh{lc $nick});
if (!exists $users{$userHandle}{HOSTS}) {
- &pSReply("you have no hosts defined in my user file; rejecting.");
+ &performStrictReply("you have no hosts defined in my user file; rejecting.");
$sock->close();
return;
}
### ROOTWARN:
&rootWarn($who,$user,$host,$chan) if (
- &IsChanConf("rootWarn") &&
+ &IsChanConf('RootWarn') &&
$user =~ /^~?r(oo|ew|00)t$/i
);
+ ### emit a message based on who just joined
+ &onjoin($who,$user,$host,$chan) if (&IsChanConf('OnJoin'));
+
### NEWS:
- if (&IsChanConf("news") && &IsChanConf("newsKeepRead")) {
- if (!&loadMyModule("news")) { # just in case.
- &DEBUG("could not load news.");
+ if (&IsChanConf('News') && &IsChanConf('newsKeepRead')) {
+ if (!&loadMyModule('News')) { # just in case.
+ &DEBUG('could not load news.');
} else {
&News::latest($chan);
}
}
### botmail:
- if (&IsChanConf("botmail")) {
+ if (&IsChanConf('botmail')) {
&botmail::check(lc $who);
}
$nuh{lc $newnick} = $nuh{lc $nick};
delete $nuh{lc $nick};
- if ($nick eq $ident) {
+ if ($nick eq $conn->nick()) {
&status(">>> I materialized into $b_green$newnick$ob from $nick");
- $ident = $newnick;
+ $ident = $newnick;
+ $conn->nick($newnick);
} else {
&status(">>> $b_cyan$nick$ob materializes into $b_green$newnick$ob");
my $mynick=$conn->nick();
sub on_public {
$conn = shift(@_);
my ($event) = @_;
- my $msg = ($event->args)[0];
+ my $msg = ($event->args)[0];
$chan = lc( ($event->to)[0] ); # CASING.
my $nick = $event->nick;
$who = $nick;
&status(">>> topic/$b_blue$chan$ob by $b_cyan$nick$ob -> $topic");
} else { # join.
my ($nick, $chan, $topic) = $event->args;
- if (&IsChanConf("topic")) {
+ if (&IsChanConf('Topic')) {
$topic{$chan}{'Current'} = $topic;
&topicAddHistory($chan,$topic);
}