]> ruin.nu Git - NDIRC.git/blobdiff - ndawn.pl
Basic conversion to POE::Component::IRC
[NDIRC.git] / ndawn.pl
old mode 100644 (file)
new mode 100755 (executable)
index 0de8351..e1b08a5
--- a/ndawn.pl
+++ b/ndawn.pl
@@ -1,3 +1,5 @@
+#!/usr/bin/perl -w
+
 #**************************************************************************
 #   Copyright (C) 2009 by Michael Andreen <harvATruinDOTnu>               *
 #                                                                         *
 #   along with this program; if not, write to the                         *
 #   Free Software Foundation, Inc.,                                       *
 #   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         *
-#**************************************************************************/
+#**************************************************************************
 
 use strict;
 use warnings;
-use vars qw($VERSION %IRSSI);
-
-use Irssi;
-use Irssi::Irc;
-
-$VERSION = "0.1";
-%IRSSI = (
-    authors => "harv",
-    contact => "harv\@ruin.nu",
-    name    => "NewDawn testbot script",
-    description => "Testbot used for implementing commands for nd bots",
-    license => "GPL-2 or (at your option) any later version",
-    url     => "",
-    changed => "",
+use feature ':5.10';
+use POE qw(Component::IRC::Qnet::State);
+
+use POE::Component::IRC::Plugin::Logger;
+use POE::Component::IRC::Plugin::BotTraffic;
+use POE::Component::IRC::Plugin::Connector;
+use POE::Component::IRC::Plugin::DCC;
+
+use ND::DB;
+use ND::Include;
+use NDIRC::Dispatcher;
+use NDIRC::Context;
+use NDIRC::Command;
+use NDIRC::Misc;
+use NDIRC::CommonStates;
+
+my $nickname = 'ndbot';
+my $ircname = 'ND test bot';
+my $server = 'irc.netgamers.org';
+
+# We create a new PoCo-IRC object
+my $irc = POE::Component::IRC::Qnet::State->spawn(
+       nick => $nickname,
+       ircname => $ircname,
+       server => $server,
+       servers => [$server, 'underworld.no.eu.netgamers.org', ]
+) or die "Oh noooo! $!";
+
+$irc->service_bots(QBOT => 'P@cservice.netgamers.org');
+
+$irc->plugin_add( 'BotTraffic', POE::Component::IRC::Plugin::BotTraffic->new() );
+$irc->plugin_add( 'DCC', POE::Component::IRC::Plugin::DCC->new() );
+$irc->plugin_add('Logger', POE::Component::IRC::Plugin::Logger->new(
+       Path    => 'irclogs',
+       DCC     => 0,
+       Private => 1,
+       Public  => 1,
+       Sort_by_date => 1,
+       Strip_color => 1,
+       Strip_formatting => 1,
+));
+
+my $DBH = DB();
+my $TICK = $DBH->selectrow_array('SELECT tick()');
+
+$ND::scanchan = '#testarmer';
+$ND::defchan = '#testarlite';
+$ND::memchan = '#testarmer';
+
+POE::Session->create(
+       package_states => [
+               'NDIRC::CommonStates' => [ qw(_default _start irc_001 sig_DIE signal_handler irc_disconnected irc_invite) ],
+               main => [ qw(irc_public irc_msg refresh sig_usr2 irc_join) ],
+       ],
+       heap => { irc => $irc},
 );
 
-$ND::refresh = 0;
+$poe_kernel->run();
 
-$SIG{USR1} = sub{
-       print "USR1";
-       $ND::refresh = 1;
-};
 
+sub sig_usr2 {
+       my $heap = $_[HEAP];
 
-use again 'ND::DB';
-use again 'ND::Include';
-use again 'NDIRC::Dispatcher';
-use again 'NDIRC::Context';
-use again 'NDIRC::Command';
-use again 'NDIRC::Misc';
+       my $disp = new NDIRC::Dispatcher;
 
-my $DBH = DB();
-my $TICK = $DBH->selectrow_array('SELECT tick()');
+       $disp->load(qw/Basic SMS Channel Def Intel Members PA Quotes Usermgm/);
 
-my $disp = new NDIRC::Dispatcher;
+       open CHANNELS, 'channels';
+       while (<CHANNELS>){
+               print;
+               my ($chan, @types) = split /\s+/;
+               say "$chan - @types";
+               $disp->add_channel($chan,\@types);
+       }
+       close CHANNELS;
 
-$disp->load(qw/Basic SMS Channel Def Intel Members PA Quotes Scans Usermgm/);
+       $heap->{disp} = $disp;
+}
 
-$ND::scanchan = '#testarmer';
-$ND::defchan = '#testarlite';
-$ND::memchan = '#testarmer';
-$disp->add_channel($ND::defchan, ['pub','help','channel','def']);
-$disp->add_channel($ND::scanchan, ['pub','help','channel','scan','member']);
-$disp->add_channel('pm', ['pub','help','pm']);
-
-sub event_pubmsg {
-       my ($server, $msg, $nick, $address, $channel) = @_;
-
-       eval {
-               if ($msg =~ /^(\S+): (.+)$/ && $disp->has_command('anon',$channel)){
-                       my $_ = $1;
-                       my $text = $2;
-                       my $channel = $server->channel_find($channel);
-                       my $nick = $channel->nick_find($1);
-                       unless ($nick || /(Constructing|Researching)/){
-                               print ".anon $_ $text";
-                               $msg = ".anon $_ $text";
-                       }
 
+sub irc_public {
+       my ($sender, $heap, $who, $where, $msg) = @_[SENDER, HEAP, ARG0 .. ARG2];
+       my ($nick,$username,$address) = ( split /[!@]/, $who );
+       my $channel = $where->[0];
+
+       my $irc = $sender->get_heap();
+
+       #$irc->yield(privmsg => $channel, "Authed? " . $irc->is_nick_authed($nick));
+
+       if ($msg =~ /^(\S+): (.+)$/ && $heap->{disp}->has_command('anon',$channel)){
+               my $_ = $1;
+               my $text = $2;
+               unless ($irc->is_channel_member($channel,$1) || /(Constructing|Researching)/){
+                       $msg = ".anon $_ $text";
                }
-               if (parseCommand($msg,$server,$nick,$address,$channel,$disp,DB())){
-                       #Command parsed and run successfully
-               }
-       };
-       print $@ if $@;
+
+       }
+       if (parseCommand($msg,$irc,$nick,$address,$channel,$heap->{disp},DB())){
+               #Command parsed and run successfully
+       }
 }
 
-sub event_privmsg {
-       my ($server, $msg, $nick, $address) = @_;
 
-       eval {
-               if (parseCommand($msg,$server,$nick,$address,'pm',$disp,DB())){
-                       #Command parsed and run successfully
+sub irc_msg {
+       my ($sender, $heap, $who, $where, $msg) = @_[SENDER, HEAP, ARG0 .. ARG2];
+       my ($nick,$username,$address) = ( split /[!@]/, $who );
+       my $irc = $sender->get_heap();
+
+       if (parseCommand($msg,$irc,$nick,$address,'pm',$heap->{disp},DB())){
+               #Command parsed and run successfully
+       }
+}
+
+sub irc_join {
+       my ($sender, $heap, $who, $channel) = @_[SENDER, HEAP, ARG0 .. ARG1];
+       my ($nick,$username,$address) = ( split /[!@]/, $who );
+       my $irc = $sender->get_heap();
+
+       if($heap->{disp}->has_command('voice',$channel)){
+               my $dbh = DB();
+               my $flags = $dbh->prepare_cached(q{
+SELECT DISTINCT flag
+FROM users u
+       JOIN groupmembers g USING (uid)
+       JOIN channel_group_flags gf USING (gid)
+WHERE u.hostmask = $1 AND channel = $2 AND flag IN ('o','v');
+               });
+               $flags->execute($address, $channel);
+               my $mode = '';
+               my @who;
+               while (my ($flag) = $flags->fetchrow()){
+                       $mode .= $flag;
+                       push @who, $nick;
                }
-       };
-       print $@ if $@;
+               say "$mode - @who";
+               $irc->yield(mode => $channel, $mode, @who) if $mode;
+       }
 }
 
 sub refresh {
-       print "SiG" if $ND::refresh;
-       $ND::refresh = 0;
+       my ($kernel,$heap) = @_[KERNEL,HEAP];
+       print 'Time: ' . time() . ' Lag: ' . $heap->{connector}->lag() . "\n";
+       $kernel->delay( refresh => 60 );
+       return;
 }
-
-Irssi::timeout_add(60*1000, 'refresh', undef);
-Irssi::timeout_add(1000, sub{refresh if $ND::refresh}, undef);
-Irssi::signal_add('message public','event_pubmsg');
-Irssi::signal_add('message private','event_privmsg');
-
-