NAME

CGI::RSS - provides a CGI-like interface for making rss feeds

SYNOPSIS

use strict;
use CGI::RSS;

# NOTE: This doesn't work either way like CGI.pm, it's only OO...

my $rss = new CGI::RSS;

print $rss->header;
print $rss->begin_rss(title=>"My Feed!", link=>"http://localhost/directory");
while( my $h = $sth->fetchrow_hashref ) {
    print $rss->item(
        $rss->title       ( $h->{title} ),
        $rss->link        ( $h->{link}  ),
        $rss->description ( $h->{desc}  ),
        $rss->date        ( $h->{date}  ),
    );
}
print $rss->finish_rss;

TAGS

RSS TAGS

The following tags work anywhere. There is no enforcement for where they belong. They're just tag functions.

rss channel item title link description language copyright
managingEditor webMaster pubDate lastBuildDate category
generator docs cloud ttl image rating textInput skipHours
skipDays link description author category comments enclosure
guid pubDate source date url

MORE TAGS

RSS.pm tricks CGI.pm into thinking the above tags are are valid html tags. It does this at run time so you can add your own.

push @CGI::RSS::TAGS, "mytagname";

The construction of CGI.pm's _make_tag_func() rule's out namespaces (e.g., push @CGI::RSS::TAGS, "myns:mytag"), if you have any suggestions on how to handle this, please let me know.

I had considered writing a CGI::RSS::_make_tag_func() that converts the ':' to a '_' in the function name... That's harder than it sounds so I let it go for now.

TODO

I just wanted to get this thing working for now, but I'm not proud of the module. In the future, I'd like to actually follow a standard.

1. conform to standard(s) if possible
2. deal with xmlns somehow

AUTHOR

Paul Miller <jettero@cpan.org>

I am using this software in my own projects... If you find bugs, please please please let me know. :) Actually, let me know if you find it handy at all. Half the fun of releasing this stuff is knowing that people use it.

COPYRIGHT

Copyright (c) 2009 Paul Miller -- LGPL

SEE ALSO

CGI