NAME

Eidolon::Driver::Router - Eidolon generic router driver.

SYNOPSIS

Example router driver:

package MyApp::Driver::Router;
use base qw/Eidolon::Driver::Router/;

sub find_handler
{
    my $self = shift;

    # ...

    throw DriverError::Router::NotFound unless $handler_found;
    
    $self->{"handler"} = ...;
    $self->{"params"}  = ...;
}

DESCRIPTION

The Eidolon::Driver::Router is a generic router driver for Eidolon. It declares some basic functions that are common for all driver types and one abstract method, that must be overloaded in ancestor classes. All router drivers should subclass this package.

METHODS

new()

Class constructor.

find_handler()

Finds a query handler. Abstract method, should be overloaded by the ancestor class.

get_handler()

Returns a reference to the query handler subroutine.

get_params()

Returns a reference to the array of query handler parameters.

ATTRIBUTES

The Eidolon::Driver::Router package has got several useful class attributes that filled in during request routing. These variables could be accessed through router object using hashref syntax:

my ($r, $router, $params);

$r      = Eidolon::Core::Registry->get_instance;
$router = $r->loader->get_object("Eidolon::Driver::Router");
$params = $router->{"params"};

controller

Contoller class name, that was selected for request handling.

handler

Handler code reference in selected controller.

params

Reference to array of handler parameters. Actually, these parameters will be passed to a request handler function, but they could be accessed this way too.

SEE ALSO

Eidolon, Eidolon::Application, Eidolon::Driver::Router::Exceptions

LICENSE

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

Anton Belousov, <abel@cpan.org>

COPYRIGHT

Copyright (c) 2009, Atma 7, http://www.atma7.com