Maypole::Config->mk_accessors(qw(table_to_class));
-
-
-sub setup_database {
- my ( $self, $config, $namespace, $classes ) = @_;
- $config->{classes} = $classes;
- foreach my $class (@$classes) { $namespace->load_model_subclass(); }
- $namespace->model_classes_loaded(1);
- $config->{table_to_class} = { map { $_->table => $_ } @$classes };
- $config->{tables} = [ keys %{ $config->{table_to_class} } ];
-}
-
-sub class_of {
- my ( $self, $r, $table ) = @_;
- return $r->config->{table_to_class}->{$table};
-}
-
-
-
-
-1;
-
=head1 NAME
Maypole::Model::CDBI::Plain - Class::DBI model without ::Loader
Foo->config->model("Maypole::Model::CDBI::Plain");
Foo->setup([qw/ Foo::SomeTable Foo::Other::Table /]);
+ # untaint columns and provide custom actions for each class
+
+ Foo::SomeTable->untaint_columns(email => ['email'], printable => [qw/name description/]);
+
+ Foo::Other::Table->untaint_columns ( ... );
+
+ sub Foo::SomeTable::SomeAction : Exported {
+
+ . . .
+
+ }
+
=head1 DESCRIPTION
This module allows you to use Maypole with previously set-up
=head1 METHODS
-=over 4
+=head2 setup
-=item setup_database
+ This method is inherited from Maypole::Model::Base and calls setup_database,
+ which uses Class::DBI::Loader to create and load Class::DBI classes from
+ the given database schema.
-=item class_of
+=head2 setup_database
-=back
+ This method loads the model classes for the application
-See L<Maypole::Model::Base>
+=cut
+
+
+
+sub setup_database {
+ my ( $self, $config, $namespace, $classes ) = @_;
+ $config->{classes} = $classes;
+ foreach my $class (@$classes) { $namespace->load_model_subclass($class); }
+ $namespace->model_classes_loaded(1);
+ $config->{table_to_class} = { map { $_->table => $_ } @$classes };
+ $config->{tables} = [ keys %{ $config->{table_to_class} } ];
+}
+
+=head2 class_of
+
+ returns class for given table
=cut
+sub class_of {
+ my ( $self, $r, $table ) = @_;
+ return $r->config->{table_to_class}->{$table};
+}
+
+=head2 adopt
+
+This class method is passed the name of a model class that represensts a table
+and allows the master model class to do any set-up required.
+
+=cut
+
+sub adopt {
+ my ( $self, $child ) = @_;
+ if ( my $col = $child->stringify_column ) {
+ $child->columns( Stringify => $col );
+ }
+}
+
+=head1 SEE ALSO
+
+L<Maypole::Model::Base>
+
+L<Maypole::Model::CDBI>
+
+=cut
+
+
+1;
+
+