| 1 | # Movable Type (r) Open Source (C) 2001-2010 Six Apart, Ltd. |
|---|
| 2 | # This program is distributed under the terms of the |
|---|
| 3 | # GNU General Public License, version 2. |
|---|
| 4 | # |
|---|
| 5 | # $Id$ |
|---|
| 6 | |
|---|
| 7 | package MT::Summary::Triggers; |
|---|
| 8 | use strict; |
|---|
| 9 | use warnings; |
|---|
| 10 | |
|---|
| 11 | sub post_init_add_triggers { |
|---|
| 12 | # post_save triggers for summary expiration |
|---|
| 13 | my $summaries = MT->registry('summaries'); |
|---|
| 14 | my %class_triggers; |
|---|
| 15 | for my $class_type (keys %$summaries) { |
|---|
| 16 | next if ($class_type eq 'plugin'); |
|---|
| 17 | for my $summary_class (keys %{$summaries->{$class_type}}) { |
|---|
| 18 | next if ($summary_class eq 'plugin'); |
|---|
| 19 | my $expires = $summaries->{$class_type}->{$summary_class}->{expires}; |
|---|
| 20 | next unless $expires; |
|---|
| 21 | for my $class (keys %$expires) { |
|---|
| 22 | # check for required code handler for expiration code |
|---|
| 23 | # it's going to be used in triggers, but we check it here because |
|---|
| 24 | # errors in triggers are handled (swallowed) by MT code |
|---|
| 25 | my $code = $expires->{$class}->{code}; |
|---|
| 26 | my $id_col = $expires->{$class}->{id_column}; |
|---|
| 27 | $code = MT->handler_to_coderef($code) if ($code && !ref($code)); |
|---|
| 28 | die "Missing required handler for '$class_type: $summary_class: expires: $class' element with $id_col\n" unless ref $code; |
|---|
| 29 | |
|---|
| 30 | $class_triggers{$class} ||= []; |
|---|
| 31 | push(@{$class_triggers{$class}}, { |
|---|
| 32 | summary_class => $summary_class, |
|---|
| 33 | class_type => $class_type, |
|---|
| 34 | expires => $expires->{$class}, |
|---|
| 35 | }); |
|---|
| 36 | } |
|---|
| 37 | } |
|---|
| 38 | } |
|---|
| 39 | for my $class (keys %class_triggers) { |
|---|
| 40 | # load the class if it hasn't been loaded already |
|---|
| 41 | # ignore errors as the class may be already loaded as part of some other class (and not available as a standalone module) |
|---|
| 42 | # if load is not successful it's going to fail on add_trigger call anyway |
|---|
| 43 | eval "require $class"; |
|---|
| 44 | $class->add_trigger(pre_save => sub { |
|---|
| 45 | \&pre_save_trigger($class_triggers{$class}, @_); |
|---|
| 46 | }); |
|---|
| 47 | $class->add_trigger(post_save => sub { |
|---|
| 48 | \&post_trigger('save', $class_triggers{$class}, @_); |
|---|
| 49 | }); |
|---|
| 50 | $class->add_trigger(post_remove => sub { |
|---|
| 51 | \&post_trigger('remove', $class_triggers{$class}, @_); |
|---|
| 52 | }); |
|---|
| 53 | $class->add_callback('pre_remove_multi', 0, MT->component('core'), sub { |
|---|
| 54 | my ($cb, @args) = @_; |
|---|
| 55 | for my $obj ($class->load(@args)) { |
|---|
| 56 | post_trigger('remove', $class_triggers{$class}, $obj, $obj); |
|---|
| 57 | } |
|---|
| 58 | }); |
|---|
| 59 | } |
|---|
| 60 | } |
|---|
| 61 | |
|---|
| 62 | sub pre_save_trigger { |
|---|
| 63 | my ($triggers, $obj) = @_; |
|---|
| 64 | if (!$obj->id) { |
|---|
| 65 | $obj->{__summary_trigger_new} = 1; |
|---|
| 66 | } |
|---|
| 67 | } |
|---|
| 68 | |
|---|
| 69 | sub post_trigger { |
|---|
| 70 | my ($action, $triggers, $obj, $orig_obj) = @_; |
|---|
| 71 | for my $trigger (@$triggers) { |
|---|
| 72 | next unless $trigger->{expires}->{id_column}; |
|---|
| 73 | my $parent_class = MT->model($trigger->{class_type}); |
|---|
| 74 | die "Can't find a class for '", $trigger->{class_type}, "'" if ! defined $parent_class; |
|---|
| 75 | my $code = $trigger->{expires}->{code}; |
|---|
| 76 | my $id_col = $trigger->{expires}->{id_column}; |
|---|
| 77 | next unless $obj->$id_col; |
|---|
| 78 | $code = MT->handler_to_coderef($code) if ($code && !ref($code)); |
|---|
| 79 | die "Missing required handler for expires with ", $trigger->{class_type}, " and $id_col" unless ref $code; |
|---|
| 80 | my $parent_obj = $parent_class->load($obj->$id_col); |
|---|
| 81 | next unless $parent_obj; |
|---|
| 82 | eval { $code->($parent_obj, $obj, $trigger->{summary_class}, $action, $orig_obj); }; |
|---|
| 83 | } |
|---|
| 84 | delete $obj->{__summary_trigger_new}; |
|---|
| 85 | } |
|---|
| 86 | |
|---|
| 87 | 1; |
|---|