X-Git-Url: https://ruin.nu/git/?p=NDIRC.git;a=blobdiff_plain;f=ndawn.pl;h=e1b08a59eb21e5b930557c38882174da8064fa06;hp=ffb7e5851a9ec17c1c396af7722d7887b6290a49;hb=e8c94cdebefdc428ea92fde6db63f18d3e8399b2;hpb=c6964887c87acd5769ec90ce8734407f74433fc7 diff --git a/ndawn.pl b/ndawn.pl old mode 100644 new mode 100755 index ffb7e58..e1b08a5 --- a/ndawn.pl +++ b/ndawn.pl @@ -1,5 +1,7 @@ +#!/usr/bin/perl -w + #************************************************************************** -# Copyright (C) 2008 by Michael Andreen * +# Copyright (C) 2009 by Michael Andreen * # * # This program is free software; you can redistribute it and/or modify * # it under the terms of the GNU General Public License as published by * @@ -15,75 +17,152 @@ # 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/); + + open CHANNELS, 'channels'; + while (){ + print; + my ($chan, @types) = split /\s+/; + say "$chan - @types"; + $disp->add_channel($chan,\@types); + } + close CHANNELS; -my $disp = new NDIRC::Dispatcher; + $heap->{disp} = $disp; +} + + +sub irc_public { + my ($sender, $heap, $who, $where, $msg) = @_[SENDER, HEAP, ARG0 .. ARG2]; + my ($nick,$username,$address) = ( split /[!@]/, $who ); + my $channel = $where->[0]; -$disp->load('Basic','PA'); + my $irc = $sender->get_heap(); -$disp->add_channel('#testarlite', ['pub','help']); -$disp->add_channel('#testarmer', ['pub','help']); + #$irc->yield(privmsg => $channel, "Authed? " . $irc->is_nick_authed($nick)); -sub event_pubmsg { - my ($server, $msg, $nick, $address, $channel) = @_; + 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())){ + } + if (parseCommand($msg,$irc,$nick,$address,$channel,$heap->{disp},DB())){ #Command parsed and run successfully } } -sub event_privmsg { - my ($server, $msg, $nick, $address) = @_; - if (parseCommand($msg,$server,$nick,$address,'pm',$disp,DB())){ +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 refresh { - print "SiG" if $ND::refresh; - $ND::refresh = 0; +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; + } + say "$mode - @who"; + $irc->yield(mode => $channel, $mode, @who) if $mode; + } } -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'); - - +sub refresh { + my ($kernel,$heap) = @_[KERNEL,HEAP]; + print 'Time: ' . time() . ' Lag: ' . $heap->{connector}->lag() . "\n"; + $kernel->delay( refresh => 60 ); + return; +}