tweet.pl 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. # This script responds with a comment each time someone in the channel says "clockbot"
  2. #
  3. # This script requires you to have the text file "clockbot" in your /home/user/.irssi/ directory
  4. #
  5. # cat ~/signatures/sig-natures | sed 's/^%$/####/;'| tr '\n' ' ' | sed 's/[[:space:]]\+/ /g;s/[[:space:]]####[[:space:]]/\n/g;' > ../../clockbot
  6. use Irssi;
  7. use vars qw($VERSION %IRSSI);
  8. use POSIX qw(strftime);
  9. use LWP::UserAgent;
  10. $VERSION = "1.3.0";
  11. %IRSSI = (
  12. author => 'pleia2',
  13. contact => 'lyz@princessleia.com ',
  14. name => 'TC-14 Tweet',
  15. description => 'Protocol Droid, dedicated to Lautre.roots',
  16. license => 'GNU GPL v2 or later',
  17. url => 'http://www.lautre.net/',
  18. );
  19. open ( CLOCKPO, "<.irssi/quotes" ) or die "can't open clockbot:$!\n";
  20. chomp( @clockpo = <CLOCKPO> );
  21. close CLOCKPO;
  22. srand (time ^ $$ ^ unpack "%L*", `ps axww | gzip -f`);
  23. my $changefile="/home/tc-14/var/changelog";
  24. my $last_tweet="";
  25. my $debug=0;
  26. my $bingo=0;
  27. my $last='';
  28. my $warn='';
  29. my @dad=("asr", "asr`", "asr_", "asr\\", "asr`_");
  30. my $timeout=30;
  31. my $warndate=time()-$timeout;
  32. Irssi::settings_add_str($IRSSI{name}, # default fifo_remote_file
  33. 'tc_chans', '#flood #starwars'); #
  34. Irssi::settings_add_str($IRSSI{name}, # default fifo_remote_file
  35. 'tc_admins', 'asr coin plop'); #
  36. Irssi::settings_add_str($IRSSI{name}, # default fifo_remote_file
  37. 'tc_changefile', '/home/tc-14/var/last.log'); #
  38. Irssi::settings_add_str($IRSSI{name}, # default fifo_remote_file
  39. 'tc_tailgrep', '/home/tc-14/bin/tailgrep'); #
  40. my @chan=split m/ /, Irssi::settings_get_str("tc_chans");
  41. my @admin_chan=split m/ /, Irssi::settings_get_str("tc_admins");
  42. my $change=Irssi::settings_get_str("tc_changefile");
  43. sub in_array {
  44. my ($arr,$search_for) = @_;
  45. return grep {$search_for eq $_} @$arr;
  46. }
  47. sub gazouille {
  48. my ( $user, $pass ) = qw ( lautrenet OoD0aiph );
  49. my $message = $_[0];
  50. my $url = 'http://identi.ca/api/statuses/update.xml';
  51. my $ua = LWP::UserAgent->new ();
  52. my $req = HTTP::Request->new ( POST => $url );
  53. $req->headers->authorization_basic( $user, $pass );
  54. $req->content("status=$message");
  55. $req->content_type('application/x-www-form-urlencoded');
  56. my $res = $ua->request ($req);
  57. return $res->is_success;
  58. }
  59. sub event_privmsg {
  60. my ($server, $data, $nick, $mask) =@_;
  61. my ($target, $text) = $data =~ /^(\S*)\s:(.*)/;
  62. #print ( "C:$target X:$text A:$admin D:$warndate L:$last W:$warn N:$nick D:$data" );
  63. sub send_server($$$$) {
  64. my ($action,$cible,$pseudo,$msg)=@_;
  65. $server->command ( "msg $target SWarn C:$cible X:$action A:$admin D:$warndate L:$last W:$warn N:$pseudo T:$msg" ) unless ($debug == 0);
  66. if (in_array(@chan,$target) || in_array(@admin_chan,$pseudo))
  67. {
  68. return;
  69. } else {
  70. if (($warndate + $timeout) < time()) {
  71. $warn='';
  72. $last='';
  73. }
  74. if (!($warn eq $pseudo)) {
  75. if ($last eq $pseudo) {
  76. $server->command ( "msg $cible $pseudo: Chut.");
  77. $warn=$nick;
  78. } else {
  79. $server->command ( "$action $cible $msg" );
  80. $last=$nick;
  81. }
  82. } else {
  83. $server->command ( "msg $cible $pseudo bloque pour $timeout" ) unless $debug=0;
  84. }
  85. $warndate=time();
  86. }
  87. }
  88. my $admin=0;
  89. if (in_array(@chan,$target) || in_array(@admin_chan,$target))
  90. {
  91. return;
  92. }
  93. foreach $father (@dad) {
  94. if ($father eq $nick) {
  95. $admin=1;
  96. }
  97. }
  98. if ( $text =~ /^!tweet\s*(.*)/) {
  99. if (in_array(@admin_chan, $target)) { return ; }
  100. if ($1 eq '') { $server->command("msg $target $nick: Usage: !tweet <<message>>"); } #$server->command ( "msg $target $nick: !tweet <<mesage>>" ); }
  101. elsif ($1 eq 'changelog') {
  102. open ( CHANGL, "tail -n1 $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  103. #chomp( @temp = <CHANGL> );
  104. #foreach $line (@temp) {
  105. # $last_tweet=$line;
  106. # if (gazouille ($line)) {
  107. # $clocky = $clockpo[rand @clockpo];
  108. # $server->command("msg $target Gazouilli posté! $clocky") unless ($nick =~ /edgard/i);
  109. # }
  110. # else
  111. # {
  112. # $server->command ("msg $target $nick: Erreur lors du post du message");
  113. # }
  114. #}
  115. close ( CHANGL );
  116. }
  117. elsif ($1 eq 'last') {
  118. $server->command("msg $target $nick: Last tweet was:");
  119. $server->command("msg $target $nick: $last_tweet");
  120. }
  121. elsif (length($1)>139) { $server->command("msg $target $nick: Message trop long, plus de 139 caractères." ); }
  122. else {
  123. # $server->command("msg $target Message: $nick |$1|");
  124. $last_tweet=$1;
  125. if (gazouille ($1)) {
  126. $clocky = $clockpo[rand @clockpo];
  127. $server->command("msg $target Gazouilli posté! $clocky") unless ($nick =~ /edgard/i);
  128. }
  129. else
  130. {
  131. $server->command ("msg $target $nick: Erreur lors du post du message");
  132. }
  133. }
  134. }
  135. elsif ( $text =~ /^!changelog( .+)?/ ) {
  136. if (in_array(@admin_chan,$target))
  137. { return; }
  138. if ($1 eq '') { $server->command ( "msg $target $nick: !changelog (list|add) [<serveur> [<liste d'actions>]]" );
  139. } elsif ($1 =~ /^ last( .+)?/) {
  140. open ( CHANGL, "tail -n1 $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  141. chomp( @temp = <CHANGL> );
  142. foreach $line (@temp) {
  143. $server->command ( "msg $target $nick: $line" );
  144. }
  145. close ( CHANGL );
  146. } elsif ($1 =~ /^ list( .+)?/) {
  147. undef @temp;
  148. if ($1 eq '') {
  149. $server->command ( "msg $target $nick: changelog total (20 lignes) en pv." );
  150. open ( CHANGL, "tail $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  151. } else {
  152. my $pattern = $1;
  153. $pattern =~ s/^ //;
  154. $pattern =~ s/['"\$]/_/g;
  155. $server->command ( "msg $target $nick: changelog pour '$pattern' (20 lignes) en pv" );
  156. open ( CHANGL, "/home/tc-14/bin/tailgrep $changefile '$pattern' |" ) or $server->command ( "msg $target $nick: erreur de pattern ou fichier vide" );
  157. }
  158. chomp( @temp = <CHANGL> );
  159. close CHANGL;
  160. foreach $line (@temp) {
  161. $server->command ( "msg $nick $line" );
  162. }
  163. } elsif ($1 =~ /^ add ([^ ]+) (.+)/) {
  164. my $locdate=strftime "%d/%m/%Y %H:%M", localtime;;
  165. open ( CHANGL, ">> $changefile" ) or $server->command ( "msg $target $nick: erreur de fichier... (O)" );
  166. printf CHANGL "%s", "$locdate : $1 - $nick - $2\n" or $server->command ( "msg $target $nick: erreur de fichier... (W)" );
  167. close CHANGL or $server->command ( "msg $target $nick: erreur de fichier... (C)" );
  168. $clocky = $clockpo[rand @clockpo];
  169. send_server("msg", $target, $nick, $clocky) unless ($nick =~ /edgard/i);
  170. } else {
  171. $server->command ( "msg $target $nick: !changelog (list|add|last) [<serveur> [<liste d'actions>]]" );
  172. }
  173. }
  174. elsif ( $text =~ /^!lastlog( .+)?/ ) {
  175. if (in_array(@admin_chan,$target))
  176. { return; }
  177. if ($1 eq '') { $server->command ( "msg $target $nick: !lastlog list [<liste d'actions>]" );
  178. } elsif ($1 =~ /^ list( .+)?/) {
  179. undef @temp;
  180. if ($1 eq '') {
  181. $server->command ( "msg $target $nick: lastlog total (20 lignes) en pv." );
  182. open ( CHANGL, "tail $logfile |" ) or $server->command ( "msg $nick fichier vide" );
  183. } else {
  184. my $pattern = $1;
  185. $pattern =~ s/^ //;
  186. $pattern =~ s/['"\$]/_/g;
  187. $server->command ( "msg $target $nick: lastlog pour '$pattern' (20 lignes) en pv." );
  188. open ( CHANGL, "/home/tc-14/bin/tailgrep $logfile '$pattern' |" ) or $server->command ( "msg $target $nick: erreur de pattern ou fichier vide" );
  189. }
  190. chomp( @temp = <CHANGL> );
  191. close CHANGL;
  192. foreach $line (@temp) {
  193. $server->command ( "msg $nick $line" );
  194. }
  195. } else { $server->command ( "msg $target $nick: !lastlog list [<liste d'actions>]" );
  196. }
  197. }
  198. if ($debug == 1) {
  199. $server->command ( "msg $target D1 A:$admin L:$last W:$warn N:$nick B:$bingo" );
  200. my $locdate=time()-$warndate;
  201. $server->command ( "msg $target D2 W:$warndate T1:".time." T2:$locdate" );
  202. }
  203. }
  204. Irssi::signal_add('event privmsg', 'event_privmsg');
  205. Irssi::signal_add("message public", "event_privmsg");
  206. print $IRSSI{"name"}." loaded $VERSION.";