Commit | Line | Data |
c0e7b4e5 |
1 | package # hide from PAUSE |
2 | DBIx::Class::Relationship::CascadeActions; |
4a07648a |
3 | |
4 | sub delete { |
5 | my ($self, @rest) = @_; |
147dd158 |
6 | return $self->next::method(@rest) unless ref $self; |
4a07648a |
7 | # I'm just ignoring this for class deletes because hell, the db should |
8 | # be handling this anyway. Assuming we have joins we probably actually |
9 | # *could* do them, but I'd rather not. |
10 | |
147dd158 |
11 | my $ret = $self->next::method(@rest); |
4a07648a |
12 | |
71e65b39 |
13 | my $source = $self->result_source; |
14 | my %rels = map { $_ => $source->relationship_info($_) } $source->relationships; |
4a07648a |
15 | my @cascade = grep { $rels{$_}{attrs}{cascade_delete} } keys %rels; |
16 | foreach my $rel (@cascade) { |
503536d5 |
17 | $self->search_related($rel)->delete; |
4a07648a |
18 | } |
19 | return $ret; |
20 | } |
21 | |
22 | sub update { |
23 | my ($self, @rest) = @_; |
147dd158 |
24 | return $self->next::method(@rest) unless ref $self; |
4a07648a |
25 | # Because update cascades on a class *really* don't make sense! |
26 | |
147dd158 |
27 | my $ret = $self->next::method(@rest); |
4a07648a |
28 | |
71e65b39 |
29 | my $source = $self->result_source; |
30 | my %rels = map { $_ => $source->relationship_info($_) } $source->relationships; |
4a07648a |
31 | my @cascade = grep { $rels{$_}{attrs}{cascade_update} } keys %rels; |
32 | foreach my $rel (@cascade) { |
33 | $_->update for $self->$rel; |
34 | } |
35 | return $ret; |
36 | } |
37 | |
38 | 1; |