summaryrefslogtreecommitdiffstats
path: root/scripts/operit.pl
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/operit.pl')
-rw-r--r--scripts/operit.pl320
1 files changed, 320 insertions, 0 deletions
diff --git a/scripts/operit.pl b/scripts/operit.pl
new file mode 100644
index 0000000..60f3181
--- /dev/null
+++ b/scripts/operit.pl
@@ -0,0 +1,320 @@
+### operit.pl (c) 2002, 2003 Petr Baudis <pasky@ucw.cz>
+#
+## Perform certain action (invite/op/...) on request authenticated by the
+## IRC operator status.
+#
+## See http://pasky.ji.cz/~pasky/dev/irssi/ for the latest version.
+#
+## Thanks to:
+## mofo <mick@mofo.nl> (patches)
+## Garion <garion@dnsspam.nl> (ideas)
+## Borys <borys@irc.pl> (ideas)
+## devastor <devastor@idiosynkrasia.net>(bug reports)
+## babar <babar@magicnet.org> (delay patch)
+#
+## $Id: operit.pl,v 1.14 2003/09/06 12:27:11 pasky Exp pasky $
+#
+# $Log: operit.pl,v $
+# Revision 1.14 2003/09/06 12:27:11 pasky
+# Okay, so while I'm at it updated other instance of my email addy, copyright, bunch of grammar fixes and documented the operit_public_delay variable.
+#
+# Revision 1.13 2003/09/06 12:25:09 pasky
+# Updated my email addy.
+#
+# Revision 1.12 2003/09/06 12:23:50 pasky
+# Added support for randomly delayed operit - if operit is public, the delay is zero to five seconds by default - this helps greatly if there is a lot of operit-enabled clients on a channel. Patch by Babar <babar@magicnet.org> and me.
+#
+# Revision 1.11 2003/03/20 08:58:18 pasky
+# Match whole channel, not random part, when checking for deny_channels and deny_hosts. So you can deny operits at #iraq but still allow them at #iraqlive ;-). Thanks to viha for cooperation during testing.
+#
+# Revision 1.10 2002/11/29 16:51:46 pasky
+# Don't play with channels we aren't on. Fixes occassional 'can't call method command on undefined value'; thanks to devastor for a report.
+#
+# Revision 1.9 2002/10/19 13:12:34 pasky
+# Introduced operit_allow_public (by default on), which toggles accepting of public (on-channel) operit requests. Idea by Borys.
+#
+# Revision 1.8 2002/10/13 12:33:13 pasky
+# We don't care about /^operit [^!#&]/ anymore. Thanks fly to Garion for suggestion.
+#
+# Revision 1.7 2002/10/07 14:16:58 pasky
+# Added operit_show_requests bool setting (by default 1, that is same behaviour as now).
+#
+# Revision 1.6 2002/09/01 12:27:08 pasky
+# Erm, compilation fixes.
+#
+# Revision 1.5 2002/09/01 12:24:24 pasky
+# Allow specification of more channels separated by a comma in requests. Changed default value of operit_hosts_deny to something harmless. Patch by mofo <mick@mofo.nl>.
+#
+# Revision 1.4 2002/03/13 13:17:36 pasky
+# remove one debug message accidentally left there
+#
+# Revision 1.3 2002/03/12 18:02:37 pasky
+# invait actually works now
+#
+# Revision 1.2 2002/02/05 17:47:13 pasky
+# fixed many things :^). now it basically works how it should...
+#
+# Revision 1.1 2002/02/05 16:47:09 pasky
+# Initial revision
+#
+#
+###
+
+### Inspired by Operit-2.01b+enge script for ircII+ clients by
+## - Viha (Viha@Theblah.Org)
+# - Karzan (Kari@Theblah.Org)
+#
+## Credits also go to:
+# - LuckyS (lucky@binet.lv) [bug reports]
+# - Fusion (fusion@nuts.edu) [bug reports]
+# - RA^v^EN (raven@sky.siol.org) [bug reports]
+# - tumble (tumble@openface.ca) [beta testing]
+# - koopal (andre@nl.uu.net) [script ideas]
+# - pt (primetime@wnol.net) [script ideas]
+# - delta (delta@rus.uni-stuttgart.de) [script ideas]
+# - pht (svobodam@irc.vsp.cz) [bug reports]
+# - enge (engerim@magicnet.org) [modifications]
+#
+### The most recent version can always be found at
+# http://www.vip.fi/~viha/irc/
+###
+
+use strict;
+
+use vars qw ($VERSION %IRSSI $rcsid);
+
+$rcsid = '$Id: operit.pl,v 1.14 2003/09/06 12:27:11 pasky Exp pasky $';
+($VERSION) = '$Revision: 1.14 $' =~ / (\d+\.\d+) /;
+%IRSSI = (
+ name => 'operit',
+ authors => 'Petr Baudis',
+ contact => 'pasky@ucw.cz',
+ url => 'http://pasky.ji.cz/~pasky/dev/irssi/',
+ license => 'BSD',
+ description => 'Perform certain action (invite/op/...) on request authenticated by the IRC operator status.'
+ );
+
+
+use Irssi 20021117; # timeout_add_once
+use Irssi::Irc;
+
+
+my $queue = 0; # already queued an operit? (when?)
+my $disp = 0; # already displayed kind notice about already queued operit?
+my $cmd = ""; # command issued
+my $target = ""; # who issued the command
+my $chan = ""; # object of the command
+
+my $coperit = 0;
+my $cinvait = 0;
+my $cdamode = 0;
+my $mpublic = 0;
+
+
+sub event_privmsg {
+ my ($server, $data, $nick, $address) = @_;
+ my ($msgtarget, $text) = split(/ :/, $data, 2);
+
+ return if (Irssi::settings_get_bool("operit_deny"));
+
+ if ($text =~ s/^(invait|operit|damode)( .*)?$/$2/i) {
+ if (uc($msgtarget) eq uc($server->{nick})) {
+ $mpublic = 0;
+ } else {
+ return unless (Irssi::settings_get_bool("operit_allow_public"));
+ $mpublic = 1;
+ }
+
+ if (time - $queue < 10) {
+ Irssi::print "Operit currently deactivated or queued. Request ignored."
+ if (time - $disp > 20);
+ $disp = time;
+ return;
+ }
+
+ $cmd = $1; $target = $nick; $queue = 0; $disp = 0;
+
+# if ($msgtarget eq $N or $cmd eq 'invait') {
+ if (1) {
+ ($_, $chan) = split /\s+/, $text; # oh.. oh well :)
+ my $a = 0;
+
+ $chan = $msgtarget if (not $chan and $msgtarget ne $server->{nick});
+ return unless ($chan =~ /^[#!&]/);
+
+ foreach (split /\s+/, Irssi::settings_get_str("operit_chans")) {
+ s/\./\\./;
+ s/\*/.*/g;
+ if ($chan =~ /^$_$/i) {
+ $a++;
+ }
+ }
+
+ unless ($a) {
+ Irssi::print "Unauthorized $cmd $chan by $target (not in operit_chans)" if (Irssi::settings_get_bool("operit_show_requests"));
+ return;
+ }
+
+ foreach (split /\s+/, Irssi::settings_get_str("operit_chans_deny")) {
+ s/\./\\./;
+ s/\*/.*/g;
+ if ($chan =~ /^$_$/i) {
+ Irssi::print "Unauthorized $cmd $chan by $target (in operit_chans_deny)" if (Irssi::settings_get_bool("operit_show_requests"));
+ return;
+ }
+ }
+
+ foreach (split /^\s+$/, Irssi::settings_get_str("operit_hosts_deny")) {
+ s/\./\\./;
+ s/\*/.*/g;
+ if ($address =~ /$_/i) {
+ Irssi::print "Unauthorized $cmd $chan by $target <$address> (in operit_hosts_deny)" if (Irssi::settings_get_bool("operit_show_requests"));
+ return;
+ }
+ }
+
+ $queue = time;
+
+ $server->redirect_event("userhost", 1, $target, 0, 'redir userhost_operit_error',
+ {"event 302" => "redir userhost_operit"});
+
+ $server->command("USERHOST $target");
+ }
+ }
+}
+
+sub event_userhost_error {
+ Irssi::print "Operit userhost on $target failed, aborting the action...";
+
+ $queue = $disp = 0;
+}
+
+
+sub event_userhost_operit {
+ my ($server, $data) = @_;
+ my ($mynick, $reply) = split(/ +/, $data);
+ my ($nick, $user, $host) = $reply =~ /^:(.*)=.(.*)@(.*)/;
+
+ unless ($nick =~ s/\*$//) {
+ Irssi::print "$target requested UNAUTHORIZED $cmd on channel $chan" if (Irssi::settings_get_bool("operit_show_requests"));
+ return;
+ }
+
+ Irssi::print "$target requested $cmd on channel $chan" if (Irssi::settings_get_bool("operit_show_requests"));
+
+ foreach my $chansplit (split(/\,/, $chan)) {
+ my $channel = $server->channel_find($chansplit);
+
+ next unless ($channel);
+
+ if (lc($cmd) eq "operit") {
+ if ($mpublic) {
+ my $precision = 10; # Delay precision (10 = 1/10s)
+ my $rdelay = int(rand(Irssi::settings_get_str("operit_public_delay") * $precision)) * 1000 / $precision;
+
+ Irssi::print "Waiting " . ($rdelay / 1000) . " seconds before executing PUBLIC $cmd for $target on $chan";
+ Irssi::timeout_add_once($rdelay + 11, sub { # XXX why + 10 ? --pasky
+ my ($target, $channel) = @{$_[0]};
+ my ($tgrec) = $channel->nick_find($target);
+ $channel->command("op $target") unless ($tgrec and $tgrec->{'op'});
+ }, [ $target, $channel ]);
+ } else {
+ $channel->command("op $target");
+ }
+ $coperit++;
+
+ } elsif (lc($cmd) eq "invait") {
+ $server->command("invite $target $chansplit");
+ $cinvait++;
+
+ } elsif (lc($cmd) eq "damode") {
+ $server->command("notice $target mode for $chansplit is +$channel->{mode}");
+ $cdamode++;
+ }
+ }
+
+ $queue = $disp = 0;
+}
+
+
+sub event_ctcp {
+ my ($server, $data, $nick, $address, $target) = @_;
+
+ return if (Irssi::settings_get_bool("operit_deny"));
+
+ if ($data =~ /^operit/i) {
+ Irssi::print "$nick requested operit thru CTCP... no way!" if (Irssi::settings_get_bool("operit_show_requests"));
+ $server->command("NOTICE $nick ssshht!");
+ Irssi::signal_stop();
+ }
+}
+
+
+sub cmd_operit {
+ my ($data, $server, $channel) = @_;
+
+ if ($data =~ /^(usage|help)/i) {
+
+ foreach (split /\n/, <<USAGEE
+Operit:
+
+Local commands
+
+operit usage - This help.
+operit help - This help.
+operit status - Display statistical information.
+
+Remote commands
+
+operit #chan - Op the person in question on #chan. (req. *)
+invait #chan - Invait the person in question to #chan. (req. *)
+damode #chan - Give the person in question the modes of #chan. (req. *)
+
+Variables
+
+operit_chans - The channelmask operit/invait is permitted on. (* is *)
+operit_chans_deny - The channel(s) operit/invait is not permitted on. (* is *)
+operit_hosts_deny - The user\@host(s) operit/invait is not permitted from. (* is *)
+operit_deny - Toogle this ON if you don't actually want invait/operit to function.
+operit_show_requests
+ - Toogle this OFF if you don't want to see messages about operit requests.
+operit_allow_public
+ - Toogle this OFF if you don't want requests written on channels to be proceeded.
+operit_public_delay
+ - Set this to 0 if you don't want random delay between request and action.
+USAGEE
+ ) {
+ Irssi::print $_;
+ }
+
+ } elsif ($data =~ /^status/i) {
+ my $ctotal = $coperit + $cinvait + $cdamode;
+
+ Irssi::print "Operit $VERSION Status:";
+ Irssi::print "The last person to request $cmd was $target [$chan].";
+ Irssi::print "This session has served $coperit op-requests, $cinvait invite-requests and $cdamode mode-requests.";
+ Irssi::print "Making a total of $ctotal succesful requests.";
+
+ } else {
+ Irssi::print "Excuse moi, sir? I guess that you want /operit usage ..?";
+ }
+}
+
+
+Irssi::command_bind("operit", "cmd_operit");
+Irssi::signal_add("redir userhost_operit", "event_userhost_operit");
+Irssi::signal_add("redir userhost_operit_error", "event_userhost_error");
+Irssi::signal_add("default ctcp msg", "event_ctcp");
+Irssi::signal_add("event privmsg", "event_privmsg");
+
+
+Irssi::settings_add_str("operit", "operit_chans", "#* !*");
+Irssi::settings_add_str("operit", "operit_chans_deny", "#ircophackers");
+Irssi::settings_add_str("operit", "operit_hosts_deny", "*!*@*.lamehost1 *lamehost2");
+Irssi::settings_add_bool("operit", "operit_deny", 0);
+Irssi::settings_add_bool("operit", "operit_show_requests", 1);
+Irssi::settings_add_bool("operit", "operit_allow_public", 1);
+Irssi::settings_add_str("operit", "operit_public_delay", 5);
+
+
+Irssi::print("Operit $VERSION loaded... see command 'operit usage'");