NAME

AxKit::App::TABOO::Data::Story - Story Data object for TABOO

SYNOPSIS

use AxKit::App::TABOO::Data::Story;
$story = AxKit::App::TABOO::Data::Story->new();
$story->load('*', $sectionid, $storyname);
$story->adduserinfo();
$story->addcatinfo();
$timestamp = $story->timestamp();
$lasttimestamp = $story->lasttimestamp();

DESCRIPTION

This Data class contains a story, as posted by the editors of a site.

METHODS

This class implements several methods, reimplements the load method, but inherits some from AxKit::App::TABOO::Data.

new()

The constructor. Nothing special.

load($what, $section, $storyname)

This class reimplements the load method, to accomodate for the possibility that one may not want to load all the data, one may for example only want to load the title and when it was posted. The load method now takes three arguments:

  • The first is a comma-separated list of fields from the data storage, see "STORED DATA" for details and available values. For all fields, use '*'.

  • The second parameter is a word identifying a section which the story has been posted to. Typically, this string will be taken directly from the URI. The use of sections makes it possible to devide the site in different ways. It is not intended that sections will coincide with categories, rather one can have sections with "small news", i.e. blatant rip-offs of other news sites with a few comments added, or longer articles with more unique content.

  • The third parameter is a unique identifier for the story. This too will typically be derived from the URI directly.

adduserinfo()

When data has been loaded into an object of this class, it will contain a string only identifying a user. This method will replace those strings (for the user posting the article, and for the submitter who sent the article to the site) with a reference to a AxKit::App::TABOO::Data::User-object, and that object's load_name method will be called. After this has been done, the story will effectively have all the user information it needs.

addcatinfo()

Similarly to adding user info, this method will also add category information, for different types of categories, again by creating a reference to a AxKit::App::TABOO::Data::Category-object and calling its load-method with the string from the data loaded by the story as argument.

timestamp([($section, $storyname)])

The timestamp method will retrieve the timestamp of the story. If the timestamp has been loaded earlier from the data storage (for example by the load method), you need not supply any arguments. If the timestamp is not available, you must supply the section and storyname identifiers, the method will then load it into the data structure first.

The timestamp method will return a Time::Piece object with the requested time information.

lasttimestamp([($section, $storyname)])

This does exactly the same as the timestamp method, but instead returns the lasttimestamp, which is intended to show when anything connected to the story (which may include comments) last changed.

It may require arguments like the timestamp method does, and it will return a Time::Piece object.

STORED DATA

The data is stored in named fields, and for certain uses, it is good to know them. If you want to subclass this class, you might want to use the same names, see the documentation of AxKit::APP::TABOO::Data for more about this.

In this class it gets even more interesting, because you may pass a list of those to the load method. This is useful if you don't want to load all data, in those cases where you don't need all the data that the object can hold.

These are the names of the stored data of this class:

  • storyname - an identifier for the story, a simple word you use to retrieve the desired object.

  • sectionid - an identifier for the section, also a simple word you use to retrieve the desired object.

  • image - the URL of an image that you want to associate with the story.

  • primcat - the primary category. You want to classify the story into one primary category.

  • seccat - the secondary categories. May be an array, so you can classify the story into any number of categories. This may be useful when you try to find relevant articles but searching along different paths.

  • freesubject - free categories. The primary categories are intended to be controlled vocabularies, whereas free subjects can be used and created more ad hoc. Also an array, you can have any number of such categories.

  • editorok - a boolean variable indicated if an editor has approved the story for publishing.

  • title - the main title of the story.

  • minicontent - Intended to be used as a summary or introduction to a story. Typically, the minicontent will be shown on a front page, where a visitor clicks happily along to read the full story.

  • content - the full story text.

  • username - the username of the user who actually does the posting of hte story. Would usually be an editor.

  • submitterid - the username of the user who submitted the article to the site for review and posting.

  • linktext - "Read More" makes a bad link text. Link texts should be meaningful when read out of context, and this should contain such a text.

  • timestamp - typically the time when the story was posted. See also the timestamp() method.

  • lasttimestamp - typically the time when something attached to the story was last changed, for example when a comment was last submitted. See also the lasttimestamp() method.

XML representation

The write_xml() method, implemented in the parent class, can be used to create an XML representation of the data in the object. The above names will be used as element names. The xmlelement() and xmlns() methods can be used to set the name of the root element and the namespace respectively. Usually, it doesn't make sense to change the defaults, which are

  • story

  • http://www.kjetil.kjernsmo.net/software/TABOO/NS/Story/Output

BUGS/TODO

Besides that it is a pre-alpha, there is a quirk in the load method. I use SQL3 arrays in the underlying database, but the database driver doesn't support this. So, there is a very hackish ad hoc implementation to parse the arrays in that method. It works for me, but not with all versions of DBD::Pg, notably 1.31, it'll segfault. 1.32 will fix the segfault, but probbably not add the needed support.

FORMALITIES

See AxKit::App::TABOO.