blob: eaaafecc8847866ac70535dddfef006998a648ec (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
package Reaction::InterfaceModel::Action::DBIC::ResultSet::Create;
use Reaction::Types::DBIC 'ResultSet';
use Reaction::Class;
use Reaction::InterfaceModel::Action;
use Reaction::InterfaceModel::Action::DBIC::Role::CheckUniques;
use namespace::clean -except => [ qw(meta) ];
extends 'Reaction::InterfaceModel::Action';
with 'Reaction::InterfaceModel::Action::DBIC::Role::CheckUniques';
has '+target_model' => (isa => ResultSet);
sub do_apply {
my $self = shift;
my $args = $self->parameter_hashref;
my $new = $self->target_model->new({});
my @delay;
foreach my $name (keys %$args) {
my $tm_attr = $new->meta->find_attribute_by_name($name);
unless ($tm_attr) {
warn "Unable to find attr for ${name}";
next;
}
my $tm_writer = $tm_attr->get_write_method;
unless ($tm_writer) {
warn "Unable to find writer for ${name}";
next;
}
if ($tm_attr->type_constraint->name eq 'ArrayRef'
|| $tm_attr->type_constraint->is_subtype_of('ArrayRef')) {
push(@delay, [ $tm_writer, $args->{$name} ]);
} else {
$new->$tm_writer($args->{$name});
}
}
$new->insert;
foreach my $d (@delay) {
my ($meth, $val) = @$d;
$new->$meth($val);
}
return $new;
};
__PACKAGE__->meta->make_immutable;
1;
=head1 NAME
Reaction::InterfaceModel::Action::DBIC::ResultSet::Create
=head1 DESCRIPTION
=head2 target_model
=head2 error_for_attribute
=head2 sync_all
=head1 AUTHORS
See L<Reaction::Class> for authors.
=head1 LICENSE
See L<Reaction::Class> for the license.
=cut
|