NAME
Ambrosia::DataProvider - a container for data sources. (Singleton)
VERSION
version 0.010
SYNOPSIS
use Ambrosia::DataProvider;
my $confDS = {
    DBI => [
        {
            engine_name   => 'DB::mysql',
            source_name  => 'Employee',
            engine_params => 'database=EmployeeDB;host=localhost;',
            user         => 'test',
            password     => 'test',
            additional_params => { AutoCommit => 0, RaiseError => 1, LongTruncOk => 1 },
            additional_action => sub { my $dbh = shift; $dbh->do('SET NAMES utf8')},
        },
        #........
    ],
    IO => [
        {
            engine_name => 'IO::CGI',
            source_name => 'cgi',
            engine_params => {
                header_params => {
                        '-Pragma' => 'no-cache',
                        '-Cache_Control' => 'no-cache, must-revalidate, no-store'
                    }
                }
        }
    ],
    
};
instance Ambrosia::Storage(application_name => $confDS);
Ambrosia::DataProvider::assign 'application_name';
DESCRIPTION
Ambrosia::DataProvider is a container for data sources. (Singleton)
For more information see:
- Ambrosia::DataProvider::DBIDriver
 - Ambrosia::DataProvider::IODriver
 - Ambrosia::DataProvider::ResourceDriver
 
SUBROUTINES/METHODS
instance
Static subrutine. Creates a singleton container.
instance('storage_name' => $config_data)
Structure of config data:
config = {
    DRIVER_TYPE => [
            engine_name   => 'ENGINE_FOR_DRIVER_TYPE',
            source_name  => 'UNIQ_NAME_FOR_SOURCE_DATA',
            engine_params => 'PARAMS_FOR_ENGINE',
            %ANY_ADDITIONAL_PARAMS_FOR_DRIVER_TYPE
    ]
}
assign
Static subrutine. Assigns a current process to a named data source from container. assign('storage_name')
storage
Static subrutine. Returns container assigned to current process. storage() storage('storage_name')
add_source
Method. Adds or changes a data source into container. storage()->add_source($config_data)
driver
Method. Returns a driver from container by driver type and source name. storage()->driver($driverType, $sourceName)
DIAGNOSTICS
CONFIGURATION AND ENVIRONMENT
DEPENDENCIES
Ambrosia::core::ClassFactory Ambrosia::Assert
THREADS
Not tested.
BUGS
Please report bugs relevant to Ambrosia to <knm[at]cpan.org>.
COPYRIGHT AND LICENSE
Copyright (C) 2010-2012 Nickolay Kuritsyn. All rights reserved.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
AUTHOR
Nikolay Kuritsyn (knm[at]cpan.org)