tweet.pl 8.4 KB

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