}
sub nick {
- my ($nick) = @_;
+ my ($newnick) = @_;
+ my $mynick = $conn->nick();
- if (!defined $nick) {
+ if (!defined $newnick) {
&ERROR("nick: nick == NULL.");
return;
}
- if (defined $ident and $nick eq $ident) {
- &WARN("nick: nick == ident == '$ident'.");
+ if (!defined $mynick) {
+ &WARN("nick: mynick == NULL.");
return;
}
- my $bad = 0;
- $bad++ if (exists $nuh{$conn->nick()});
- $bad++ if (&IsNickInAnyChan($conn->nick()));
+ my $bad = 0;
+ $bad++ if (exists $nuh{$newnick});
+ $bad++ if (&IsNickInAnyChan($newnick));
if ($bad) {
- &WARN("Nick: not going to try and get my nick back. [".
- scalar(gmtime). "]");
-# hrm... over time we lose track of our own nick.
-# return;
+ &WARN("Nick: not going to try to change from $mynick to $newnick. [". scalar(gmtime). "]");
+ # hrm... over time we lose track of our own nick.
+ #return;
}
-# FIXME broken for multiple nicks
-# if ($nick =~ /^$mask{nick}$/) {
-# &rawout("NICK ".$nick);
-#
-# if (defined $ident) {
-# &status("nick: Changing nick to $nick (from $ident)");
-# # following shouldn't be here :(
-# $ident = $nick;
-# } else {
-# &DEBUG("first time nick change.");
-# $ident = $nick;
-# }
-#
-# return 1;
-# }
- &DEBUG("nick: failed... why oh why (nick => $nick)");
-
+ if ($newnick =~ /^$mask{nick}$/) {
+ &status("nick: Changing nick from $mynick to $newnick");
+ # ->nick() will NOT change cause we are using rawout?
+ &rawout("NICK $newnick");
+ return 1;
+ }
+ &DEBUG("nick: failed... why oh why (mynick=$mynick, newnick=$newnick)");
return 0;
}
sub on_nick_taken {
$conn = shift(@_);
my $nick = $conn->nick();
- my $newnick = $nick.int(rand 10);
+ #my $newnick = $nick . int(rand 10);
+ my $newnick = $nick . "_";
- if ($nick eq $ident) {
- &DEBUG("on_nick_tane: nick eq ident... wtf?");
- return;
- }
-
- &DEBUG("on_nick_taken: ident => $ident");
+ &DEBUG("on_nick_taken: nick => $nick");
&status("nick taken ($nick); preparing nick change.");
delete $chanstats{lc $nick};
###
- # FIXME: does this work?
- my $mynick = $conn->nick();
- if ($nick !~ /^\Q$ident\E$/ and $nick =~ /^\Q$mynick\E$/i) {
- &status("nickchange: own nickname became free; changing.");
- &nick($mynick);
- }
+ # FIXME: broken for multiple connects
+ #my $mynick = $conn->nick();
+ #if ($nick !~ /^\Q$ident\E$/ and $nick =~ /^\Q$mynick\E$/i) {
+ #&status("nickchange: own nickname became free; changing.");
+ #&nick($mynick);
+ #}
}
sub on_targettoofast {
}
# wantNick. xk++
-# if ($message =~ /^wantNick(\+)?$/i) {
-# my ($force) = ($1) ? 1 : 0;
-# $force = 0 unless (&IsFlag("n"));
-#
-# # cannot trust Net::IRC's nick() (TimRiker asks why?)
-# if ($param{'ircNick'} eq $ident) {
-# &msg($who, "I hope you're right. I'll try anyway.");
-# &DEBUG("ircNick => $param{'ircNick'}");
-# &DEBUG("ident => $ident");
-# }
-#
-# # fallback check, I guess. needed?
-# if (! &IsNickInAnyChan( $param{'ircNick'} ) ) {
-# my $str = "attempting to change nick to $param{'ircNick'}";
-# &status($str);
-# &msg($who, $str);
-# &nick($param{ 'ircNick' });
-# return;
-# }
-#
-# # idea from dondelecarlo :)
-# # TODO: use cache{nickserv}
-# if ($param{'nickServ_pass'}) {
-# return if ($param{'ircNick'} eq $ident or $force == 0);
-#
-# &status("someone is using our nick; GHOSTing");
-# &msg($who, "using GHOST on $param{'ircNick'}.");
-# &msg("NickServ", "GHOST $param{'ircNick'} $param{'nickServ_pass'}");
-#
-# $conn->schedule(5, sub {
-# &status("going to change nick after GHOST.");
-# &nick( $param{'ircNick'} );
-# } );
-#
-# return;
-# }
-#
-# return;
-# }
+ # FIXME does not try to get nick "back", just switches nicks
+ if ($message =~ /^wantNick\s(.*)?$/i) {
+ return unless (&hasFlag("o"));
+ my $wantnick = lc $1;
+ my $mynick = $conn->nick();
+
+ if ($mynick eq $wantnick) {
+ &msg($who, "I hope you're right. I'll try anyway (mynick=$mynick, wantnick=$wantnick).");
+ }
+
+ # fallback check, I guess. needed?
+ if (! &IsNickInAnyChan( $wantnick ) ) {
+ my $str = "attempting to change nick from $mynick to $wantnick";
+ &status($str);
+ &msg($who, $str);
+ &nick($wantnick);
+ return;
+ }
+
+ # idea from dondelecarlo :)
+ # TODO: use cache{nickserv}
+ if ($param{'nickServ_pass'}) {
+ my $str = "someone is using nick $wantnick; GHOSTing";
+ &status($str);
+ &msg($who, $str);
+ &msg("NickServ", "GHOST $wantnick $param{'nickServ_pass'}");
+
+ $conn->schedule(5, sub {
+ &status("going to change nick from $mynick to $wantnick after GHOST.");
+ &nick($wantnick);
+ } );
+
+ return;
+ }
+
+ return;
+ }
return "CONTINUE";
}