tweet.pl 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  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. my @chan=split m/ /, Irssi::settings_get_str("tc_chans");
  39. my @admin_chan=split m/ /, Irssi::settings_get_str("tc_admins");
  40. my $change=Irssi::settings_get_str("tc_changefile");
  41. sub in_array {
  42. my ($arr,$search_for) = @_;
  43. return grep {$search_for eq $_} @$arr;
  44. }
  45. sub gazouille {
  46. my ( $user, $pass ) = qw ( lautrenet OoD0aiph );
  47. my $message = $_[0];
  48. my $url = 'http://identi.ca/api/statuses/update.xml';
  49. my $ua = LWP::UserAgent->new ();
  50. my $req = HTTP::Request->new ( POST => $url );
  51. $req->headers->authorization_basic( $user, $pass );
  52. $req->content("status=$message");
  53. $req->content_type('application/x-www-form-urlencoded');
  54. my $res = $ua->request ($req);
  55. return $res->is_success;
  56. }
  57. sub event_privmsg {
  58. my ($server, $data, $nick, $mask) =@_;
  59. my ($target, $text) = $data =~ /^(\S*)\s:(.*)/;
  60. #print ( "C:$target X:$text A:$admin D:$warndate L:$last W:$warn N:$nick D:$data" );
  61. sub send_server($$$$) {
  62. my ($action,$cible,$pseudo,$msg)=@_;
  63. $server->command ( "msg $target SWarn C:$cible X:$action A:$admin D:$warndate L:$last W:$warn N:$pseudo T:$msg" ) unless ($debug == 0);
  64. if (in_array(@chan,$target) || in_array(@admin_chan,$pseudo))
  65. {
  66. return;
  67. } else {
  68. if (($warndate + $timeout) < time()) {
  69. $warn='';
  70. $last='';
  71. }
  72. if (!($warn eq $pseudo)) {
  73. if ($last eq $pseudo) {
  74. $server->command ( "msg $cible $pseudo: Chut.");
  75. $warn=$nick;
  76. } else {
  77. $server->command ( "$action $cible $msg" );
  78. $last=$nick;
  79. }
  80. } else {
  81. $server->command ( "msg $cible $pseudo bloque pour $timeout" ) unless $debug=0;
  82. }
  83. $warndate=time();
  84. }
  85. }
  86. my $admin=0;
  87. if (in_array(@chan,$target) || in_array(@admin_chan,$target))
  88. {
  89. return;
  90. }
  91. foreach $father (@dad) {
  92. if ($father eq $nick) {
  93. $admin=1;
  94. }
  95. }
  96. if ( $text =~ /^!tweet\s*(.*)/) {
  97. if (in_array(@admin_chan, $target)) { return ; }
  98. if ($1 eq '') { $server->command("msg $target $nick: Usage: !tweet <<message>>"); } #$server->command ( "msg $target $nick: !tweet <<mesage>>" ); }
  99. elsif ($1 eq 'changelog') {
  100. open ( CHANGL, "tail -n1 $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  101. #chomp( @temp = <CHANGL> );
  102. #foreach $line (@temp) {
  103. # $last_tweet=$line;
  104. # if (gazouille ($line)) {
  105. # $clocky = $clockpo[rand @clockpo];
  106. # $server->command("msg $target Gazouilli posté! $clocky") unless ($nick =~ /edgard/i);
  107. # }
  108. # else
  109. # {
  110. # $server->command ("msg $target $nick: Erreur lors du post du message");
  111. # }
  112. #}
  113. close ( CHANGL );
  114. }
  115. elsif ($1 eq 'last') {
  116. $server->command("msg $target $nick: Last tweet was:");
  117. $server->command("msg $target $nick: $last_tweet");
  118. }
  119. elsif (length($1)>139) { $server->command("msg $target $nick: Message trop long, plus de 139 caractères." ); }
  120. else {
  121. # $server->command("msg $target Message: $nick |$1|");
  122. $last_tweet=$1;
  123. if (gazouille ($1)) {
  124. $clocky = $clockpo[rand @clockpo];
  125. $server->command("msg $target Gazouilli posté! $clocky") unless ($nick =~ /edgard/i);
  126. }
  127. else
  128. {
  129. $server->command ("msg $target $nick: Erreur lors du post du message");
  130. }
  131. }
  132. }
  133. elsif ( $text =~ /^!changelog( .+)?/ ) {
  134. if (in_array(@admin_chan,$target))
  135. { return; }
  136. if ($1 eq '') { $server->command ( "msg $target $nick: !changelog (list|add) [<serveur> [<liste d'actions>]]" );
  137. } elsif ($1 =~ /^ last( .+)?/) {
  138. open ( CHANGL, "tail -n1 $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  139. chomp( @temp = <CHANGL> );
  140. foreach $line (@temp) {
  141. $server->command ( "msg $target $nick: $line" );
  142. }
  143. close ( CHANGL );
  144. } elsif ($1 =~ /^ list( .+)?/) {
  145. undef @temp;
  146. if ($1 eq '') {
  147. $server->command ( "msg $target $nick: changelog total (20 lignes) en pv." );
  148. open ( CHANGL, "tail $changefile |" ) or $server->command ( "msg $target $nick: fichier vide" );
  149. } else {
  150. my $pattern = $1;
  151. $pattern =~ s/^ //;
  152. $pattern =~ s/['"\$]/_/g;
  153. $server->command ( "msg $target $nick: changelog pour '$pattern' (20 lignes) en pv" );
  154. open ( CHANGL, "/home/tc-14/bin/tailgrep $changefile '$pattern' |" ) or $server->command ( "msg $target $nick: erreur de pattern ou fichier vide" );
  155. }
  156. chomp( @temp = <CHANGL> );
  157. close CHANGL;
  158. foreach $line (@temp) {
  159. $server->command ( "msg $nick $line" );
  160. }
  161. } elsif ($1 =~ /^ add ([^ ]+) (.+)/) {
  162. my $locdate=strftime "%d/%m/%Y %H:%M", localtime;;
  163. open ( CHANGL, ">> $changefile" ) or $server->command ( "msg $target $nick: erreur de fichier... (O)" );
  164. printf CHANGL "%s", "$locdate : $1 - $nick - $2\n" or $server->command ( "msg $target $nick: erreur de fichier... (W)" );
  165. close CHANGL or $server->command ( "msg $target $nick: erreur de fichier... (C)" );
  166. $clocky = $clockpo[rand @clockpo];
  167. send_server("msg", $target, $nick, $clocky) unless ($nick =~ /edgard/i);
  168. } else {
  169. $server->command ( "msg $target $nick: !changelog (list|add|last) [<serveur> [<liste d'actions>]]" );
  170. }
  171. }
  172. elsif ( $text =~ /^!lastlog( .+)?/ ) {
  173. if (in_array(@admin_chan,$target))
  174. { return; }
  175. if ($1 eq '') { $server->command ( "msg $target $nick: !lastlog list [<liste d'actions>]" );
  176. } elsif ($1 =~ /^ list( .+)?/) {
  177. undef @temp;
  178. if ($1 eq '') {
  179. $server->command ( "msg $target $nick: lastlog total (20 lignes) en pv." );
  180. open ( CHANGL, "tail $logfile |" ) or $server->command ( "msg $nick fichier vide" );
  181. } else {
  182. my $pattern = $1;
  183. $pattern =~ s/^ //;
  184. $pattern =~ s/['"\$]/_/g;
  185. $server->command ( "msg $target $nick: lastlog pour '$pattern' (20 lignes) en pv." );
  186. open ( CHANGL, "/homet/tc-14/bin/tailgrep $logfile '$pattern' |" ) or $server->command ( "msg $target $nick: erreur de pattern ou fichier vide" );
  187. }
  188. chomp( @temp = <CHANGL> );
  189. close CHANGL;
  190. foreach $line (@temp) {
  191. $server->command ( "msg $nick $line" );
  192. }
  193. } else { $server->command ( "msg $target $nick: !lastlog list [<liste d'actions>]" );
  194. }
  195. }
  196. if ($debug == 1) {
  197. $server->command ( "msg $target D1 A:$admin L:$last W:$warn N:$nick B:$bingo" );
  198. my $locdate=time()-$warndate;
  199. $server->command ( "msg $target D2 W:$warndate T1:".time." T2:$locdate" );
  200. }
  201. }
  202. Irssi::signal_add('event privmsg', 'event_privmsg');
  203. Irssi::signal_add("message public", "event_privmsg");
  204. print $IRSSI{"name"}." loaded $VERSION.";