Я создал плагин, который заполняет таблицу в базе данных числами из настраиваемого поля.Функция подключается к действию save_post
и выполняет серию проверок, чтобы убедиться, что код запускается только при публикации нового сообщения, а не при установке на auto-draft
.Код работал нормально, пока я не решил установить MailOptin, который автоматически отправляет электронные письма через Mailchimp, когда публикуется новое сообщение.
По какой-то причине, когда он был установлен, он игнорировал условные операторы, установленные в функции my_save_post
, и дважды запустил функцию.Просматривая код MailOptin, я вижу, что у них работает собственная функция.
Есть ли способ убедиться, что у меня все еще работают условные проверки?Я попытался изменить приоритет в моем плагине, чтобы функция вызывалась раньше, но это не сработало.
Почтовый индекс:
public function new_publish_post($new_status, $old_status, $post)
{
if (defined('DOING_AJAX')) return;
// hopefully this will cause all custom field to be updated before new post is triggered.
do_action('save_post', $post->ID, $post, true);
if (get_post_meta($post->ID, '_mo_disable_npp', true) == 'yes') return;
if ($new_status == 'publish' && $old_status != 'publish') {
$new_publish_post_campaigns = ER::get_by_email_campaign_type(ER::NEW_PUBLISH_POST);
foreach ($new_publish_post_campaigns as $npp_campaign) {
$email_campaign_id = absint($npp_campaign['id']);
if (ER::is_campaign_active($email_campaign_id) === false) continue;
$custom_post_type = ER::get_merged_customizer_value($email_campaign_id, 'custom_post_type');
$post_type_support = ['post'];
if ($custom_post_type != 'post') {
$post_type_support = [$custom_post_type];
}
$post_type_support = apply_filters('mo_new_publish_post_post_types_support', $post_type_support, $email_campaign_id);
if ( ! in_array($post->post_type, $post_type_support)) continue;
$custom_post_type_settings = ER::get_merged_customizer_value($email_campaign_id, 'custom_post_type_settings');
if ($custom_post_type != 'post' && ! empty($custom_post_type_settings)) {
$custom_post_type_settings = json_decode($custom_post_type_settings, true);
if (is_array($custom_post_type_settings)) {
foreach ($custom_post_type_settings as $taxonomy => $npp_terms) {
if ( ! empty($npp_terms)) {
$npp_terms = array_map('absint', $npp_terms);
$post_terms = array_map('absint', wp_get_object_terms($post->ID, $taxonomy, ['fields' => 'ids']));
// do not check if $post_terms is empty because if no term is on the post, wp_get_object_terms return empty array
// so we can use the empty to check against if NPP requires certain term(s)
if (is_array($npp_terms) && ! empty($npp_terms)) {
$result = array_intersect($post_terms, $npp_terms);
if (empty($result)) continue 2;
}
}
}
}
} else {
$npp_categories = ER::get_merged_customizer_value($email_campaign_id, 'post_categories');
$npp_tags = ER::get_merged_customizer_value($email_campaign_id, 'post_tags');
$post_categories = wp_get_post_categories($post->ID, ['fields' => 'ids']);
$post_tags = wp_get_post_tags($post->ID, ['fields' => 'ids']);
// do not check if $post_categories is empty because if no category is on the post, wp_get_post_categories return empty array
// so we can use the empty to check against if NPP requires certain category(s)
if (is_array($npp_categories) && ! empty($npp_categories)) {
// use intersect to check if categories match.
$result = array_intersect($post_categories, $npp_categories);
if (empty($result)) continue;
}
if (is_array($npp_tags) && ! empty($npp_tags)) {
// use intersect to check if categories match.
$result = array_intersect($post_tags, $npp_tags);
if (empty($result)) continue;
}
}
$send_immediately_active = $this->send_immediately($email_campaign_id);
$email_subject = ER::get_merged_customizer_value($email_campaign_id, 'email_campaign_subject');
$content_html = (new Templatify($email_campaign_id, $post))->forge();
$campaign_id = $this->save_campaign_log(
$email_campaign_id,
self::format_campaign_subject($email_subject, $post),
$content_html
);
if ($send_immediately_active) {
$this->send_campaign($email_campaign_id, $campaign_id);
} else {
if ( ! $this->schedule_time($email_campaign_id)) continue;
// convert schedule time to timestamp.
$schedule_time_timestamp = strtotime($this->schedule_time($email_campaign_id));
$response = wp_schedule_single_event(
$schedule_time_timestamp,
'mailoptin_send_scheduled_email_campaign',
[$email_campaign_id, $campaign_id]
);
// wp_schedule_single_event() return false if event wasn't scheduled.
if (false !== $response) {
$this->update_campaign_status($campaign_id, 'queued', $schedule_time_timestamp);
}
}
}
}
}
Структура, которая у меня есть, выглядит примерно так:
add_action('save_post', array($this, 'my_save_post'), 10, 3);
function my_save_post( $post_id, $post, $update ) {
// Autosave, do nothing
if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE )
return;
// AJAX? Not used here
if ( defined( 'DOING_AJAX' ) && DOING_AJAX )
return;
// Check user permissions
if ( ! current_user_can( 'edit_post', $post_id ) )
return;
// don't run the echo if the function is called for saving revision.
if ( $post->post_type == 'revision' )
return;
if($post->post_status == 'draft')
return;
}