3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-14 22:22:46 +01:00
pbot/modules/headlines.pl
Pragmatic Software 73b793295b todo! add support for admin management - needs support for adding/removing/saving!
todo! multi-channel support pathetic (note 12/08/09, fixed multi-channel for anti-flood and for ignore)
todo! most of this crap needs to be refactored (note 11/23/09, refactored execute_module)

0.4.1 (12/08/09): improved anti-flood system to be significantly more accurate and per-channel
                  added per-nick-per-channel message history using %flood_watch
                  add per-channel support to ignore system
                  automatically remove message history for nicks that haven't spoken in one day (run once per hour)
                  do not ignore !login command
0.3.16(11/23/09): refactored module execution to execute_module() subroutine
                  added trigger to execute get_title.pl module when URL is
                  detected in regular untriggered chat
0.3.15(11/20/09): replace 'me' with '$nick' in arguments
2009-12-09 01:08:12 +00:00

114 lines
2.6 KiB
Perl
Executable File

#!/usr/bin/perl -w -I /home/msmud/lib/lib/perl5/site_perl/5.10.0/
use XML::RSS;
use LWP::Simple;
# Note: Some of these may no longer exist.
# http://radio.xmlstoragesystem.com/rcsPublic/rssHotlist and many other
# similiar URLS (try Google?) may be useful.
my %news_sites = (
"jbad" => [ "http://jalalabad.us/backend/geeklog.rdf",
"Jalalabad.us"
],
"bbc" => [ "http://news.bbc.co.uk/rss/newsonline_uk_edition/world/rss091.xml",
"news.bbc.co.uk"
],
"cnn" => [ "http://www.cnn.com/cnn.rss",
"CNN News"
],
"chealth" => [ "http://www.cnn.com/health/health.rdf",
"CNN Health"
],
"ctech" => [ "http://www.cnn.com/technology/tech.rdf",
"CNN Technology"
],
"csports" => [ "http://www.cnn.com/sports/sports.rdf",
"CNN Sports"
],
"/." => [ "http://slashdot.org/slashdot.rdf",
"Slashdot"
],
"nyttech" => [ "http://xml.newsisfree.com/feeds/62/162.xml",
"New York Times Technology"
],
"morons" => [ "http://www.morons.org/morons.rss",
"morons.org"
]
);
my $args = join(' ', @ARGV);
my $links = 0;
my $key;
my $value;
if($args =~ /^links\s+(.*)/i) {
$args = $1;
$links = 1;
}
$args = quotemeta($args);
foreach $key (keys %news_sites) {
$value = $news_sites{$key}->[0];
if($key =~ /$args/i) {
check_news($value, $links, $news_sites{$key}->[1]);
exit(0);
}
}
print "Invalid Headline. Usage: .headlines [links] <news server> - News servers are: ";
foreach $key (keys %news_sites) {
print "$key => $news_sites{$key}->[1], ";
}
print "\n";
sub check_news {
my ($site, $links, $headline) = @_;
my $text = "$headline: ";
my $rss = new XML::RSS;
my $content = get($site);
if($content) {
eval {
$rss->parse($content);
};
if(my $error = $@) {
$error =~ s/\n//g;
print "Got error: $error\n";
return 0;
}
foreach my $item (@{$rss->{'items'}}) {
next unless defined($item->{'title'}) && defined($item->{'link'});
if($links == 1)
{
$text = " $item->{'title'} : ( $item->{'link'} )";
$text =~ s/\n//g;
$text =~ s/\t//g;
$text =~ s/\r//g;
print "$text\n";
}
else
{
$text .= " $item->{'title'} -";
}
}
}
$text =~ s/\n//g;
$text =~ s/\t//g;
$text =~ s/\r//g;
print "$text\n" if ($links == 0);
}