Как узнать, какие функции подключены к действию / фильтру?

32

Есть ли способ узнать, какие функции подключены к определенному крючку? Например, если я хотел бы знать, какие функции подключены к wp_headкрючку.

Хавьер Вильянуэва
источник
Я уверен, что это делает то, что вы хотите: @ Rarst's Debug WordPress hooks
ан
взгляните на этот ответ на похожий вопрос и, более конкретно, плагин, размещенный там Майком.
Bainternet
1
Я могу ошибаться, но разве это не приводит к полному списку хуков? То, как я читаю вопрос - он хочет знать, какие функции прикреплены к хуку.
ану
Отчасти неправильно, он сказал «например, что подключено к wp_head», так что это полный список, а не только один крючок.
Bainternet
Действительно, я хотел посмотреть, какие функции прикреплены к определенному хуку, поэтому, например, если к нему подключено 10 функций, wp_headя бы хотел перечислить эти 10.
Хавьер Вильянуэва

Ответы:

16

Посмотрите на глобальную переменную $wp_filter. Смотрите мой плагин для списка всех фильтров комментариев для примера:

<?php
/*
Plugin Name: List Comment Filters
Description: List all comment filters on wp_footer
Version:     1.1
Author:      Fuxia Scholz
License:     GPL v2
*/

add_action( 'wp_footer', 'list_comment_filters' );

function list_comment_filters()
{
    global $wp_filter;

    $comment_filters = array ();
    $h1  = '<h1>Current Comment Filters</h1>';
    $out = '';
    $toc = '<ul>';

    foreach ( $wp_filter as $key => $val )
    {
        if ( FALSE !== strpos( $key, 'comment' ) )
        {
            $comment_filters[$key][] = var_export( $val, TRUE );
        }
    }

    foreach ( $comment_filters as $name => $arr_vals )
    {
        $out .= "<h2 id=$name>$name</h2><pre>" . implode( "\n\n", $arr_vals ) . '</pre>';
        $toc .= "<li><a href='#$name'>$name</a></li>";
    }

    print "$h1$toc</ul>$out";
}

Пример вывода для pre_comment_author_email:

array (
  10 => 
  array (
    'trim' => 
    array (
      'function' => 'trim',
      'accepted_args' => 1,
    ),
    'sanitize_email' => 
    array (
      'function' => 'sanitize_email',
      'accepted_args' => 1,
    ),
    'wp_filter_kses' => 
    array (
      'function' => 'wp_filter_kses',
      'accepted_args' => 1,
    ),
  ),
)
Фуксия
источник
Отличная маленькая функция, спасибо, что поделились этим. Я использую его для оценки всех хуков действий, загруженных для темы при действии shutdown.
Кевин Лири
11

чтобы увидеть список функций или действий, привязанных к конкретной ловушке действий, вы можете использовать следующий код.

global $wp_filter;
echo '<pre>';
var_dump( $wp_filter['wp_head'] );
echo '</pre>';
Аамер Шахзад
источник
5

Для отладки простой

global $wp_filter;
echo "<pre>" . print_r($wp_filter, true) . "</pre>";

сделал бы это ...

Мартин из WP-Stars.com
источник
1
В моем случае, вызов var_dump($wp_filter)произвел слишком много продукции. Я предпочел использовать var_dump($wp_filter["<action name>"]). (То же самое касается print_r- я лично предпочел var_dump.)
Acsor
4

Это показывает более читаемый список фильтров

function print_filters_for( $hook = '' ) {
    global $wp_filter;
    if( empty( $hook ) || !isset( $wp_filter[$hook] ) ) return;

    $ret='';
    foreach($wp_filter[$hook] as $priority => $realhook){
        foreach($realhook as $hook_k => $hook_v){
            $hook_echo=(is_array($hook_v['function'])?get_class($hook_v['function'][0]).':'.$hook_v['function'][1]:$hook_v['function']);
            $ret.=  "\n$priority $hook_echo";
        }

    }
     return $ret;
}
Симона Г
источник
0

Я нашел ответ от @ user3623530 полезным, но он не учитывал тот факт, что иногда замыкания могут быть подключены. Вот моя более многословная (и уродливая) версия:

if( isset($wp_filter[$filterName]) ){
    foreach( $wp_filter[$filterName] as $priority => $hooks){
        foreach ($hooks as $hook_k => $hook_v) {
            $hook_echo=(is_array($hook_v['function'])?get_class($hook_v['function'][0]).':'.$hook_v['function'][1]:$hook_v['function']);
            if(is_object($hook_echo) && ($hook_echo instanceof Closure)){
                $hook_echo="closure";
            }
            error_log($filterName." HOOKED (".serialize($priority)."): ".serialize($hook_k)."".serialize($hook_echo));
        }
    }
} else {
    error_log($filterName." NO FILTERS HOOKED");
}
Derwent
источник