Manual:Hooks/ru



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

Хуки могут быть зарегистрированы путем сопоставления имени хука с обратным вызовом в файле расширения :

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

Назначьте функции хукам в конце или в вашем собственном файле расширения в области действия файла (не в функции  или хуке ). Для расширений, если поведение функции перехвата обусловлено параметром в LocalSettings.php, перехват должен быть назначен, и функция должна завершиться досрочно, если условие не было выполнено.

Вы также можете создавать новые хуки в своем собственном расширении. Он регистрируется в extension.json так же, как если бы вы регистрировали встроенный хук MediaWiki для использования в вашем расширении. Затем вы можете запустить свой хук в своем расширении, вызвав. Наконец, не забудьте добавить их к.

Введение
Перехват запускается вызовом, обычно с помощью метода в HookRunner. HookContainer найдет обработчики хуков для запуска и вызовет их с параметрами, заданными для. Обработчики крючков регистрируются через.

См. также.

В этом примере из функции  в, doPurge вызывает  для запуска хука , передавая   в качестве аргумента:

вызывает много хуков, но также может вызывать хуки.



Запись обработчика хуков
Обработчик хука — это функция, которую вы регистрируете, который будет вызываться всякий раз, когда запускается рассматриваемый хук.

Для расширений, зарегистрируйте свои обработчики хука в :

Обработчики хуков также могут быть зарегистрированы через глобальный массив. Это чаще всего используется для конкретных настроек сайта в или в устаревших расширениях, которые предшествуют. Все нижеприведенные допустимые способы определения обработчика перехвата для хука EventName, которому передаются два параметра:

Обратите внимание, что когда объект назначается, и вы не указываете метод, вызываемый метод - "onEventName". Например, "onArticleSave", "onUserLogin" и т.д.

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

Этот код приведет к тому, что  будет выполняться дважды при сохранении страницы: один раз для 'TimStarling' и один раз для 'brion'.



Возвращаемые значения обработчика хука
Обработчики хука могут возвращать одно из трех возможных значений:


 * (нет возвращаемого значения или ) — обработчик хука успешно сработал. (До MediaWiki 1.23 требовалось возвращать значение .)
 * "некоторая строка" — произошла ошибка; обработка должна быть остановлена, и ошибка должна быть показана пользователю
 * - обработчик хуков выполнил всю необходимую работу или заменил обычную обработку. Это предотвратит запуск дальнейших обработчиков и в некоторых случаях укажет вызывающей функции пропустить обычную обработку.

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



Обработка хуков в MediaWiki 1.35 и более поздних версиях
MediaWiki 1.35 introduces the HookHandlers system. Это включает в себя интерфейсы для каждого хука для улучшенной статической проверки и обнаружения документации по параметрам. It also enables dependency injection by introducing an intermediary class instance that accepts a number of specified services (instead of static callbacks that explicitly access services from global state).

The approach from MediaWiki 1.34 and earlier, of registering hook handlers directly as static methods, remains supported and is not deprecated. Extension authors may opt-in to the new system are welcome to do so. To learn more, see the MediaWiki core: Hook specification and the announcement on wikitech-l.



Изменения в названиях хуков
Prior to MediaWiki 1.35, hooks sometimes included characters that could not be used in a class or method name, such as colons and dashes. With the introduction of per-hook interfaces, the canonical names of these hooks have been changed to use underscores instead. For example, the interface for is. Hook handlers that are registered with the old names remain supported.

Registering hooks using HookHandlers
To adopt the new system, change your Hooks class to have regular methods instead of static methods and to be constructible. This class is then registered once, via the HookHandlers attribute in, using the  option as part of an  description where you can use the   option.

Например, чтобы зарегистрировать хук :



Обработка хуков с использованием интерфейсов
To use hook interfaces, extensions should define a Hooks class in their namespace and implement one or more hook interfaces. Hook interfaces are named with the hook name followed by the word "Hook".

Convert an extension to the new hook system
Follow these steps for each hook handling method:


 * identify the hook handler interface, and make the Hooks class implement this interface.
 * update the method name and signature to be exactly the same as in the interface.
 * change the Hooks section of to refer to the handler you specified in the HookHandlers section.

Процесс был продемонстрирован на :
 * Пример патча для расширения
 * Запись на YouTube



Поведение хуков до MediaWiki 1.22 по сравнению с после
Извлечено из: change 500542: для не прерываемых хуков (большинство хуков) возврат true был избыточным с MediaWiki 1.22 (в 2015 году). Это было сделано, чтобы уменьшить вероятность случайного сбоя, потому что мы столкнулись с несколькими сбоями и сбоями функций из-за тихих сбоев, когда, например, один обратный вызов где-то случайно возвращал значение, отличное от bool, или вместо /  и, таким образом, замыкал всю систему.

(Возврат значения, отличного от true/void в хук MediaWiki эквивалентен  и   в событиях JavaScript, он убивает других слушателей для того же события).

Например, если бы хук  возвращал false в MobileFrontend, это означало бы, что всплывающие окна останавливаются, потому что его обратный вызов больше не будет выполняться. См. различия ниже, предполагая, что хук.

До MediaWiki 1.22

или

MediaWiki 1.22+

Документация
В настоящее время хуки в ядре MediaWiki должны быть задокументированы как в [интерфейс хука https://doc.wikimedia.org/mediawiki-core/master/php/group__Hooks.html] (в репозитории исходного кода), так и в здесь на MediaWiki.org. В некоторых случаях один из этих шагов, возможно, еще не завершен, поэтому, если крючок кажется недокументированным, проверьте оба.

Каждый хук, предоставляемый ядром MediaWiki, определяется в интерфейсе хук. Как правило, интерфейсы хук расположены в подпространстве имен "Hook" внутри пространства имен вызывающего абонента. Например,. Вы можете найти список интерфейсов хуков в документации MediaWiki PHP [сгенерированной https://doc.wikimedia.org/mediawiki-core/master/php/group__Hooks.html].

Чтобы задокументировать хук в вики, используйте MediaWikiHook.

Шаблон документа интерфейса хука

В интерфейсах хуков комментарии doc определяют статус, назначение, параметры и поведение хука.



Доступные хуки


Хуки сгруппированные по функциям
Некоторые из этих хуков могут быть сгруппированы в несколько функций.
 * Разделы: Управление статьями - Редактировать страницу - Рендеринг страницы - Пользовательский интерфейс - Управление файлами - Специальные страницы - Управление пользователями - Регистрация - Шаблоны для скинов - API - Импорт/Экспорт - Различия - Разное



Алфавитный список крюков
Для получения полного списка хуков используйте, который следует поддерживать в актуальном состоянии.

Примечания


См. также

 * — спецификация системы хуков
 * Список интерфейсов хуков в ядре MediaWiki
 * — содержит примеры хуков
 * — JavaScript/интерфейсная система хуков
 * — спецификация системы хуков
 * Список интерфейсов хуков в ядре MediaWiki
 * — содержит примеры хуков
 * — JavaScript/интерфейсная система хуков