The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Catalyst::Model::EVDB - EVDB model class for Catalyst

SYNOPSIS

    # Use the Catalyst helper
    script/myapp_create.pl model EVDB EVDB xxxxxxxxxxxxxxxx

    # lib/MyApp/Model/EVDB.pm
    package MyApp::Model::EVDB;

    use base qw/Catalyst::Model::EVDB/;

    __PACKAGE__->config(
        app_key => 'xxxxxxxxxxxxxxxx',
    );

    1;

    # In a controller action
    my %args = (
        location => 'Gainesville, FL',
        keywords => 'tag:music',
    );

    my $evdb    = $c->model('EVDB');
    my $results = $evdb->call('events/search', \%args)
        or die 'Error searching for events: ' . $evdb->errstr;

DESCRIPTION

This is the EVDB::API model class for Catalyst. EVDB::API is a Perl interface to EVDB, the Events and Venues Database.

Please note that EVDB API methods require an application key.

For more information on EVDB, or to obtain an application key, see http://api.evdb.com/.

METHODS

new

Create a new EVDB model component, using app_key as specified in your configuration.

errstr

Return the EVDB API error message.

login

Login using the specified username and password. For example:

    # In a controller action (don't forget validation!)
    my $username = $c->req->param('username');
    my $password = $c->req->param('password');

    my $evdb = $c->model('EVDB');
    $evdb->login(username => $username, password => $password)
        or die 'Error logging in: ' . $evdb->errstr;

Alternatively, you can set a username and password in the configuration for your model class. They will be used when this method is called without arguments. For example:

    # In your model class
    __PACKAGE__->config(
        app_key  => 'xxxxxxxxxxxxxxxx',
        username => 'danieltwc',
        password => 'secret',
    );

    # In a controller action
    my $evdb = $c->model('EVDB');
    $evdb->login or die 'Error logging in: ' . $evdb->errstr;

    # Call an EVDB method which requires authentication
    my %args = (
        title      => 'Lamb',
        start_time => '2006-03-18T21:00:00',
        tags       => 'music',
        venue_id   => 'V0-001-000160549-4',
    );

    my $response = $evdb->call('events/new', \%args);

This method also supports passwords which have already been hashed using MD5. Use the password_md5 key instead of password when calling the method or in your configuration.

SEE ALSO

AUTHOR

Daniel Westermann-Clark <danieltwc@cpan.org>

ACKNOWLEDGMENTS

  • Brian Cassidy, for clever new code

LICENSE

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