RIGHT:[[:t/プラグイン]]

MediaWikiのフックは本体を拡張する仕組み。でも目的に合うフックを探さないといけない。

本体を拡張するなら、ビルトインな機能もプラグインとして実装。プラグインの入れ替えで本体に手を加えられるようにする。パッチを当てるのもプラグインごとに。

特定のpublicメソッド(この仕組みに対応しているメソッド。API)の実行前後に、プラグイン内で定義されている"pre"、"post"付きメソッドを実行。(preで呼ばれたプラグインとは逆の順序でpostを持つプラグインを呼び出し)

- RenderDocument_Pre (プラグインAの)
- RenderDocument_Pre (プラグインBの)
- RenderDocument (本体の)
- RenderDocument_Post (プラグインBの)
- RenderDocument_Post (プラグインAの)

どのメソッドも同じインターフェイスで宣言。

これでも目的に合うAPIを探さないといけない。実行順序をドキュメントにしておくか、どんなユースケースであっても呼び出されたAPIをログやビュー上に出力できるように。それを読んでAPI探し。出力には引数名も載せて何をしているか分かりやすく。PerlのSmart::Commentsのようなことができれば理想的。

つまり、どのpublicメソッドもフックをかけられるようにするということ。

[[→:WebHook]]

アスペクト指向のように。




*** プラグインのフック [#m8e10d82]
プラグインが独自にフックを実装するのもあり。でもそれはプラグインにできることしか提供できない。