NAME

Apache::Voodoo::Table - framework to handle common database operations

VERSION

$Id: Table.pm 1451 2005-02-07 19:02:05Z medwards $

SYNOPSIS

FIXME
FIXME  Add the TONS of necessary documentation
FIXME

EXAMPLE CONFIGURATION

{
   table => 'table name',
   primary_key => 'column name' OR [ 'column', 'column2' ],
   primary_key_user_supplied => 0 | 1 (defaults to 0),
   primary_key_regexp => regular_expression (defaults to ^\d+$)
   columns => {
       name1 => {
           type => varchar, 
           length => +int or -1 for unlimited
           valid => 'email' |'url'| $code_ref

           --- Common to all data types ---
           regexp => regexp it must match.
           unique => 0|1 if (the column must be unique)
           required => 0|1
           references => {
               table       => 'name'
               primary_key => 'column'
               columns => 'column name' OR [ 'column1', 'column2', 'column3' ]
               select_label => column or sql concat(foo,bar,baz)
               select_default => primary_key value for default selected
               select_extra => 'order by foo or where stuff order by foo, etc.'
           }
       },
       name2 => {
           type => unsigned_int
           max  => maximum value
       },
       name3 => {
           type => signed_int
           max => maximum value
           min => minimum value
       },
       name4 => {
           type => (un)signed_decimal
           left => number of digits to left of decimal
           right => number of digits to right of decimal
       },
       name5 => {
           type => date,
           min => minimum date (optional) -- magic value: 'now' date must be >= today's date 
           max => maximum date (optional) -- magic value: 'now' date must be <= today's date
       },
       name6 => {
           type => time
       },
       name7 => {
           type => bit
       },
       name8 => {
           type => password (proposed magic type handling passwords, 
                             would assume varchar(32) not null as the column type
                             using Crypt::passwdMD5
                            )
       }
   },
   list_options => {
       default_sort => 'sort_name'
       sort => {
           'sort_name'  => [ column, column2, referenced_table.column, referenced_table.column2 ]
           'sort_name2' => [ column3, column4, referenced_table.column2 ]
       },
       search => [
           ['select list label','column'],
           ['select list label2','referenced_table.column']
       ]
   }
}

METHODS

success()

Returns 1 if the the last operation was "successful"

'add' resulted in a new row
'edit' resulted in an update to a row
'view' returned a row
'delete' 1 for 'no' on conformation; 2 for 'yes' and successful deletion
'list' returns 0 or more rows (no call errors)
'toggle' flipped a row
edit_details()

Returns details on the columns that we changed via edit. Useful for producing a detailed audit log.

Return structure looks like:

[
    [ 'column name','old value','new value' ]
]
add_insert_callback($subroutine_reference)

Adds a data validation routine to the add function

add_update_callback($subroutine_reference)

Adds a data validation routine to the edit function

add($p)

performs a database insertion

edit($p,$additional_where_clause_expression)

performs a database update

delete($p)

performs a delete from a table

list($p,$additional_where_clause_expression)

list all or part of the rows in a table

view($p,$additional_where_clause_expression)

Displays a particular row from the table

toggle($p,$column_name)

Toggles the column specified by the second parameter

AUTHOR

Maverick, /\/\averick@smurfbaneDOTorg

COPYRIGHT

Copyright (c) 2005 Steven Edwards. All rights reserved.

You may use and distribute Voodoo under the terms described in the LICENSE file include in this package or Apache::Voodoo::license. The summary is it's a legalese version of the Artistic License :)

1 POD Error

The following errors were encountered while parsing the POD:

Around line 156:

You forgot a '=back' before '=head1'