NAME Bryar - A modular, extensible weblog tool SYNOPSIS Bryar->go(); DESCRIPTION Bryar is a piece of blog production software, similar in style to (but considerably more complex than) Rael Dornfest's "blosxom". The main difference is extensibility, in terms of data collection and output formatting. For instance, data can be acquired via DBD from a database, or from the filesystem, or from any other source you can think of; documents can be specified in HTML, or some other format which gets turned into HTML; pages can be rendered with Template Toolkit, HTML::Template, or any other template engine of your choice. INSTALLING BRYAR The short answer: run bryar-newblog in a directory served by your web server. Then do what it tells you. The long answer: The only front-end working in this release is the CGI one; please don't try this in mod_perl yet. You'll need to write a little driver script which sets some parameters. For instance, my bryar.cgi looks like this: #!/usr/bin/perl use Bryar; Bryar->go( name => "Themes, Dreams and Crazy Schemes", description => "Simon Cozens' weblog", baseurl => "http://blog.simon-cozens.org/bryar.cgi" ); You can get away without any configuration options, but it's probably wise to set something like the above up. Bryar will look in its current directory for data files and templates, so if you're keeping your data somewhere else, you'll want to set the datadir option too: use Bryar; Bryar->go( datadir => "/home/simon/blog" ); If Bryar finds a file called bryar.conf in the data directory, (which as noted above, defaults to the current directory if not specified explicitly) then it'll parse that as a colon-separated file full of other options. I could, for instance, get away with name: Themes, Dreams and Crazy Schemes description: Simon Cozens' weblog baseurl: http://blog.simon-cozens.org/bryar.cgi email: something@example.com in a bryar.conf, and then would be able to use "Bryar->go()" with no further parameters. For details of interesting parameters, look in Bryar::Config. See also Bryar::DataSource::DBI for how to database-back the blog. Now you will need some templates to make your new blog look nice and shiny. You can copy in the template.rss and template.html which come with Bryar, and edit those. The bryar-newblog program which comes with Bryar will set all this up for you. Look at Bryar::Renderer::TT for hints as to how to customize the look-and-feel of the blog. Once you're all up and running, (and your web server knows about bryar.cgi) then you can start blogging! Just dump .txt files into your data directory. If you used bryar-newblog, you should even have a sample blog entry there for you. USING BRYAR This section describes Bryar from the end-users point of view - that is, what do all those URLs do? If you're familiar with blosxom, this section should be a breeze. http://your.blog.com/ will return the most recent 20 posts. The default of 20 can be changed by setting the "recent" configuration option. http://your.blog.com/something will try to find a sub-blog - in blosxom terms, this is a subdirectory underneath the main data directory. Sub-blogs can have their own templates, but by default inherit the templates from the main blog. (Oh, and another thing - you can stick templates either in the template subdirectory or the main directory for your blog/sub-blog. Bryar looks in both.) If you want your main blog to contain things from sub-blogs, you can change the value of the "depth" option, which defaults to one - no descent into subblogs. You can also export your blog as RSS: http://your.blog.com/bryar.cgi/xml And combine subblogging with RSS: http://your.blog.com/bryar.cgi/otherblog/xml These are actually blosxom backwardly-compatible versions of the Bryar: http://your.blog.com/bryar.cgi?format=xml There's also an Atom feed: http://your.blog.com/bryar.cgi?format=atom And you can write your own formats; see the renderer class documentation for how. Each blog post will have a unique ID; you can get to an individual post by specifying its ID: http://your.blog.com/bryar.cgi/id_1234 And finally you can retrieve blog entries for a specific period of time: http://your.blog.com/bryar.cgi/2003/May/ # All entries in May http://your.blog.com/bryar.cgi/2003/May/14/ # All entries on the 14th Of course, you can combine all these components: http://your.blog.com/bryar.cgi/otherblog/2003/May/xml METHODS Now for the programmer's interface to Bryar. new $self->new(%params) Creates a new Bryar instance. You probably don't need to use this unless you're programming your blog to do clever stuff. Use "go" instead. go $self->go() Bryar->go(%params) Does all the work of producing the blog. For parameters you might be interested in setting, see "Bryar::Config". posts_calendar TODO: Move this out to something that is more flexible. Return a data structure containing the days and weeks of a given month and year with blog posts attached. See the "calendar" template for an example. config Returns the Bryar::Config object for this blog. This is useful as the blog object is passed into the templates by default. LICENSE This module is free software, and may be distributed under the same terms as Perl itself. THANKS Steve Peters provided Atom support. Marco d'Itri contributed the calendar, HTTP validators, caching, FastCGI, sitemaps, non-ASCII charsets, bug fixes and optimizations. AUTHOR Copyright (C) 2003, Simon Cozens "simon@cpan.org" some parts Copyright 2007 David Cantrell "david@cantrell.org.uk" some parts Copyright 2009 Marco d'Itri "md@linux.it"