package Catalyst::IOC::ConstructorInjection;
use Moose;
+use Catalyst::Utils ();
extends 'Bread::Board::ConstructorInjection';
-with 'Catalyst::IOC::Service::WithAcceptContext';
+with 'Bread::Board::Service::WithClass',
+ 'Bread::Board::Service::WithDependencies',
+ 'Catalyst::IOC::Service::WithParameters',
+ 'Catalyst::IOC::Service::WithCOMPONENT';
-sub _build_constructor_name { 'COMPONENT' }
+has config_key => (
+ is => 'ro',
+ isa => 'Str',
+ lazy_build => 1,
+);
+sub _build_config_key {
+ Catalyst::Utils::class2classsuffix( shift->class );
+}
+
+# FIXME - how much of this should move to ::WithCOMPONENT?
sub get {
my $self = shift;
my $constructor = $self->constructor_name;
- my $config = $self->param('config')->{ $self->params->{suffix} } || {};
- my $class = $self->param('class');
my $component = $self->class;
-
- unless ( $self->class->can( $constructor ) ) {
- # FIXME - make some deprecation warnings
- return $component;
- }
+ my $params = $self->params;
+ my $config = $params->{config}->{ $self->config_key } || {};
+ my $app_name = $params->{application_name};
# Stash catalyst_component_name in the config here, so that custom COMPONENT
# methods also pass it. local to avoid pointlessly shitting in config
# for the debug screen, as $component is already the key name.
- local $config->{catalyst_component_name} = $self->class;
-
- my $instance = eval { $component->$constructor( $class, $config ) };
-
- if ( my $error = $@ ) {
- chomp $error;
- Catalyst::Exception->throw(
- message => qq/Couldn't instantiate component "$component", "$error"/
- );
- }
- elsif (!blessed $instance) {
- my $metaclass = Moose::Util::find_meta($component);
- my $method_meta = $metaclass->find_method_by_name('COMPONENT');
- my $component_method_from = $method_meta->associated_metaclass->name;
- my $value = defined($instance) ? $instance : 'undef';
- Catalyst::Exception->throw(
- message =>
- qq/Couldn't instantiate component "$component", COMPONENT() method (from $component_method_from) didn't return an object-like value (value was $value)./
- );
- }
-
- return $instance;
+ local $config->{catalyst_component_name} = $component;
+
+ return $component->$constructor( $app_name, $config );
}
__PACKAGE__->meta->make_immutable;
=head1 NAME
-Catalyst::IOC::BlockInjection
+Catalyst::IOC::ConstructorInjection
+
+=head1 SYNOPSIS
+
+=head1 DESCRIPTION
=head1 AUTHORS