--- trunk/bin/irc-logger.pl 2008/02/07 17:09:54 76 +++ trunk/bin/irc-logger.pl 2008/02/07 17:48:51 77 @@ -973,7 +973,10 @@ my $search = $q->param('search') || $q->param('grep') || ''; - if ($request->url =~ m#/rss#i) { + if ($request->url =~ m#/rss(?:/(tags)(?:=(\d+))?)#i) { + my $show = lc($1); + my $arg = $2 || 50; + my $type = 'RSS'; # Atom $response->content_type( 'application/' . lc($type) . '+xml' ); @@ -983,30 +986,51 @@ my $feed = XML::Feed->new( $type ); - $feed->title( "last $last_x_tags from $CHANNEL" ); - $feed->link( $url ); - $feed->description( "collects messages which have tags// in them" ); - - foreach my $m ( @last_tags ) { -# warn dump( $m ); - #my $tags = join(' ', @{$m->{tags}} ); + if ( $show eq 'tags' ) { + $feed->title( "tags from $CHANNEL" ); + $feed->link( "$url/tags" ); + $feed->description( "tag cloud created from messages on channel $CHANNEL which have tags// in them" ); my $feed_entry = XML::Feed::Entry->new($type); - $feed_entry->title( $m->{nick} . '@' . $m->{time} ); - $feed_entry->author( $m->{nick} ); - $feed_entry->link( '/#' . $m->{id} ); - $feed_entry->issued( DateTime::Format::Flexible->build( $m->{time} ) ); - - my $message = $filter->{message}->( $m->{message} ); - $message .= "
\n" unless $message =~ m!<(/p|br/?)>!; - warn "## message = $message\n"; - from_to( $message, $ENCODING, 'UTF-8' ); + $feed_entry->title( "$arg tags from $CHANNEL" ); + $feed_entry->author( $NICK ); + $feed_entry->link( '/#tags' ); - #$feed_entry->summary( $feed_entry->content( - "" + qq{} + . $cloud->css + . qq{} + . $cloud->html( $arg ) + . qq{]]>} ); - $feed_entry->category( join(', ', @{$m->{tags}}) ); $feed->add_entry( $feed_entry ); + + } else { + + $feed->title( "last $last_x_tags from $CHANNEL" ); + $feed->link( $url ); + $feed->description( "collects messages which have tags// in them" ); + + foreach my $m ( @last_tags ) { +# warn dump( $m ); + #my $tags = join(' ', @{$m->{tags}} ); + my $feed_entry = XML::Feed::Entry->new($type); + $feed_entry->title( $m->{nick} . '@' . $m->{time} ); + $feed_entry->author( $m->{nick} ); + $feed_entry->link( '/#' . $m->{id} ); + $feed_entry->issued( DateTime::Format::Flexible->build( $m->{time} ) ); + + my $message = $filter->{message}->( $m->{message} ); + $message .= "
\n" unless $message =~ m!<(/p|br/?)>!; + warn "## message = $message\n"; + from_to( $message, $ENCODING, 'UTF-8' ); + + #$feed_entry->summary( + $feed_entry->content( + "" + ); + $feed_entry->category( join(', ', @{$m->{tags}}) ); + $feed->add_entry( $feed_entry ); + } } $response->content( $feed->as_xml ); @@ -1020,17 +1044,17 @@ $response->content_type("text/html; charset=$ENCODING"); my $html = - qq{$NICK} . - qq{ + qq{$NICK} + . qq{ - } . - $cloud->html(500) . - qq{

}; + } + . $cloud->html(500) + . qq{

}; if ($request->url =~ m#/tags?#) { # nop