--- /dev/null
+#**************************************************************************
+# Copyright (C) 2009 by Michael Andreen <harvATruinDOTnu> *
+# *
+# 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 *
+# the Free Software Foundation; either version 2 of the License, or *
+# (at your option) any later version. *
+# *
+# This program is distributed in the hope that it will be useful, *
+# but WITHOUT ANY WARRANTY; without even the implied warranty of *
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
+# GNU General Public License for more details. *
+# *
+# You should have received a copy of the GNU General Public License *
+# along with this program; if not, write to the *
+# Free Software Foundation, Inc., *
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
+#**************************************************************************/
+package NDIRC::Bot;
+
+use strict;
+use warnings;
+use feature ':5.10';
+
+use Moose;
+
+use POE::Session;
+use POE::Component::IRC::Plugin::Logger;
+use POE::Component::IRC::Plugin::BotTraffic;
+use POE::Component::IRC::Plugin::Connector;
+use POE::Component::IRC::Plugin::AutoJoin;
+use POE::Component::IRC::Plugin::NickReclaim;
+
+use NDIRC::Dispatcher;
+
+use IO::File;
+
+# We registered for all events, this will produce some debug info.
+sub _default {
+ my ($event, $args) = @_[ARG0 .. $#_];
+ my @output = ( "$event: " );
+
+ for my $arg (@$args) {
+ if ( ref $arg eq 'ARRAY' ) {
+ push( @output, '[' . join(', ', @$arg ) . ']' );
+ }
+ else {
+ push ( @output, "'$arg'" );
+ }
+ }
+ print join ' ', @output, "\n";
+ return 0;
+}
+
+sub _start {
+ my ($kernel,$heap,$session) = @_[KERNEL,HEAP,SESSION];
+
+ # retrieve our component's object from the heap where we stashed it
+ my $irc = $heap->{irc};
+ $kernel->sig( DIE => 'sig_DIE' );
+ $kernel->sig( USR1 => 'sig_usr1' );
+ $kernel->sig( USR2 => 'sig_usr2' );
+ $kernel->sig( INT => 'signal_handler' );
+
+ $irc->plugin_add( 'NickReclaim', POE::Component::IRC::Plugin::NickReclaim->new() );
+ $irc->plugin_add( 'AutoJoin', POE::Component::IRC::Plugin::NickReclaim->new() );
+ $irc->plugin_add( 'BotTraffic', POE::Component::IRC::Plugin::BotTraffic->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,
+ ));
+
+ $heap->{connector} = POE::Component::IRC::Plugin::Connector->new(
+ servers => ['irc.netgamers.org', 'underworld.no.eu.netgamers.org'
+ ,'firefly.no.eu.netgamers.org', 'underworld.ca.us.netgamers.org' ]
+ );
+ $irc->plugin_add( 'Connector' => $heap->{connector} );
+
+ $kernel->signal($session => 'USR2');
+
+ $irc->yield( register => 'all' );
+ $irc->yield( connect => { server => 'irc.netgamers.org' } );
+
+ $kernel->delay( refresh => 60 );
+ return;
+}
+
+sub auth {
+ my $heap = $_[HEAP];
+
+ if (my $f = new IO::File 'auth'){
+ my $user = <$f>;
+ chomp $user;
+ my $pass = <$f>;
+ chomp $pass;
+ $heap->{irc}->yield(qbot_auth => $user => $pass);
+ }
+}
+
+sub sig_usr1 {
+ my ($kernel,$heap) = @_[KERNEL,HEAP];
+
+ $kernel->yield( 'refresh' );
+}
+
+sub sig_usr2 {
+ my $heap = $_[HEAP];
+
+ my $disp = new NDIRC::Dispatcher;
+
+ if (my $commands = new IO::File 'commands'){
+ my @commands = split /\W+/, do{local $/; <$commands>};
+ say "Loading commands from: @commands";
+ $disp->load(@commands);
+ }
+
+ my $channels = new IO::File 'channels';
+ while (<$channels>){
+ my ($chan, @types) = split /\s+/;
+ say "$chan - @types";
+ if ($chan =~ /^(.*):(.*)$/){
+ $chan = $1;
+ $disp->set_target($2,$chan);
+ }
+ $disp->add_channel($chan,\@types);
+ }
+
+ $heap->{disp} = $disp;
+}
+
+sub sig_DIE {
+ my( $kernel,$sig, $ex ) = @_[ KERNEL,ARG0, ARG1 ];
+ say "DIED!!!!!!!!!!!!!!";
+ # $sig is 'DIE'
+ # $ex is the exception hash
+ warn "$$: error in event: $ex->{error_str}";
+ $kernel->sig_handled();
+
+ # Send the signal to session that sent the original event.
+ #if( $ex->{source_session} ne $_[SESSION] ) {
+ #$kernel->signal( $ex->{source_session}, 'DIE', $sig, $ex );
+ #}
+}
+
+sub signal_handler {
+ my ($kernel, $signal_name, $heap) = @_[KERNEL, ARG0, HEAP];
+ print "First session caught SIG$signal_name\n";
+
+ given($signal_name){
+ when ('INT') {
+ exit unless $heap->{irc}->connected;
+ $heap->{INT} = 1;
+ $heap->{irc}->yield(quit => 'Bye!');
+ $kernel->sig_handled();
+ }
+ }
+ #$kernel->sig_handled();
+}
+
+sub irc_disconnected {
+ my ($sender,$heap) = @_[SENDER,HEAP];
+
+ exit if $heap->{INT};
+}
+
+sub irc_001 {
+ my ($sender,$heap,$kernel) = @_[SENDER,HEAP,KERNEL];
+
+ # Since this is an irc_* event, we can get the component's object by
+ # accessing the heap of the sender. Then we register and connect to the
+ # specified server.
+ my $irc = $sender->get_heap();
+
+ print "Connected to ", $irc->server_name(), "\n";
+
+ $kernel->yield( 'auth' );
+ $irc->yield( mode => $irc->nick_name, '+ix');
+
+ # we join our channels
+ $irc->yield( join => $_ ) for grep /^#/, keys %{$heap->{disp}->channels};
+ return;
+}
+
+sub irc_invite {
+ my ($sender, $heap, $who, $channel) = @_[SENDER, HEAP, ARG0 .. ARG1];
+ my $irc = $sender->get_heap();
+
+ $irc->yield( join => $_ ) for grep /^$channel$/i, keys %{$heap->{disp}->channels}
+}
+
+sub irc_public {
+}
+
+sub irc_msg {
+}
+
+sub refresh {
+}
+
+sub irc_join {
+}
+
+1;
+++ /dev/null
-#**************************************************************************
-# Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu> *
-# *
-# 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 *
-# the Free Software Foundation; either version 2 of the License, or *
-# (at your option) any later version. *
-# *
-# This program is distributed in the hope that it will be useful, *
-# but WITHOUT ANY WARRANTY; without even the implied warranty of *
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
-# GNU General Public License for more details. *
-# *
-# You should have received a copy of the GNU General Public License *
-# along with this program; if not, write to the *
-# Free Software Foundation, Inc., *
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
-#**************************************************************************/
-package NDIRC::CommonStates;
-
-use strict;
-use warnings;
-use feature ':5.10';
-
-use POE::Session;
-use POE::Component::IRC::Plugin::Logger;
-use POE::Component::IRC::Plugin::BotTraffic;
-use POE::Component::IRC::Plugin::Connector;
-use POE::Component::IRC::Plugin::AutoJoin;
-use POE::Component::IRC::Plugin::NickReclaim;
-
-use NDIRC::Dispatcher;
-
-use IO::File;
-
-# We registered for all events, this will produce some debug info.
-sub _default {
- my ($event, $args) = @_[ARG0 .. $#_];
- my @output = ( "$event: " );
-
- for my $arg (@$args) {
- if ( ref $arg eq 'ARRAY' ) {
- push( @output, '[' . join(', ', @$arg ) . ']' );
- }
- else {
- push ( @output, "'$arg'" );
- }
- }
- print join ' ', @output, "\n";
- return 0;
-}
-
-sub _start {
- my ($kernel,$heap,$session) = @_[KERNEL,HEAP,SESSION];
-
- # retrieve our component's object from the heap where we stashed it
- my $irc = $heap->{irc};
- $kernel->sig( DIE => 'sig_DIE' );
- $kernel->sig( USR1 => 'sig_usr1' );
- $kernel->sig( USR2 => 'sig_usr2' );
- $kernel->sig( INT => 'signal_handler' );
-
- $irc->plugin_add( 'NickReclaim', POE::Component::IRC::Plugin::NickReclaim->new() );
- $irc->plugin_add( 'AutoJoin', POE::Component::IRC::Plugin::NickReclaim->new() );
- $irc->plugin_add( 'BotTraffic', POE::Component::IRC::Plugin::BotTraffic->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,
- ));
-
- $heap->{connector} = POE::Component::IRC::Plugin::Connector->new(
- servers => ['irc.netgamers.org', 'underworld.no.eu.netgamers.org'
- ,'firefly.no.eu.netgamers.org', 'underworld.ca.us.netgamers.org' ]
- );
- $irc->plugin_add( 'Connector' => $heap->{connector} );
-
- $kernel->signal($session => 'USR2');
-
- $irc->yield( register => 'all' );
- $irc->yield( connect => { server => 'irc.netgamers.org' } );
-
- $kernel->delay( refresh => 60 );
- return;
-}
-
-sub auth {
- my $heap = $_[HEAP];
-
- if (my $f = new IO::File 'auth'){
- my $user = <$f>;
- chomp $user;
- my $pass = <$f>;
- chomp $pass;
- $heap->{irc}->yield(qbot_auth => $user => $pass);
- }
-}
-
-sub sig_usr1 {
- my ($kernel,$heap) = @_[KERNEL,HEAP];
-
- $kernel->yield( 'refresh' );
-}
-
-sub sig_usr2 {
- my $heap = $_[HEAP];
-
- my $disp = new NDIRC::Dispatcher;
-
- if (my $commands = new IO::File 'commands'){
- my @commands = split /\W+/, do{local $/; <$commands>};
- say "Loading commands from: @commands";
- $disp->load(@commands);
- }
-
- my $channels = new IO::File 'channels';
- while (<$channels>){
- my ($chan, @types) = split /\s+/;
- say "$chan - @types";
- if ($chan =~ /^(.*):(.*)$/){
- $chan = $1;
- $disp->set_target($2,$chan);
- }
- $disp->add_channel($chan,\@types);
- }
-
- $heap->{disp} = $disp;
-}
-
-sub sig_DIE {
- my( $kernel,$sig, $ex ) = @_[ KERNEL,ARG0, ARG1 ];
- say "DIED!!!!!!!!!!!!!!";
- # $sig is 'DIE'
- # $ex is the exception hash
- warn "$$: error in event: $ex->{error_str}";
- $kernel->sig_handled();
-
- # Send the signal to session that sent the original event.
- #if( $ex->{source_session} ne $_[SESSION] ) {
- #$kernel->signal( $ex->{source_session}, 'DIE', $sig, $ex );
- #}
-}
-
-sub signal_handler {
- my ($kernel, $signal_name, $heap) = @_[KERNEL, ARG0, HEAP];
- print "First session caught SIG$signal_name\n";
-
- given($signal_name){
- when ('INT') {
- exit unless $heap->{irc}->connected;
- $heap->{INT} = 1;
- $heap->{irc}->yield(quit => 'Bye!');
- $kernel->sig_handled();
- }
- }
- #$kernel->sig_handled();
-}
-
-sub irc_disconnected {
- my ($sender,$heap) = @_[SENDER,HEAP];
-
- exit if $heap->{INT};
-}
-
-sub irc_001 {
- my ($sender,$heap,$kernel) = @_[SENDER,HEAP,KERNEL];
-
- # Since this is an irc_* event, we can get the component's object by
- # accessing the heap of the sender. Then we register and connect to the
- # specified server.
- my $irc = $sender->get_heap();
-
- print "Connected to ", $irc->server_name(), "\n";
-
- $kernel->yield( 'auth' );
- $irc->yield( mode => $irc->nick_name, '+ix');
-
- # we join our channels
- $irc->yield( join => $_ ) for grep /^#/, keys %{$heap->{disp}->channels};
- return;
-}
-
-sub irc_invite {
- my ($sender, $heap, $who, $channel) = @_[SENDER, HEAP, ARG0 .. ARG1];
- my $irc = $sender->get_heap();
-
- $irc->yield( join => $_ ) for grep /^$channel$/i, keys %{$heap->{disp}->channels}
-}
-
-1;
#**************************************************************************
-# Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu> *
+# Copyright (C) 2009 by Michael Andreen <harvATruinDOTnu> *
# *
# 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 *
use warnings;
use feature ':5.10';
+use Moose;
+extends 'NDIRC::Bot';
+
use POE::Session;
use NDIRC::Misc;
use ND::DB;
#**************************************************************************
-# Copyright (C) 2006 by Michael Andreen <harvATruinDOTnu> *
+# Copyright (C) 2009 by Michael Andreen <harvATruinDOTnu> *
# *
# 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 *
use warnings;
use feature ':5.10';
+use Moose;
+extends 'NDIRC::Bot';
+
use POE::Session;
use NDIRC::Misc;
use ND::DB;
use feature ':5.10';
use POE qw(Component::IRC::Qnet::State);
-
-use NDIRC::CommonStates;
eval "require NDIRC::$ARGV[0]";
die $@ if $@;
$irc->service_bots(QBOT => 'P@cservice.netgamers.org');
+my $bot = eval "new NDIRC::$ARGV[0]";
+
POE::Session->create(
- package_states => [
- 'NDIRC::CommonStates' => [ qw(_default _start irc_001 sig_DIE sig_usr1 sig_usr2
- signal_handler irc_disconnected irc_invite auth) ],
- "NDIRC::$ARGV[0]" => [ qw(irc_public irc_msg refresh irc_join) ],
+ object_states => [
+ $bot => [ qw(_default _start irc_001 sig_DIE sig_usr1 sig_usr2
+ signal_handler irc_disconnected irc_invite auth
+ irc_public irc_msg refresh irc_join) ],
],
heap => { irc => $irc },
);