blob: f67a77ca1561e6a1f1991fbfa7739ab399f57433 (
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
|
package Reaction::InterfaceModel::Action::DBIC::ResultSet::Create;
use Reaction::Types::DBIC;
use Reaction::Class;
use Reaction::InterfaceModel::Action;
use Reaction::InterfaceModel::Action::DBIC::Role::CheckUniques;
class Create is 'Reaction::InterfaceModel::Action', which {
does 'Reaction::InterfaceModel::Action::DBIC::Role::CheckUniques';
has '+target_model' => (isa => 'DBIx::Class::ResultSet');
implements do_apply => as {
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;
};
};
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
|