diff options
-rw-r--r-- | bot.pl | 49 |
1 files changed, 42 insertions, 7 deletions
@@ -21,6 +21,7 @@ POE::Session->new ( _start => \&irc_start, | |||
21 | irc_376 => \&irc_connect, #end of motd | 21 | irc_376 => \&irc_connect, #end of motd |
22 | irc_372 => \&irc_motd, | 22 | irc_372 => \&irc_motd, |
23 | irc_353 => \&irc_names, | 23 | irc_353 => \&irc_names, |
24 | irc_311 => \&irc_whois, | ||
24 | irc_public => \&irc_pub_msg, | 25 | irc_public => \&irc_pub_msg, |
25 | irc_msg => \&irc_priv_msg, | 26 | irc_msg => \&irc_priv_msg, |
26 | ); | 27 | ); |
@@ -60,12 +61,18 @@ sub irc_motd { | |||
60 | } | 61 | } |
61 | 62 | ||
62 | sub irc_names { | 63 | sub irc_names { |
64 | my $kernel = $_[KERNEL]; | ||
63 | my $names = (split /:/, $_[ARG1])[1]; | 65 | my $names = (split /:/, $_[ARG1])[1]; |
64 | my $channel = (split /:/, $_[ARG1])[0]; | 66 | my $channel = (split /:/, $_[ARG1])[0]; |
65 | 67 | ||
66 | $channel =~ s/[@|=] (.*?) /$1/; | 68 | $channel =~ s/[@|=] (.*?) /$1/; |
67 | 69 | ||
68 | print "#-> Users on $channel [ $names ]\n"; | 70 | print "#-> Users on $channel [ $names ]\n"; |
71 | |||
72 | for my $user (split / /, $names) { | ||
73 | $user =~ s/^@|%|\+//; | ||
74 | $kernel->post( 'irc_client', 'whois', $user); | ||
75 | } | ||
69 | } | 76 | } |
70 | 77 | ||
71 | #nick change | 78 | #nick change |
@@ -73,6 +80,10 @@ sub irc_nick { | |||
73 | my $oldnick = (split /!/, $_[ARG0])[0]; | 80 | my $oldnick = (split /!/, $_[ARG0])[0]; |
74 | my $newnick = $_[ARG1]; | 81 | my $newnick = $_[ARG1]; |
75 | 82 | ||
83 | if( $newnick ne $current_nick ) { | ||
84 | $dbh->do( "UPDATE users SET nick = '$newnick' WHERE nick = '$oldnick'" ); | ||
85 | } | ||
86 | |||
76 | print "#-> $oldnick is now known as $newnick\n"; | 87 | print "#-> $oldnick is now known as $newnick\n"; |
77 | } | 88 | } |
78 | 89 | ||
@@ -89,12 +100,19 @@ sub irc_join { | |||
89 | my $kernel = $_[KERNEL]; | 100 | my $kernel = $_[KERNEL]; |
90 | my $nick = (split /!/, $_[ARG0])[0]; | 101 | my $nick = (split /!/, $_[ARG0])[0]; |
91 | my $channel = $_[ARG1]; | 102 | my $channel = $_[ARG1]; |
103 | my $host = (split /@/, $_[ARG0])[1]; | ||
92 | 104 | ||
93 | if( $nick eq $current_nick ) { | 105 | if( $nick eq $current_nick ) { |
94 | print "I JOIN JOIN JOIN\n"; | ||
95 | $kernel->post( 'irc_client', 'privmsg', $channel, 'Hier bin ich!'); | 106 | $kernel->post( 'irc_client', 'privmsg', $channel, 'Hier bin ich!'); |
107 | } else { | ||
108 | my ($cnt) = $dbh->selectrow_array( "SELECT COUNT(*) FROM users WHERE nick='$nick'" ); | ||
109 | if ( $cnt == 0 ) { | ||
110 | $dbh->do( "INSERT INTO users(id, nick, words, lines, lastlogin, lasthost) VALUES ( '$nick', '$nick', 0, 0, now(), '$host' )"); | ||
111 | } else { | ||
112 | $dbh->do( "UPDATE users SET lasthost = '$host', lastlogin = now() WHERE nick = '$nick'" ); | ||
113 | } | ||
96 | } | 114 | } |
97 | 115 | ||
98 | print "#-> $nick has joined $channel\n"; | 116 | print "#-> $nick has joined $channel\n"; |
99 | } | 117 | } |
100 | 118 | ||
@@ -107,10 +125,15 @@ sub irc_quit { | |||
107 | } | 125 | } |
108 | 126 | ||
109 | sub irc_pub_msg{ | 127 | sub irc_pub_msg{ |
110 | my $kernel = $_[KERNEL]; | 128 | my $kernel = $_[KERNEL]; |
111 | my $nick = (split /!/, $_[ARG0])[0]; | 129 | my $nick = (split /!/, $_[ARG0])[0]; |
112 | my $channel = $_[ARG1]->[0]; | 130 | my $channel = $_[ARG1]->[0]; |
113 | my $msg = $_[ARG2]; | 131 | my $msg = $_[ARG2]; |
132 | my $words = (split / /, $msg); | ||
133 | |||
134 | if( $nick ne $current_nick ) { | ||
135 | $dbh->do( "UPDATE users SET lines = lines + 1, words = words + $words WHERE nick = '$nick'" ); | ||
136 | } | ||
114 | 137 | ||
115 | print "$channel: <$nick> $msg\n"; | 138 | print "$channel: <$nick> $msg\n"; |
116 | } | 139 | } |
@@ -122,10 +145,22 @@ sub irc_priv_msg{ | |||
122 | 145 | ||
123 | $kernel->post( 'irc_client', 'privmsg', $nick, 'Ich dich auch!'); | 146 | $kernel->post( 'irc_client', 'privmsg', $nick, 'Ich dich auch!'); |
124 | 147 | ||
125 | $dbh->do( "INSERT INTO strings VALUES ('$nick', '$msg')" ); | ||
126 | |||
127 | print "PRIV: [$nick] $msg\n"; | 148 | print "PRIV: [$nick] $msg\n"; |
128 | } | 149 | } |
129 | 150 | ||
151 | sub irc_whois{ | ||
152 | my $nick = (split / /, $_[ARG1])[0]; | ||
153 | my $host = (split / /, $_[ARG1])[2]; | ||
154 | |||
155 | if( $nick ne $current_nick ) { | ||
156 | my ($cnt) = $dbh->selectrow_array( "SELECT COUNT(*) FROM users WHERE nick='$nick'" ); | ||
157 | if ( $cnt == 0 ) { | ||
158 | $dbh->do( "INSERT INTO users(id, nick, words, lines, lastlogin, lasthost) VALUES ( '', '$nick', 0, 0, now(), '$host' )"); | ||
159 | } else { | ||
160 | $dbh->do( "UPDATE users SET lasthost = '$host' WHERE nick = '$nick'" ); | ||
161 | } | ||
162 | } | ||
163 | } | ||
164 | |||
130 | #start everything | 165 | #start everything |
131 | $poe_kernel->run(); | 166 | $poe_kernel->run(); |