NAME DBIx::Class::Indexed - Index data via external indexing facilities. SYNOPSIS package Foo; use base qw( DBIx::Class ); __PACKAGE__->load_components( qw( Indexed Core ) ); __PACKAGE__->set_indexer( 'WebService::Lucene', { server => 'http://localhost:8080/lucene/', index => 'stuff', }); __PACKAGE__->add_columns( foo_id => { data_type => 'integer', is_auto_increment => 1, }, name => { data_type => 'varchar', size => 256, indexed => 1, }, description => { data_type => 'text', indexed => 1, }, ); ACCESSORS indexer_package( [ $indexer ] ) Sets which indexer will be responsible for indexing this class' data. Corresponds to the package name after the DBIx::Class::Indexer prefix. indexer_connection_info( [ \%info ] ) Sets the extra information passed to the indexer on instantiation. index_on_insert Determines whether or not DBIx::Class::Indexed will index the document when it is inserted. index_on_update Determines whether or not DBIx::Class::Indexed will index the document when it is updated. index_on_delete Determines whether or not DBIx::Class::Indexed will remove the document when it is deleted. METHODS indexer( ) Accessor for the indexer object; lazy loaded. set_indexer( $name [, \%connection_info ] ) Set the indexer information. Connection information is stored in the "indexer_connection_info" accessor and the package name is stored in "indexer_package". insert( ) Sends the object to the indexer's "insert" method, if "index_on_insert" is true. update( ) Sends the object to the indexer's "update" method, if "index_on_update" is true. delete( ) Sends the object to the indexer's "delete" method, if "index_on_delete" is true. register_column ( $column, \%info ) Overrides DBIx::Class's "register_column". If %info contains the key 'indexed', calls "register_field". add_index_fields ( @fields ) Behaves similarly to DBIx::Class's "add_columns". Calls "register_field" underneath. register_field( $field, \%info ) Registers a field as indexed. AUTHORS * Adam Paynter <adapay@cpan.org> * Brian Cassidy <bricas@cpan.org> COPYRIGHT AND LICENSE Copyright 2006 by Adam Paynter, 2007-2011 by Brian Cassidy This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.