Why not adopt me?
NAME
Object::Annotate - mix in logging-to-database to objects
VERSION
$Id: /my/icg/annotate/trunk/lib/Object/Annotate.pm 18618 2006-02-11T12:38:11.249527Z rjbs $
version 0.01
SYNOPSIS
package Your::Class;
use Object::Annotate { dsn => '...', table => 'notes' };
...
my $object = Your::Class->new( ... );
$object->annotate({ event => "created", comment => "(as example)" });
DESCRIPTION
Object::Annotate is a mixin that provides any class with method for storing and retrieving notes about its objects. It can also produce objects which exist only to store annotations about abstract (uninstantiated) objects, procedures, or concepts.
USAGE
To mix Object::Annotate into a class, just use
it. To create a classless annotator object, use Object::Annotate's new
method. Both of these usages accept the same arguments:
db - options for the database in which notes are stored; a hashref:
dsn - the DSN to pass to Class::DBI to create a connection
user - the username to use in connecting to the database
pass - the password to use in connecting to the database
table - the table in which annotations are stored
sequence - if given, the Class::DBI table's primary key values comes from
this sequence; see L<Class::DBI> for more information
columns - columns for the annotation table
obj_class - the class name to use for annotations for this class
(defaults to Class->moniker, see UNIVERSAL::moniker)
id_attr - the object attribute to use for "id"; called as a method
if it's a scalar ref, it's de-ref'd and used as a constant string
new
You can use the new
method to create a singularity -- an object that can annotate as if it was of a class that used Object::Annotate, but is of its own unique class.
my $notepad = Object::Annotate->new({ db => { ... } });
METHODS
These methods are not provided by Object::Annotate, but are installed into classes that use Object::Annotate.
annotation_class
my $annotation_class = Your::Class->annotation_class;
This method returns the name of the automatically constructed class that handles annotations for the class or object on which it is installed.
annotate
$object->annotate({
event => 'update',
attr => 'priority',
old_val => 1,
new_val => 3,
});
This method creates an annotation for the object on which it is called.
search_annotations
# search all annotations for this class
my @notes = Class->search_annotations({ event => 'explosion' });
# searches only annotations for this object
my @notes = $object->search_annotations({ event => 'explosion' });
This method searches through the annotations for a class or an object, using the Class::DBI search
method.
INTERNALS
setup_class
Object::Annotate->setup_class($target, \%arg);
This method does the heavy lifting needed to turn the class named by $target
into one that does annotation.
class_for
my $class = Object::Annotate->class_for(\%arg);
This method returns the class to use for the described database and table, constructing it (see "construct_class"
) if needed.
Valid arguments are (for all, see the "USAGE" section): dsn, table, db_user, db_pass, sequence
See the "USAGE" section, above, for information on these arguments, which typically are passed along by the import routine.
default_dsn
default_table
default_user
default_pass
These methods return the default database settings to use if none is specified when importing Object::Annotate. The built-in behavior is to return the OBJ_ANNOTATE_DSN, OBJ_ANNOTATE_TABLE, etc. environment variables.
construct_cdbi_class
my $new_class = Object::Annotate->construct_cdbi_class(\%arg);
This method sets up a new Class::DBI subclass that will store in the database described by the arguments.
Valid arguments are:
dsn - the dsn for the database in which to store
user - the database user as whom to connect
pass - the database password
table - the table in which to store annotations
columns - the extra columns for the table
base_class - class from which the new class inherits (default: Class::DBI)
build_annotator
my $code = Object::Annotate->build_annotator(\%arg);
This builds the routine that will be installed as "annotate" in the importing class. It returns a coderef.
It takes the following arguments:
obj_class - the class name to use for this class's log entries
id_attr - the method to use to get object ids; if a scalar ref,
the dereferenced string is used as a constant
set_time - if true, the note_time value will be created as the current time
build_searcher
my $code = Object::Annotate->build_searcher(\%arg);
This builds the routine that will be installed as "search_annotations" in the importing class. It returns a coderef.
It takes the following arguments:
obj_class - the class name to use for this class's log entries
id_attr - the method to use to get object ids; if a scalar ref,
the dereferenced string is used as a constant