1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
2 <html xmlns="http://www.w3.org/1999/xhtml" lang="ja-JP" xml:lang="ja-JP">
4 <!-- $Id: plugins.html,v 1.7 2006-07-12 07:11:46 kimitake Exp $ -->
5 <!-- $NucleusJP: plugins.html,v 1.6.2.1 2005/09/09 07:34:26 kimitake Exp $ -->
6 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
7 <title>Nucleus - プラグイン API</title>
8 <link rel="stylesheet" type="text/css" href="styles/manual.css" />
9 <style type="text/css">
10 /* refence parameters (greenish) */
12 background-color: #afa;
16 /* object parameters */
24 /* read-only parameters (non-ref; reddish) */
26 background-color: #faa;
33 <p class="heading"> </p>
39 <div class="note-trans"><strong>訳者注:</strong>
41 <li>このドキュメントの原文は以下のURLにあります。<br />
42 <a href="http://nucleuscms.org/documentation/devdocs/plugins.html">http://nucleuscms.org/documentation/devdocs/plugins.html</a></li>
43 <li>誤訳にお気づきの方は<a href="http://japan.nucleuscms.org/bb/viewforum.php?f=7">こちら</a>へご連絡いただけると助かります。</li>
47 <div class="note"><strong>注:</strong>
49 <li>このドキュメントは基本的なプラグインの書き方についての情報を提供しています。さらに質問がある方は <a href="http://forum.nucleuscms.org/viewforum.php?f=10">Plugin
50 Development Forum</a> (<a href="http://japan.nucleuscms.org/bb/viewforum.php?f=5">日本語フォーラム</a>)をご覧ください。</li>
51 <li>Nucleusバージョン1.5以降に導入されたメソッドとイベントには、導入時のバージョン情報を付記しています。それらの機能を利用するときは、<code>getMinNucleusVersion</code> を適切に設定するのを忘れないでください。</li>
58 <a href="./index.html">開発者向けドキュメントの目次へ戻る</a>
62 このドキュメントはNucleusプラグインの作り方についての解説です。
65 <h1><a name="toc"></a><a name="top"></a>目次</h1>
68 <li><a href="#introduction">イントロダクション</a></li>
69 <li><a href="#firstplug">はじめてプラグインを書いてみる</a></li>
70 <li><a href="#nucleusplugin"><code>NucleusPlugin</code> クラスの概要</a></li>
71 <li><a href="#skinvars"><code><%plugin(...)%></code> スキン変数</a></li>
72 <li><a href="#templatevars"><code><%plugin(...)%></code> テンプレート変数</a></li>
73 <li><a href="#actions"><code>action.php</code> を使ったアクション</a></li>
74 <li><a href="#events">イベントとイベント登録の仕方</a></li>
75 <li><a href="#options">オプションを保存する</a></li>
76 <li><a href="#tables">データベース・テーブル</a></li>
77 <li><a href="#admin">プラグイン管理エリアの提供</a></li>
78 <li><a href="#help">ヘルプページの提供</a></li>
79 <li><a href="#dependency">プラグイン依存チェック</a></li>
80 <!-- <li><a href="#parser">Using the <code>PARSER</code> class</a></li>
81 <li><a href="#"></a></li>
82 <li><a href="#"></a></li>
83 <li><a href="#"></a></li>
84 <li><a href="#"></a></li>-->
87 <h1>イントロダクション <a name="introduction" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
90 Nucleusプラグインによって、誰もがNucleusの提供する機能を、Nucleus内部のPHPコードを変更することなく拡張することができます。プラグインはあるメソッドを実装したシンプルなPHPスクリプトで、Nucleusユーザー同士で簡単に交換することができます。インストールは簡単で、プラグインディレクトリにファイルをアップし、Nucleusにそれを認識させるだけです。
94 プラグインの利点は以下のとおりです。</p>
97 <li>実装について詳しくしらなくてもNucleusフレームワークに簡単に機能を追加できる</li>
98 <li>必要なプラグインだけをインストールでき、ページ生成にかかる時間を節約できる</li>
102 すべてのプラグインファイルは <code>config.php</code> に記述されたディレクトリに置く必要があります。一般的に、それは <code>/your/path/nucleus/plugins/</code> になるでしょう。プラグインファイル名は <code>NP<i>_name</i>.php</code> という形式を用いることにより認識されます。プラグインによっては、追加ファイルを格納する同名のサブディレクトリや、管理エリアを必要とします。</p>
105 <b>注:</b> プラグイン名は大文字・小文字を識別しますので、<code>Np_</code> や <code>np_</code> ではなく、<code>NP_</code> で始まることに気をつけてください。またプラグインがサブディレクトリを使用する場合は、サブディレクトリの名称は<em>すべて小文字にします</em>。</div>
110 <h1>はじめてプラグインを書いてみる<a name="firstplug" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
113 では、シンプルなプラグインを書いてみましょう。基本的にプラグインは、あらかじめ定義された <code>NucleusPlugin</code> クラスを継承したPHPクラスです。以下は<code>HelloWorld</code>プラグインの例です。</p>
115 <pre class="example"><code><?
117 class NP_HelloWorld extends NucleusPlugin
123 return 'Hello World';
129 return 'Wouter Demuynck';
133 // mailto:foo@bar.com の形式も可
136 return '../../index.html';
140 function getVersion()
145 // インストール済みのプラグインリストに表示される説明文
146 function getDescription()
148 return 'Just a sample plugin.';
151 function doSkinVar($skinType)
156 function supportsFeature ($what)
160 case 'SqlTablePrefix':
172 このコードをコピーし、 <code>NP_HelloWorld.php</code> と名づけて保存し、プラグインディレクトリに置きます。<em>最後の <code>?></code> の後や、最初の <code><?</code> の前にスペースがないことを確認しましょう</em>。ところでNP は "Nucleus Plugin" って意味ですよ :-) 念のため。
174 <li>Nucleusの管理画面を開き、<em>Nucleusの管理>プラグインの管理</em>にいきます。</li>
175 <li><em>HelloWorld</em> プラグインがインストール可能な状態になっているはずですので、インストールします。すべてがうまくいけば、インストール済みプラグインリストに追加されます。</li>
176 <li>あなたのスキンの1つを編集し、実際のページに表示する箇所に次の文を挿入します。
177 <pre class="example"><code><%HelloWorld%></code></pre>
178 注意:カッコ内の名称 (<code>HelloWorld</code>) は大文字小文字を識別します!</li>
179 <li>さて、編集したスキンから生成されるページを見てみましょう。プラグイン変数を追加した場所に "Hello
180 World" と見えますね?</li>
183 <p>ここまではそれほど難しくなかったと思います。さらに読み進めて理解してください。</p>
186 <h1>NucleusPlugin クラスの概要 <a name="nucleusplugin" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
188 <p>すべてのプラグインは、<code>NucleusPlugin</code> というPHPクラスを継承しなければなりません。難しそうに聞こえても心配ご無用、大丈夫です。このPHPクラスの継承によって、プラグインに必要なメソッドだけを実装でき、いくつかの補助ファンクションにアクセスでき、つまりはあなたの人生はよりラクになります。</p>
190 <p>下記は <code>NucleusPlugin</code> が提供する、再実装可能なメソッドの概要です。このクラス自身のソースコードを見たければ、<code>nucleus/libs/PLUGIN.php</code>にあります。</p>
192 <table summary="An overview of the redefinable methods in the class NucleusPlugin">
194 <code>NucleusPlugin</code> クラスの概要(再定義可能なメソッド)
197 <th>メソッド名</th><th>説明</th>
200 <td><code>getName()</code></td>
201 <td>プラグイン名を返します。インストール済みプラグインリストに表示されます。デフォルトの実装では <code>Undefined</code> を返すため、必ず再定義されないといけません。</td>
204 <td><code>getAuthor()</code></td>
205 <td>プラグインの作者名を返します。インストール済みプラグインリストに表示されます。デフォルトの実装では <code>Undefined</code> を返すため、必ず再定義されないといけません。</td>
208 <td><code>getURL()</code></td>
209 <td>プラグインをダウンロード可能な、またはプラグインの追加情報のあるサイトのURLを返します。そのようなサイトがない場合は作者のメールアドレスへの mailto:リンクが適切です。デフォルトの実装では <code>Undefined</code> を返すため、必ず再定義されないといけません。</td>
212 <td><code>getDescription()</code></td>
213 <td>プラグインに関する説明文(長文)を返します。インストール済みプラグインリストに表示されます。デフォルトの実装では <code>Undefined</code> を返します。</td>
216 <td><code>getVersion()</code></td>
217 <td>プラグインの現在のバージョンを返します。デフォルトは <code>0.0</code> を返します。</td>
220 <td><code>getMinNucleusVersion()</code></td>
221 <td>(v2.0b) 最低限必要なNucleusのバージョンを返します。デフォルトは <code>155</code> (v1.55)を返します。後に導入されたプラグイン関連機能を利用している場合は、このファンクションを実装するようお願いします(例: v2.0 => 200)。ただし、Nucleus v1.55 はこのファンクションを使用しないため、新機能を利用したプラグインが(対応する前のシステムに)インストールされる可能性が残っています。</td>
224 <td><code>getMinNucleusPatchLevel()</code></td>
225 <td>(v3.1) 最低限必要なNucleusのバージョン(<code>getMinNucleusVersion</code>)での、最低限必要なパッチレベルを返します。デフォルトは <code>0</code> を返します。このファンクションは主に新しいプラグインの機能がNucleusの最新版のパッチによって可能になる場合に用いられます。</td>
228 <td><code>init()</code></td>
229 <td>プラグインを初期化します。このメソッドはプラグインオブジェクトが生成された直後に呼び出され、<code>plugid</code>属性がセットされます。デフォルトではこのメソッドは何もしません。</td>
232 <td><code>doSkinVar($skinType)</code></td>
233 <td><code><%plugin(...)%></code> スキン変数によってプラグインが呼び出されたときにこのメソッドが呼ばれます。<code>$skinType</code> パラメータはプラグインが呼ばれた場所のスキンタイプに該当します(<code>item</code>,
234 <code>archive</code>, ...)。パラメータが一つしかないことに混乱しないでください。複数パラメータを渡すことも<strong>可能</strong>です。<a href="#skinvars"><code>doSkinVar</code> メソッドの実装に関する詳細情報はこちら</a>。デフォルトではこのメソッドはなにも出力しません。</td>
237 <td><code>doTemplateVar(&$item)</code></td>
238 <td>基本的に <code>doSkinVar</code> と同じですが、今度は<em>テンプレート</em>内(<code>item
239 header/body/footer</code> と <code>dateheader/footer</code>)での<code><%plugin(...)%></code> 変数からの呼び出しになります。デフォルトではこのメソッドはテンプレートをスキンタイプとみなして
240 <code>doSkinVar</code> メソッドに処理を渡します。<a href="#templatevars"><code>doTemplateVar</code> メソッドの実装に関する詳細情報はこちら</a></td>
243 <td><code>doTemplateCommentsVar(&$item, &$comment)</code></td>
244 <td>(v2.0b) 基本的に <code>doSkinVar</code> と同じですが、今度は<em>テンプレート</em>内(コメント部分)での<code><%plugin(...)%></code> 変数からの呼び出しになります。デフォルトではこのメソッドはテンプレートをスキンタイプとみなして
245 <code>doSkinVar</code> メソッドに処理を渡します。<a href="#templatevars"><code>doTemplateCommentsVar</code>
246 メソッドの実装に関する詳細情報はこちら</a></td>
249 <td><code>doAction($type)</code></td>
250 <td>プラグインがユーザーインタラクションを求めたとき、 <code>action.php</code>を介してこのメソッドがそれを与えます。.
251 これはNucleus自身が新しいコメントや投票を処理するのに使用するスクリプトです。正しいパラメータを用いることで、プラグインからの
252 <code>doAction</code> メソッドを呼び出せます。<code>$type</code> はオプションのメッセージタイプに該当します。<code>doAction</code> メソッド内で、リクエストからの追加の変数にアクセスできます。デフォルトではこのメソッドがエラーメッセージをトリガーすると<code>'No
253 Such Action'</code>という文字列を返します。<a href="#actions"><code>doAction</code> に関する詳細情報はこちら</a></td>
256 <td><code>install()</code></td>
257 <td>このメソッドはプラグインがインストールされた際に呼ばれます。データベース・テーブルの生成やプラグインオプションの生成などの初期化作業を行うことができます。デフォルトではこのメソッドは何もしません。</td>
260 <td><code>unInstall()</code></td>
261 <td>プラグインがアンインストールされた際に呼ばれます。この時点でデータベースに作られたプラグイン情報を消去すると良いです。デフォルトではこのメソッドは何もしません。</td>
264 <td><code>getEventList()</code></td>
265 <td>プラグインはイベント登録が可能です。イベントはNucleusが何かアクションを起こすたびに生成されます。たとえば、<code>AddItem</code> イベントは、このイベントを登録しているすべてのプラグインを呼び出します。呼び出されるメソッドは <code>event_AddItem($params)</code>になります。 <code>$params</code> パラメータは、例えば <code>AddItem</code> の <code>itemid</code> のような、情報フィールドを複数持つ連想配列です。デフォルトではどのイベントにも登録されていないことを示す空の配列を返します。<a href="#events">イベントに関する詳細情報
269 <td><code>getTableList()</code></td>
270 <td>このメソッドはプラグインが生成したデータベース・テーブルの配列を返します。これはNucleusが提供するバックアップ機能で利用されるので、プラグインテーブルをバックアップに含めることができます。デフォルトでは空の配列を返します。</td>
273 <td><code>hasAdminArea()</code></td>
274 <td>プラグインが独自の管理エリアをもつ場合 1 を、そうでない場合 0 を返します。デフォルトでは <code>0</code> を返します。</td>
277 <td><code>getPluginDep()</code></td>
278 <td>(v3.2) プラグイン名の配列を返します。Nucleusはこれらのプラグインが前もってインストールされてない場合、プラグインのインストールを拒否します。デフォルトでは空の配列が返されます。<a href="#dependency">プラグイン依存に関する詳細情報はこちら</a></td>
282 <p>実装可能なメソッドの次は、<code>NucleusPlugin</code> クラスが提供する、再実装<strong>すべきでない</strong>幾つかの特殊メソッドです。これらはプラグイン内で、<code>$this->functionName()</code>シンタックスを利用して呼び出します。</p>
284 <table summary="An overview of the auxiliary methods in the class NucleusPlugin. You should NOT redefine these">
286 <code>NucleusPlugin</code> クラスの概要(再定義不可能なメソッド)
294 <code>createOption(...)</code>
295 <br /><code>createBlogOption(...)</code>(v2.2)
296 <br /><code>createCategoryOption(...)</code>(v2.2)
297 <br /><code>createMemberOption(...)</code>(v2.2)
298 <br /><code>createItemOption(...)</code>(v3.2)
300 <td><a href="#options" title="More info on options">新しいオプションを生成します。</a></td>
304 <code>deleteOption(...)</code>
305 <br /><code>deleteBlogOption(...)</code>(v2.2)
306 <br /><code>deleteCategoryOption(...)</code>(v2.2)
307 <br /><code>deleteMemberOption(...)</code>(v2.2)
308 <br /><code>deleteItemOption(...)</code>(v3.2)
310 <td><a href="#options" title="More info on options">オプションを削除します。</a></td>
314 <code>setOption(...)</code>
315 <br /><code>setBlogOption(...)</code>(v2.2)
316 <br /><code>setCategoryOption(...)</code>(v2.2)
317 <br /><code>setMemberOption(...)</code>(v2.2)
318 <br /><code>setItemOption(...)</code>(v3.2)
320 <td><a href="#options" title="More info on options">オプションに値をセットします。</a></td>
324 <code>getOption(...)</code>
325 <br /><code>getBlogOption(...)</code>(v2.2)
326 <br /><code>getCategoryOption(...)</code>(v2.2)
327 <br /><code>getMemberOption(...)</code>(v2.2)
328 <br /><code>getItemOption(...)</code>(v3.2)
330 <td><a href="#options" title="More info on options">オプションの値を取得します。</a></td>
334 <code>getAllBlogOptions(...)</code>(v2.2)
335 <br /><code>getAllCategoryOptions(...)</code>(v2.2)
336 <br /><code>getAllMemberOptions(...)</code>(v2.2)
337 <br /><code>getAllItemOptions(...)</code>(v3.2)
339 <td><a href="#options" title="More info on options">与えられたオプションにより、すべての値(コンテクストごとの一つの値)の連想配列を返します。</a></td>
343 <code>getBlogOptionTop(...)</code>(v3.2)
344 <br /><code>getMemberOptionTop(...)</code>(v3.2)
345 <br /><code>getCategoryOptionTop(...)</code>(v3.2)
346 <br /><code>getItemOptionTop(...)</code>(v3.2)
348 <td><a href="#options" title="More info on options">与えられたオプションにより、すべての値のうちの最初の値を返します。</a></td>
351 <td><code>getID()</code></td>
352 <td>このプラグインのIDを返します(このIDはNucleus内部で利用されるものです)。</td>
355 <td><code>getAdminURL()</code></td>
356 <td>プラグインの管理エリアが置かれたURLを返します(そのような管理エリアがない場合は、この情報は無効です)。</td>
359 <td><code>getDirectory()</code></td>
360 <td>プラグインの追加ファイルが格納されたサーバーのファイルシステムのパスを返します(そのようなファイルがない場合は、この情報は無効です)。結果は"<code>.../nucleus/plugins/<em>plugname</em>/</code>"のようになります。</td>
363 <td><code>getShortName()</code></td>
364 <td>"NP_"部分を省き、全てを小文字にしたプラグインのクラス名を返します。この情報は <code>getAdminURL</code> と <code>getDirectory</code> で使用されます。</td>
369 <h1>スキン変数<a name="skinvars" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
374 独自のスキン変数を生成し、<code><%plugin(<em>PlugName,parameters</em>)%></code> または <code><%PlugName(parameters)%></code>で呼び出すことが出来ます(すでに存在するスキン変数とかぶらない場合)。パラメータはカンマ区切りです。</p>
377 スキン変数を扱うには、<code>doSkinVar</code> メソッドを実装する必要があります。いくつかの例を以下に示します。</p>
379 <pre class="example"><code>function doSkinVar($skinType)
380 function doSkinVar($skinType, $param1, $param2)
381 function doSkinVar($skinType, $skinVar, $param1, $param2)
382 function doSkinVar($skinType, $skinVar, $param1 = 'default value')</code></pre>
385 <li><code>$skinType</code> パラメータは、'index', 'item', 'archive', 'archivelist', 'member', 'error',
386 'search', 'imagepopup', <a href="#templatevars" title="Information on templatevars">'template'</a>のうちの一つを取ります</li>
387 <li><code>$skinVar</code> は、スキン変数のタイプとして解釈される実質的に最初のパラメータになります(例:<code><%plugin(PlugName,VarType)%></code>)。</li>
388 <li><code>doSkinVar()</code>(パラメータ無し)を使い、PHPファンクションの<code>func_get_args()</code>を用いてパラメータを取得することができます。引数の数の異なる、タイプの違うスキン変数を扱うときに便利です。</li>
394 <li>(v2.0b) グローバル変数としてパースされている <code>$currentSkinName</code> を使ってスキンの名前を取得できます。</li>
400 <h1>テンプレート変数<a name="templatevars" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
405 テンプレートプラグイン変数はスキンプラグイン変数と同様に働きますが以下の2点が異なります。</p>
408 <li>スキン内ではなくテンプレート内から呼ばれます。</li>
409 <li>$skinTypeパラメータを取りません。代わりに現在パースされているアイテムやコメントの情報付きの追加パラメータを取ります。
411 <li><code>doTemplateVar</code> メソッドは <code>&$item</code> パラメータを取ります。</li>
412 <li><code>doTemplateCommentsVar</code> メソッドは <code>&$item</code> と <code>&$comment</code> パラメータを取ります。</li>
414 <strong>&マークに注意!</strong>
418 <p>テンプレート変数はスキン変数と同じ要領で呼ばれます(<code><%plugin(PlugName,parameters)%></code> または <code><%PlugName(parameters)%></code>)。</p>
421 デフォルトでは、全てのテンプレート変数は'<code>template</code>'を<code>skintype</code>パラメータとして、<code>doSkinVar</code> メソッドに渡ります。</p>
424 独自の実装を提供したい場合は、<code>doTemplateVar</code> メソッドや <code>doTemplateCommentsVar</code> メソッドを再定義する必要があります。<code>skintype</code>パラメータが無くなる以外はdoSkinVarと同様に働きます。</p>
426 <pre class="example"><code>function doTemplateVar(&$item)
427 function doTemplateVar(&$item, $param1, $param2)
428 function doTemplateVar(&$item, $type, $param1, $param2)
429 function doTemplateVar(&$item, $type, $param1 = 'default value')
430 function doTemplateCommentsVar(&$item, &$comment)
431 function doTemplateCommentsVar(&$item, &$comment, $param1, $param2)
432 function doTemplateCommentsVar(&$item, &$comment, $type, $param1, $param2)
433 function doTemplateCommentsVar(&$item, &$comment, $type, $param1 = 'default value')</code></pre>
438 <li>(v2.0b) グローバル変数として内部で利用される <code>$currentSkinName</code> を使ってテンプレートの名前を取得できます。</li>
444 <h1>アクション<a name="actions" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
446 <p>プラグインは <code>action.php</code> を通してアクションを行うことができ、同様のスクリプトがコメントや投票の受け取りにも使用されてます。GETまたはPOSTのどちらかを通して呼び出せます。必要なパラメータは
447 <code>action</code>('plugin'と指定)、<code>name</code>(プラグイン名)、<code>type</code>(リクエストされたアクションの種類)です。</p>
449 <p>これらのアクションを有効にするために、<code>doAction($actionType)</code> メソッドをプラグイン内で実装する必要があります。リクエストからの追加パラメータは
450 <code>requestVar('<em>name</em>')</code> で取得できます(<code>requestVar</code> はPHPが付加する magic_quotes_gpc に配慮しています)。</p>
453 <code>doAction</code> メソッドが文字列を返すとき、エラーとして解釈され、エラーメッセージが表示されます。</p>
460 <h1>イベント<a name="events" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
463 Nucleusプラグインはなにか重要なことが起きたときに発生するイベントに登録可能です。プラグインはイベント発生の際にアクションを実行したり、テキストを出力したりできます。</p>
468 下記は <code>PreAddComment</code> イベント(blogにコメントが追加される直前に生成されるイベント)にプラグインが登録する例です。</p>
470 <pre class="example"><code>class NP_Acronyms extends NucleusPlugin {
472 function getEventList() { return array('PreAddComment'); }
474 function event_PreAddComment(&$data) {
476 $data['comment']['body'] =
478 '<acronym title="HyperText Markup Language">HTML</acronym>',
479 $data['comment']['body']);
484 <p>このプラグインはコメント中の'HTML'というテキストを'<code><acronym title="HyperText
485 Markup Language">HTML</acronym></code>'に置き換えます。acronymタグはHTMLタグで、頭字語についての追加情報を提供します。</p>
489 <p>イベント登録に必要なステップは以下になります。</p>
492 <li><code>getEventList</code> メソッドから返る配列にイベント名を追加します。</li>
493 <li><code>event_EventName($data)</code> という形でメソッドを生成し、この中でイベントを処理します。</li>
496 <p>複数のプラグインが同じイベントに登録できます。管理エリアのプラグインリストの順序に従ってプラグインに通知が行きます。リストの上にあるプラグインほど早く通知されます。</p>
500 <p><code>event_EventName</code> メソッドはひとつだけ <code>$data</code> パラメータを持ち、それはイベントごとに内容が異なります。これは連想配列です。この連想配列に渡されたオブジェクトや配列は<strong>参照形式</strong>で渡されるため、これらに加えた変更は記憶されます。</p>
502 <p>以下のイベントリストは、パラメータ変更がNucleusに知られるかどうかを示すために色を使い分けています。</p>
505 <li><var class="ref">参照渡し(緑)</var>: この種のパラメータに変更を加えるとNucleusに知られます。</li>
506 <li><var class="ro">値渡し(赤)</var>: プラグインイベントハンドラに渡される前に値がコピーされます。これらの変数への変更は自動的に破棄されます。.</li>
509 <p>パラメータとして渡されるオブジェクトは<var class="obj">object</var>.として示されます。ほとんどのオブジェクトは参照渡しで、<var class="obj ref">object
510 by ref</var>のように示されます。</p>
514 <table summary="An overview of events to which a Nucleus Plugin can subscribe, and what parameters are passed along to the method that handles the event">
516 プラグインが登録できるイベント</caption>
523 <td>InitSkinParse</td>
526 <dt class="obj ref">skin</dt>
527 <dd>パースする<code>SKIN</code>オブジェクト</dd>
528 <dt class="ro">type</dt>
529 <dd>スキンタイプ('index', 'item', 'archive', 'archivelist',
530 'member', 'error', 'search', 'imagepopup', 'fileparser'のいずれか)</dd>
534 <td>PreSkinParse</td>
537 <dt class="obj ref">skin</dt>
538 <dd>パースする<code>SKIN</code>オブジェクト</dd>
539 <dt class="ro">type</dt>
540 <dd>スキンタイプ('index', 'item', 'archive', 'archivelist',
541 'member', 'error', 'search', 'imagepopup', 'fileparser'のいずれか)</dd>
542 <dt class="ref">contents</dt>
547 <td>PostSkinParse</td>
550 <dt class="obj ref">skin</dt>
551 <dd>パースする<code>SKIN</code>オブジェクト</dd>
552 <dt class="ro">type</dt>
553 <dd>スキンタイプ('index', 'item', 'archive', 'archivelist', 'member', 'error', 'search',
554 'imagepopup', 'fileparser'のいずれか)</dd>
559 <td>アイテムのパース前、ただしアイテムヘッダーのパース後</td>
561 <dt class="ref obj">blog</dt>
562 <dd><code>BLOG</code> オブジェクト</dd>
563 <dt class="ref obj">item</dt>
564 <dd>アイテムデータを持つオブジェクト</dd>
569 <td>アイテムのパース後、ただしアイテムフッターのパース前</td>
571 <dt class="ref obj">blog</dt>
572 <dd><code>BLOG</code> オブジェクト</dd>
573 <dt class="ref obj">item</dt>
574 <dd>アイテムデータを持つオブジェクト</dd>
581 <dt class="ref">comment</dt>
582 <dd>コメントデータを持つ連想配列</dd>
589 <dt class="ref">comment</dt>
590 <dd>コメントデータを持つ連想配列</dd>
597 <dt class="obj ref">blog</dt>
598 <dd><code>BLOG</code> オブジェクト</dd>
599 <dt class="ro">timestamp</dt>
600 <dd>日付ヘッダーのタイムスタンプ</dd>
604 <td>PostDateHead</td>
607 <dt class="obj ref">blog</dt>
608 <dd><code>BLOG</code> オブジェクト</dd>
609 <dt class="ro">timestamp</dt>
610 <dd>日付ヘッダーのタイムスタンプ</dd>
617 <dt class="ref obj">blog</dt>
618 <dd><code>BLOG</code> オブジェクト</dd>
619 <dt class="ro">timestamp</dt>
620 <dd>日付フッターのタイムスタンプ</dd>
624 <td>PostDateFoot</td>
627 <dt class="ref obj">blog</dt>
628 <dd><code>BLOG</code> オブジェクト</dd>
629 <dt class="ro">timestamp</dt>
630 <dd>日付フッターのタイムスタンプ</dd>
634 <td>LoginSuccess</td>
637 <dt class="obj ref">member</dt>
638 <dd><code>MEMBER</code> オブジェクト</dd>
645 <dt class="ro">username</dt>
646 <dd>ログイン時に使われたユーザー名</dd>
653 <dt class="ro">username</dt>
654 <dd>ログアウト時のユーザー名</dd>
658 <td>PreBlogContent</td>
659 <td>blogの内容がスキン変数を通して挿入される前</td>
661 <dt class="obj ref">blog</dt>
662 <dd><code>BLOG</code> オブジェクト</dd>
663 <dt class="ro">type</dt>
664 <dd>呼び出されたスキン変数 ('blog', 'otherblog', 'archive', 'archivelist', 'item', 'searchresults',
665 'othersearchresults', 'categorylist', 'otherarchive', 'otherarchivelist')</dd>
669 <td>PostBlogContent</td>
670 <td>blogの内容がスキン変数を通して挿入された後</td>
672 <dt class="obj ref">blog</dt>
673 <dd><code>BLOG</code> オブジェクト</dd>
674 <dt class="ro">type</dt>
675 <dd>呼び出されたスキン変数 ('blog', 'otherblog', 'archive', 'archivelist', 'item', 'searchresults',
676 'othersearchresults', 'categorylist', 'otherarchive', 'otherarchivelist')</dd>
680 <td>PreAddComment</td>
681 <td>コメントがデータベースに追加される前</td>
683 <dt class="ref">comment</dt>
684 <dd>コメントデータ(連想配列)</dd>
688 <td>PostAddComment</td>
689 <td>コメントがデータベースに追加された後</td>
691 <dt class="ref">comment</dt>
692 <dd>コメントデータ(連想配列)</dd>
693 <dt class="ref">commentid</dt>
698 <td>PostRegister</td>
701 <dt class="obj ref">member</dt>
702 <dd>新しい<code>MEMBER</code> オブジェクト</dd>
707 <td>アイテムがデータベースに追加された後</td>
709 <dt class="ro">itemid</dt>
710 <dd>データベースに出来た新しい itemid</dd>
714 <td>PostUpdateItem</td>
715 <td>アイテムがデータベースにアップデートされた直後</td>
717 <dt class="ro">itemid</dt>
723 <td>アイテムがデータベースに追加される直前</td>
725 <dt class="ref">title</dt>
727 <dt class="ref">body</dt>
729 <dt class="ref">more</dt>
731 <dt class="ref obj">blog</dt>
732 <dd><code>BLOG</code> オブジェクト</dd>
733 <dt class="ref">authorid</dt>
735 <dt class="ref">timestamp</dt>
736 <dd>UNIX タイムスタンプ</dd>
737 <dt class="ref">closed</dt>
738 <dd>1 (コメント不可) or 0 (コメント可)</dd>
739 <dt class="ref">draft</dt>
740 <dd>1 (ドラフト) or 0 (非ドラフト)</dd>
741 <dt class="ref">catid</dt>
746 <td>PreUpdateItem</td>
747 <td>データベースにあるアイテムが更新される直前</td>
749 <dt class="ro">itemid</dt>
751 <dt class="ref">title</dt>
753 <dt class="ref">body</dt>
755 <dt class="ref">more</dt>
757 <dt class="ref obj">blog</dt>
758 <dd><code>BLOG オブジェクト</code> object</dd>
759 <dt class="ref">closed</dt>
760 <dd>1 (コメント不可) or 0 (コメント可)</dd>
761 <dt class="ref">catid</dt>
766 <td>PrepareItemForEdit</td>
767 <td>アイテムをデータベースから取得した直後で、編集のためにユーザーに表示される前</td>
769 <dt class="ref">item</dt>
770 <dd>アイテムデータを持つ連想配列</dd>
774 <td>PreUpdateComment</td>
775 <td>コメントが更新され、データベースに保存される直前</td>
777 <dt class="ref">body</dt>
782 <td>PrepareCommentForEdit</td>
783 <td>コメントをデータベースから取得した直後で、編集のためにユーザーに表示される前</td>
785 <dt class="ref">comment</dt>
786 <dd>コメントデータ(連想配列)</dd>
790 <td>PrePluginOptionsEdit</td>
792 (v2.0b) 'プラグインオプションの編集'フォームが生成される前
794 <br />(v3.2) 各オプションにパラメータ追加
797 <dt class="ro">context</dt>
798 <dd>(v2.2) <code>global</code>, <code>blog</code>, <code>member</code>, <code>item</code>, <code>category</code>のいずれか</dd>
799 <dt class="ref">options</dt>
800 <dd>次のインデックスをもつ連想配列: <code>name</code>, <code>value</code>, <code>oid</code>, <code>description</code>, <code>type</code>, <code>typeinfo</code>, <code>contextid</code>, <code>extra</code> 。追加オプションをここに加えることも可能(それらで何かの処理をするときはPostPluginOptionsUpdateの記述も必要)<br />
801 <code>extra</code>フィールドを用いて、オプションに追加HTML(たとえばフォームのコントロール)を追加できます。もしそうする場合、 <code>extra</code> に追加する前に <code>pid</code> と <code>getID()</code> を比較し、さらに <code>name</code> をチェックすべきです。</dd>
802 <dt class="ro">plugid</dt>
803 <dd>プラグイン ID (これが気になるなら、<code>GetID()</code>を見ると理解できる)(コンテクストがglobalのときのみ存在)</dd>
804 <dt class="ro">contextid</dt>
805 <dd>コンテクスト ID (blogid, memberid, catid, itemid コンテクストによる)</dd>
809 <td>PrePluginOptionsUpdate</td>
811 (v3.2) プラグインオプションが更新される前。(このイベントを使ってオプションの新しい値を評価したり変更したりできます)
814 <dt class="ro">context</dt>
815 <dd>(v2.2) <code>global</code>, <code>member</code>, <code>blog</code>, <code>item</code>, <code>category</code>のいずれか</dd>
816 <dt class="ro">plugid</dt>
817 <dd>プラグイン ID (これが気になるなら、<code>GetID()</code>を見ると理解できる)</dd>
818 <dt class="ro">optionname</dt>
820 <dt class="ro">contextid</dt>
821 <dd>コンテクスト ID (blogid, memberid, catid, itemid コンテクストによる)</dd>
822 <dt class="ref">value</dt>
823 <dd>そのオプションの新しい値</dd>
827 <td>PostPluginOptionsUpdate</td>
829 (v2.0b) プラグインオプションの更新後<br />
830 (v2.2) コンテクストによって異なるパラメータ</td>
832 <dt class="ro">context</dt>
833 <dd>(v2.2) <code>global</code>, <code>member</code>, <code>blog</code>, <code>item</code>, <code>category</code>のいずれか</dd>
834 <dt class="ro">plugid</dt>
835 <dd>プラグイン ID (これが気になるなら、<code>GetID()</code>を見ると理解できる)(globalコンテクスト)</dd>
836 <dt class="ro">blogid</dt>
837 <dd>(v2.2) blog ID (blog コンテクスト)</dd>
838 <dt class="ref obj">blog</dt>
839 <dd>(v2.2) BLOG オブジェクト (blog コンテクスト)</dd>
840 <dt class="ro">memberid</dt>
841 <dd>(v2.2) member ID (member コンテクスト)</dd>
842 <dt class="ref obj">member</dt>
843 <dd>(v2.2) MEMBER オブジェクト (member コンテクスト)</dd>
844 <dt class="ro">catid</dt>
845 <dd>(v2.2) category ID (category コンテクスト)</dd>
846 <dt class="ro">itemid</dt>
847 <dd>(v2.2) item ID (item コンテクスト)</dd>
848 <dt class="ref obj">member</dt>
849 <dd>(v2.2) ITEM オブジェクト (item コンテクスト)</dd>
854 <td>PostAuthentication</td>
855 <td>(v2.0b) ログイン処理の完了後。ページリクエストごとに発生</td>
857 <dt class="ro">loggedIn</dt>
858 <dd><code>$member->isLoggedIn()</code>の戻り値</dd>
862 <td>PreAddItemForm</td>
863 <td>(v2.0b) アイテム追加フォーム(ブックマークレットまたは管理エリア)が生成される直前</td>
865 <dt class="ref">contents</dt>
866 <dd>連想配列への参照。そのうちの'title',
867 'body', 'more'にはフォームフィールドへの初期値を与えることができます。複数のプラグイン間でこれらの値の変更を避けるには、処理後に'hasBeenSet'の値を1にセットします(かつ処理前にこの値をチェックするようにします)</dd>
868 <dt class="ref obj">blog</dt>
869 <dd><code>BLOG</code> オブジェクトへの参照</dd>
873 <td>AddItemFormExtras</td>
874 <td>(v2.0b) アイテム追加ページまたはブックマークレット内部のどこか。<code>template</code> ファイルの類を別に用意しなくても、ここでプラグインがカスタムフィールドを追加できる。</td>
876 <dt class="ref obj">blog</dt>
877 <dd><code>BLOG</code> オブジェクトへの参照</dd>
881 <td>EditItemFormExtras</td>
883 (v2.0b) アイテム編集ページまたはブックマークレット内部のどこか。<code>template</code> ファイルの類を別に用意しなくても、ここでプラグインがカスタムフィールドを追加できる。<br />
885 あまり多くのデータを追加しないこと。また以下のように<strong>正しいXHTML</strong>を生成してください。 <pre class="example"><code><h3>プラグイン名</h3>
886 <p>追加フォームの内容</p></code></pre>
887 このようにして、正しい構造を保ちつつ複数のプラグインがオプションを保持できます。またフィールド名の重複を避けるためにプレフィックスを用いてください(例 <code>plug_tb_url</code>)。</td>
889 <dt class="ref obj">blog</dt>
890 <dd><code>BLOG</code> オブジェクトへの参照</dd>
891 <dt class="ro">variables</dt>
893 (read-only) 編集されるアイテムに関する全ての情報を持つ連想配列: 'itemid',
894 'draft', 'closed', 'title', 'body', 'more', 'author', 'authorid',
895 'timestamp', 'karmapos', 'karmaneg', 'catid'
897 <dt class="ro">itemid</dt>
898 <dd>アイテム IDへのショートカット</dd>
902 <td>BlogSettingsFormExtras</td>
903 <td>(v2.0) blog設定ページにフォームを追加可能<br /><br />
904 あまり多くのデータを追加しないこと。また以下のように<strong>正しいXHTML</strong>を生成してください。 <pre class="example"><code><h4>プラグイン名</h4>
905 <form method="post" action="..."><p>
906 追加フォームの内容</p></form></code></pre>
907 このようにして、正しい構造を保ちつつ複数のプラグインがオプションを保持できます。またフィールド名の重複を避けるためにプレフィックスを用いてください(例 <code>plug_tb_url</code>)。</td>
909 <dt class="obj ref">blog</dt>
910 <dd><code>BLOG</code> オブジェクトへの参照</dd>
914 <td>PreDeleteItem</td>
915 <td>(v2.0) アイテムがデータベースから削除される直前</td>
917 <dt class="ro">itemid</dt>
922 <td>PostDeleteItem</td>
923 <td>(v2.0) アイテムがデータベースから削除された直後</td>
925 <dt class="ro">itemid</dt>
930 <td>PreDeleteCategory</td>
931 <td>(v2.0) カテゴリーがデータベースから削除される直前</td>
933 <dt class="ro">catid</dt>
934 <dd>削除されるカテゴリー ID</dd>
938 <td>PostDeleteCategory</td>
939 <td>(v2.0) カテゴリーがデータベースから削除された直後</td>
941 <dt class="ro">catid</dt>
942 <dd>削除されたカテゴリー ID</dd>
946 <td>PreDeleteBlog</td>
947 <td>(v2.0) blogがデータベースから削除される直前</td>
949 <dt class="ro">blogid</dt>
954 <td>PostDeleteBlog</td>
955 <td>(v2.0) blogがデータベースから削除された直後</td>
957 <dt class="ro">blogid</dt>
962 <td>PreDeleteMember</td>
963 <td>(v2.0) メンバーがデータベースから削除される直前</td>
965 <dt class="ref obj">member</dt>
966 <dd><code>削除されるメンバーに関するMEMBER</code> オブジェクトへの参照</dd>
970 <td>PostDeleteMember</td>
971 <td>(v2.0) メンバーがデータベースから削除された直後</td>
973 <dt class="ref obj">member</dt>
974 <dd><code>削除されるメンバーに関するMEMBER</code> オブジェクトへの参照</dd>
978 <td>PreDeleteTeamMember</td>
979 <td>(v2.0) メンバーがweblogチームから削除される直前</td>
981 <dt class="ref obj">member</dt>
982 <dd><code>MEMBER</code> オブジェクトへの参照</dd>
983 <dt class="ro">blogid</dt>
988 <td>PostDeleteTeamMember</td>
989 <td>(v2.0) メンバーがweblogチームから削除された直後</td>
991 <dt class="ref obj">member</dt>
992 <dd><code>MEMBER</code> オブジェクトへの参照</dd>
993 <dt class="ro">blogid</dt>
998 <td>PreDeleteComment</td>
999 <td>(v2.0) コメントがデータベースから削除される直前</td>
1001 <dt class="ro">commentid</dt>
1002 <dd>削除されるコメントID</dd>
1006 <td>PostDeleteComment</td>
1007 <td>(v2.0) コメントがデータベースから削除された直後</td>
1009 <dt class="ro">commentid</dt>
1010 <dd>削除されたコメントID</dd>
1014 <td>ActionLogCleared</td>
1015 <td>(v2.0) アクションログが消去された後</td>
1019 <td>PreDeleteTemplate</td>
1020 <td>(v2.0) テンプレートがデータベースから削除される直前</td>
1022 <dt class="ro">templateid</dt>
1023 <dd>削除されるテンプレートID</dd>
1027 <td>PostDeleteTemplate</td>
1028 <td>(v2.0) テンプレートがデータベースから削除された直後</td>
1030 <dt class="ro">templateid</dt>
1031 <dd>削除されたテンプレートID</dd>
1035 <td>PreDeleteSkin</td>
1036 <td>(v2.0) スキンがデータベースから削除される直前</td>
1038 <dt class="ro">skinid</dt>
1043 <td>PostDeleteSkin</td>
1044 <td>(v2.0) スキンがデータベースから削除された直後</td>
1046 <dt class="ro">skinid</dt>
1051 <td>PreDeletePlugin</td>
1052 <td>(v2.0) プラグインがデータベースから削除される直前</td>
1054 <dt class="ro">plugid</dt>
1055 <dd>削除されるプラグインID</dd>
1059 <td>PostDeletePlugin</td>
1060 <td>(v2.0) プラグインがデータベースから削除された直後</td>
1062 <dt class="ro">plugid</dt>
1063 <dd>削除されたプラグインID</dd>
1067 <td>PreDeleteBan</td>
1068 <td>(v2.0) 禁止IPがデータベースから削除される直前</td>
1070 <dt class="ro">blogid</dt>
1071 <dd>禁止IPが削除されるblogのID</dd>
1072 <dt class="ro">iprange</dt>
1077 <td>PostDeleteBan</td>
1078 <td>(v2.0) 禁止IPがデータベースから削除された直後</td>
1080 <dt class="ro">blogid</dt>
1081 <dd>禁止IPが削除されたblogのID</dd>
1082 <dt class="ro">iprange</dt>
1087 <td>PreAddCategory</td>
1088 <td>(v2.0) 新しいカテゴリーがデータベースに生成される直前</td>
1090 <dt class="ref obj">blog</dt>
1091 <dd><code>BLOG</code> オブジェクトの参照</dd>
1092 <dt class="ref">name</dt>
1094 <dt class="ref">description</dt>
1095 <dd>新しいカテゴリーの説明</dd>
1099 <td>PostAddCategory</td>
1100 <td>(v2.0) 新しいカテゴリーがデータベースに生成された直後</td>
1102 <dt class="ref obj">blog</dt>
1103 <dd><code>BLOG</code> オブジェクトへの参照</dd>
1104 <dt class="ro">name</dt>
1106 <dt class="ro">description</dt>
1107 <dd>新しいカテゴリーの説明</dd>
1108 <dt class="ro">catid</dt>
1109 <dd>新しいカテゴリー ID</dd>
1114 <td>(v2.0) 新しいblogが生成される直前</td>
1116 <dt class="ref">name</dt>
1118 <dt class="ref">shortname</dt>
1119 <dd>新しい blogの短縮名</dd>
1120 <dt class="ref">timeoffset</dt>
1121 <dd>新しい blogのタイムオフセット</dd>
1122 <dt class="ref">description</dt>
1123 <dd>新しい blogの説明</dd>
1124 <dt class="ref">defaultskin</dt>
1125 <dd>新しいblogのデフォルトスキンのID</dd>
1129 <td>PostAddBlog</td>
1130 <td>(v2.0) 新しいblogが生成された直後</td>
1132 <dt class="ref obj">blog</dt>
1133 <dd>新しい<code>BLOG</code> オブジェクト</dd>
1137 <td>PreAddPlugin</td>
1138 <td>(v2.0) プラグインが追加される直前</td>
1140 <dt class="ref">file</dt>
1141 <dd>新しいプラグインのファイル名</dd>
1145 <td>PostAddPlugin</td>
1146 <td>(v2.0) プラグインが追加された直後</td>
1148 <dt class="ref obj">plugin</dt>
1149 <dd>新しく追加されたプラグインのオブジェクト</dd>
1153 <td>PreAddTeamMember</td>
1154 <td>(v2.0) メンバーがblogチームに追加される直前</td>
1156 <dt class="ref obj">blog</dt>
1157 <dd><code>BLOG</code> オブジェクト</dd>
1158 <dt class="ref obj">member</dt>
1159 <dd><code>MEMBER</code> オブジェクト</dd>
1160 <dt class="ref">admin</dt>
1161 <dd>新しく追加されたメンバーが管理権限を持っているかどうかを示すブール値</dd>
1165 <td>PostAddTeamMember</td>
1166 <td>(v2.0) メンバーがblogチームに追加された直後</td>
1168 <dt class="ref obj">blog</dt>
1169 <dd><code>BLOG</code> オブジェクト</dd>
1170 <dt class="ref obj">member</dt>
1171 <dd><code>MEMBER</code> オブジェクト</dd>
1172 <dt class="ro">admin</dt>
1173 <dd>新しく追加されたメンバーが管理権限を持っているかどうかを示すブール値</dd>
1177 <td>PreAddTemplate</td>
1178 <td>(v2.0) 新しいテンプレートが生成される直前(注:テンプレートが複製されたときも呼ばれる)</td>
1180 <dt class="ref">name</dt>
1182 <dt class="ref">description</dt>
1183 <dd>新しいテンプレートの説明</dd>
1187 <td>PostAddTemplate</td>
1188 <td>(v2.0) 新しいテンプレートが生成された直後</td>
1190 <dt class="ro">name</dt>
1192 <dt class="ro">description</dt>
1193 <dd>新しいテンプレートの説明</dd>
1194 <dt class="ro">templateid</dt>
1195 <dd>新しいテンプレートID</dd>
1200 <td>(v2.0) 新しいスキンが生成される直前(注:スキンが複製されたときも呼ばれる)</td>
1202 <dt class="ref">name</dt>
1204 <dt class="ref">description</dt>
1206 <dt class="ref">type</dt>
1207 <dd>スキンのコンテントタイプ</dd>
1208 <dt class="ref">includeMode</dt>
1209 <dd>新しいスキンのインクルードモード</dd>
1210 <dt class="ref">includePrefix</dt>
1211 <dd>新しいスキンのインクルードプレフィックス</dd>
1215 <td>PostAddSkin</td>
1216 <td>(v2.0) 新しいスキンが生成された直後</td>
1218 <dt class="ro">name</dt>
1220 <dt class="ro">description</dt>
1222 <dt class="ro">type</dt>
1223 <dd>スキンのコンテントタイプ</dd>
1224 <dt class="ro">includeMode</dt>
1225 <dd>新しいスキンのインクルードモード</dd>
1226 <dt class="ro">includePrefix</dt>
1227 <dd>新しいスキンのインクルードプレフィックス</dd>
1228 <dt class="ro">skinid</dt>
1234 <td>(v2.0) 新しい禁止IPが追加される直前</td>
1236 <dt class="ref">blogid</dt>
1238 <dt class="ref">iprange</dt>
1240 <dt class="ref">reason</dt>
1241 <dd>禁止された理由を記述したテキストメッセージ</dd>
1246 <td>(v2.0) 新しい禁止IPが追加された直後</td>
1248 <dt class="ro">blogid</dt>
1250 <dt class="ro">iprange</dt>
1252 <dt class="ro">reason</dt>
1253 <dd>禁止された理由を記述したテキストメッセージ</dd>
1258 <td>PreMoveItem</td>
1259 <td>(v2.0) アイテムが他のblog/カテゴリーに移される直前</td>
1261 <dt class="ref">itemid</dt>
1263 <dt class="ref">destblogid</dt>
1265 <dt class="ref">destcatid</dt>
1266 <dd>移動先のカテゴリーID</dd>
1270 <td>PostMoveItem</td>
1271 <td>(v2.0) アイテムが他のblog/カテゴリーに移された直後</td>
1273 <dt class="ro">itemid</dt>
1275 <dt class="ro">destblogid</dt>
1277 <dt class="ro">destcatid</dt>
1282 <td>PreMoveCategory</td>
1283 <td>(v2.0) カテゴリーが他のblogに移される直前</td>
1285 <dt class="ref">catid</dt>
1287 <dt class="ref obj">sourceblog</dt>
1288 <dd>移動元の<code>BLOG</code> オブジェクト</dd>
1289 <dt class="ref obj">destblog</dt>
1290 <dd>移動先の<code>BLOG</code> オブジェクト</dd>
1294 <td>PostMoveCategory</td>
1295 <td>(v2.0) カテゴリーが他のblogに移された直後</td>
1297 <dt class="ro">catid</dt>
1299 <dt class="ref obj">sourceblog</dt>
1300 <dd>移動元の<code>BLOG</code> オブジェクト</dd>
1301 <dt class="ref obj">destblog</dt>
1302 <dd>移動先の<code>BLOG</code> オブジェクト</dd>
1306 <td>MemberSettingsFormExtras</td>
1307 <td>(v2.0) メンバー設定ページにフォームを追加可能<br /><br />
1308 あまり多くのデータを追加しないこと。また以下のように<strong>正しいXHTML</strong>を生成してください。
1309 <pre class="example"><code><h4>プラグイン名</h4>
1310 <form method="post" action="..."><p>
1311 追加フォームの内容</p></form></code></pre>
1312 このようにして、正しい構造を保ちつつ複数のプラグインがオプションを保持できます。またフィールド名の重複を避けるためにプレフィックスを用いてください(例 <code>plug_tb_url</code>)。</td>
1314 <dt class="ref obj">member</dt>
1315 <dd><code>MEMBER</code> オブジェクトへの参照</dd>
1319 <td>GeneralSettingsFormExtras</td>
1320 <td>(v2.0) 一般設定ページにフォームを追加可能<br />
1322 あまり多くのデータを追加しないこと。また以下のように<strong>正しいXHTML</strong>を生成してください。
1323 <pre class="example"><code><h4>プラグイン名</h4>
1324 <form method="post" action="..."><p>
1325 追加フォームの内容</p></form></code></pre>
1326 このようにして、正しい構造を保ちつつ複数のプラグインがオプションを保持できます。またフィールド名の重複を避けるためにプレフィックスを用いてください(例 <code>plug_tb_url</code>)。</td>
1330 <td>AdminPrePageHead</td>
1331 <td>(v2.5) 管理画面で、ページヘッドを出力する直前。このイベントはヘッド領域にスクリプトやCSSを追加するのに用いられます。</td>
1333 <dt class="ref">extrahead</dt>
1334 <dd>HTMLページのヘッド領域に埋め込まれる追加情報。ここに追加したいものを入れてください。</dd>
1335 <dt class="ro">action</dt>
1336 <dd>現在実行されているアクション、またはページタイプ</dd>
1340 <td>AdminPrePageFoot</td>
1341 <td>(v2.5) 管理画面で、ページフッターを出力する直前。</td>
1343 <dt class="ro">action</dt>
1346 現在実行されているアクション、またはページタイプ</td>
1349 <td>PreSendContentType</td>
1350 <td>(v2.5) HTTPヘッダーにコンテントタイプがセットされる直前</td>
1352 <dt class="ref">contentType</dt>
1353 <dd>コンテントタイプ(<code>application/xhtml+xml</code>など)</dd>
1354 <dt class="ref">charset</dt>
1356 <dt class="ro">pageType</dt>
1357 <dd>表示するページの種類を示す文字列:<code>skin</code> (スキンタイプ), <code>media</code> (メディアライブラリ), <code>admin-<em>action</em></code> (管理エリア), <code>bookmarklet-<em>action</em></code> (ブックマークレット)</dd>
1362 <td>(v2.5) 管理エリアのクイックメニューの一番下。そこへのプラグイン登録に利用されます。登録するにはoptionsに連想配列を入れます。実装例が<a href="#admin">プラグイン管理エリアを作る</a>のセクションにあります。</td>
1364 <dt class="ref">options</dt>
1369 <td>BookmarkletExtraHead</td>
1370 <td>(v2.5) ブックマークレット
1371 XHTMLコードのヘッド領域内。</td>
1373 <dt class="ref">extrahead</dt>
1374 <dd>XHTMLコードのヘッド領域に埋め込まれる追加情報。ここに追加したいものを入れてください。</dd>
1379 <td>(v3.2) このイベントは、プラグインがコメント、メンバー間メール、認証フォームのいずれかのフォーム内に追加フィールドを挿入するときに使います。フォーム処理の際に発生する <code>ValidateForm</code> イベントに対応します。</td>
1381 <dt class="ro">type</dt>
1382 <dd>イベントを発生させるフォームタイプ
1384 <li><code>activation</code></li>
1385 <li><code>additemform</code> (注:これは管理画面のアイテム追加フォームではない)</li>
1386 <li><code>commentform-loggedin</code></li>
1387 <li><code>commentform-notloggedin</code></li>
1388 <li><code>membermailform-loggedin</code></li>
1389 <li><code>membermailform-notloggedin</code></li>
1392 <dt class="ro obj">member</dt>
1393 <dd><code>type</code> が <code>activation</code>のとき、このフィールドは認証メンバーの詳細情報を含みます</dd>
1397 <td>ValidateForm</td>
1398 <td>(v3.2) コメント、メンバー間メール、アカウント認証のいずれかが処理されるときに呼ばれます。プラグインはこれで各データの評価を実行でき、もし不具合があれば処理を中断できます。<code>FormExtra</code> と共に使うとフォームにフィールドを追加できます。</td>
1400 <dt class="ro">type</dt>
1403 <li><code>membermail</code></li>
1404 <li><code>comment</code></li>
1405 <li><code>activation</code></li>
1408 <dt class="ref">error</dt>
1409 <dd>フォーム処理をストップするときに、<code>error</code> フィールドに空でないエラーメッセージを記入します。このエラーメッセージはユーザー側に表示されます。</dd>
1410 <dt class="ref">comment</dt>
1411 <dd>コメントフォームのとき、コメントデータに関する連想配列を含みます。</dd>
1412 <dt class="ro obj">member</dt>
1413 <dd>認証フォームのとき、認証中のメンバー情報を含みます。</dd>
1485 <h1>オプションを保存する<a name="options" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
1487 <p>プラグインに簡単にオプションを登録・取得できるように一連のメソッドが用意されています。これらのオプションは直接Nucleusの管理エリアで編集でき、プラグイン自身の管理エリアを用意する必要もなく、PHPファイルそのものの中にオプションの値を書き込まずにすみます。</p>
1489 <p>オプションは異なったコンテクストで利用可能です。</p>
1492 <li><strong>グローバルオプション</strong>:管理エリアのプラグインセクションで編集可能</li>
1493 <li><strong>blogオプション</strong>:blog設定ページで編集可能</li>
1494 <li><strong>カテゴリーオプション</strong>:blog設定ページ(のカテゴリー編集ページ)で編集可能</li>
1495 <li><strong>メンバーオプション</strong>:メンバー編集ページで編集可能</li>
1496 <li><strong>アイテムオプション</strong>:アイテムの追加、およびアイテムの編集ページで編集可能</li>
1501 <p>オプションにはいくつかのタイプが提供されています。</p>
1507 <dd>'yes'か'no'どちらか(編集画面ではラジオボタンとして表示されます)</dd>
1509 <dd>テキストフィールド (編集画面では伏字で表示されます)</dd>
1510 <dt>textarea (v2.2)</dt>
1511 <dd>複数行のテキストフィールド</dd>
1512 <dt>select (v2.2)</dt>
1513 <dd>ドロップダウンメニュー。次のような形式の追加情報が必要です: Option 1|value1|Option 2|value2|Option 3|value3 </dd>
1518 <p>Nucleus v3.2よりオプション・メタデータを用いて、オプションタイプを正しい値を受け取れるように制限できるようになりました。このメタデータは <code>$typeExtras</code>フィールドにセミコロン区切りのリストで保存されます。注:selectオプションでは、selectリストは<code>$typeExtras</code>のなかで一番最初でなければいけません。</p>
1524 <td><code>datatype</code></td>
1525 <td>Nucleus本体に、どのデータ型を使いたいかという追加情報を与えます。現在は '<code>numerical</code>' のみ利用できます。 '<code>numerical</code>' を指定することでNucleusは数値情報のみを受け付けます(クライアントサイド・サーバサイド両方でチェック) ('<code>select</code>' と '<code>text</code>'のオプションタイプで利用できます)</td>
1527 <td><code>access</code></td>
1528 <td>'<code>readonly</code>'にセットすることで、オプションを編集不可能にします('<code>text</code>' と '<code>textarea</code>'のオプションタイプで利用できます)<br />
1529 '<code>hidden</code>'を使うと、利用者側にそのオプションの存在を完全に隠蔽します('<code>text</code>'のオプションタイプで利用できます)</td>
1533 <pre class="example"><code>// 数値のみを受け付けるテキストオプションを作成
1534 $this->createBlogOption('FooBar', 'foobar', 'text', '0', 'datatype=numerical');
1535 // 数値のみを受け付けるセレクトオプションを作成
1536 $this->createItemOption('FooBar', 'foobar', 'select', '0', '0|0|1|1|2|2;datatype=numerical');
1537 // 編集不可能なテキストエリアオプションを作成
1538 $this->createOption('FooBar', 'foobar', 'textarea', 'This textarea is readonly', 'access=readonly');
1544 <li>オプション名は最大20文字です。</li>
1545 <li>オプションの説明文は最大255文字です。</li>
1546 <li>オプションの値は制限ありません(v2.2より前のバージョンでは128文字の制限がありました)</li>
1547 <li>'=', '|', ';' のキャラクターはセレクトオプション用のセレクトリストやオプション・メタデータ中で使用することはできません。</li>
1552 <h3>createOption($name, $desc, $type, $defValue = '', $typeExtras = '')</h3>
1554 <p><strong>グローバル</strong>なコンテクストで新しいオプションを生成します。</p>
1564 <td>オプション編集画面で表示される説明文</td>
1567 <td>オプションタイプ(前出)</td>
1572 <td>$typeExtras</td>
1573 <td>オプションタイプの追加情報(前出)</td>
1576 <h3>[v2.2] createBlogOption($name, $desc, $type, $defValue = '', $typeExtras = '')</h3>
1578 <p><strong>blog</strong>のコンテクストで新しいオプションを生成します(<code>createOption</code>を参照)。</p>
1580 <h3>[v2.2] createCategoryOption($name, $desc, $type, $defValue = '', $typeExtras = '')</h3>
1582 <p><strong>カテゴリー</strong>のコンテクストで新しいオプションを生成します(<code>createOption</code>を参照)。</p>
1584 <h3>[v2.2] createMemberOption($name, $desc, $type, $defValue = '', $typeExtras = '')</h3>
1586 <p><strong>メンバー</strong>のコンテクストで新しいオプションを生成します(<code>createOption</code>を参照)。</p>
1588 <h3>[v3.2] createItemOption($name, $desc, $type, $defValue = '', $typeExtras = '')</h3>
1590 <p><strong>アイテム</strong>のコンテクストで新しいオプションを生成します(<code>createOption</code>を参照)。</p>
1592 <h3>setOption($name, $value)</h3>
1594 <p>すでにデータベースに存在するオプションの値を変更します。</p>
1607 <h3>[v2.2] setBlogOption($blogid, $name, $value)</h3>
1609 <p>blogオプションの値を変更します。<code>blogid</code>属性はどのblogでそのオプションが有効かを示します(その他のオプション:<code>setOption</code>を参照)。</p>
1611 <h3>[v2.2] setCategoryOption($catid, $name, $value)</h3>
1613 <p>カテゴリーオプションの値を変更します。<code>catid</code>属性はどのカテゴリーでそのオプションが有効かを示します(その他のオプション:<code>setOption</code>を参照)。</p>
1615 <h3>[v2.2] setMemberOption($memberid, $name, $value)</h3>
1617 <p>メンバーオプションの値を変更します。<code>memberid</code>属性はどのメンバーでそのオプションが有効かを示します(その他のオプション:<code>setOption</code>を参照)。</p>
1619 <h3>[v3.2] setItemOption($itemid, $name, $value)</h3>
1621 <p>アイテムオプションの値を変更します。<code>itemid</code>属性はどのアイテムでそのオプションが有効かを示します(その他のオプション:<code>setOption</code>を参照)。</p>
1623 <h3>getOption($name)</h3>
1625 <p>データベース内のオプションの値を返します。</p>
1635 <h3>[v2.2] getBlogOption($blogid, $name)</h3>
1637 <p>blogオプションの値を返します。<code>blogid</code>属性は値がリスエストされたblogを示します(その他のオプション:<code>getOption</code>を参照)。</p>
1639 <h3>[v2.2] getCategoryOption($catid, $name)</h3>
1641 <p>カテゴリーオプションの値を返します。<code>catid</code>属性は値がリスエストされたカテゴリーを示します(その他のオプション:<code>getOption</code>を参照)。<br />
1644 <h3>[v2.2] getMemberOption($memberid, $name)</h3>
1646 <p>メンバーオプションの値を返します。<code>memberid</code>属性は値がリスエストされたメンバーを示します(その他のオプション:<code>getOption</code>を参照)。</p>
1648 <h3>[v3.2] getItemOption($itemid, $name)</h3>
1650 <p>アイテムオプションの値を返します。<code>itemid</code>属性は値がリスエストされたアイテムを示します(その他のオプション:<code>getOption</code>を参照)。</p>
1652 <h3>deleteOption($name)</h3>
1654 <p>データベースからオプションを削除します。</p>
1664 <h3>[v2.2] deleteBlogOption($name)</h3>
1666 <p>blogオプションを削除します(<code>deleteOption</code>を参照)。</p>
1668 <h3>[v2.2] deleteCategoryOption($name)</h3>
1670 <p>カテゴリーオプションを削除します(<code>deleteOption</code>を参照)。</p>
1672 <h3>[v2.2] deleteMemberOption($name)</h3>
1674 <p>メンバーオプションを削除します(<code>deleteOption</code>を参照)。</p>
1676 <h3>[v3.2] deleteItemOption($name)</h3>
1678 <p>アイテムオプションを削除します(<code>deleteOption</code>を参照)。</p>
1680 <h3>[v2.2] getAllBlogOptions($name)</h3>
1682 <p>与えられたblogオプションの全ての値を返します。結果は存在するblogidごとの連想配列です。</p>
1684 <h3>[v2.2] getAllCategoryOptions($name)</h3>
1686 <p>与えられたカテゴリーオプションの全ての値を返します。結果は存在するcatidごとの連想配列です。</p>
1688 <h3>[v2.2] getAllMemberOptions($name)</h3>
1690 <p>与えられたメンバーオプションの全ての値を返します。結果は存在するmemberidごとの連想配列です。</p>
1692 <h3>[v3.2] getAllItemOptions($name)</h3>
1694 <p>与えられたアイテムオプションの全ての値を返します。結果は存在するitemidごとの連想配列です。</p>
1696 <h3>[v3.2] getBlogOptionTop($name, $amount = 10, $sort = 'desc')</h3>
1698 <p>与えられたオプションの最初の値を返します。結果は配列で、各要素がそれぞれのblogid ('id') の値 ('value') を持つ配列になっています。</p>
1711 <td>昇順 ('asc') か降順 ('desc') で並べ替え</td>
1714 <h3>[v3.2] getMemberOptionTop($name, $amount = 10, $sort = 'desc')</h3>
1716 <p>与えられたオプションの最初の値を返します。結果は配列で、各要素がそれぞれのメンバーID ('id') の値 ('value') を持つ配列になっています(パラメータは<code>getBlogOptionTop</code>を参照)。</p>
1718 <h3>[v3.2] getCategoryOptionTop($name, $amount = 10, $sort = 'desc')</h3>
1720 <p>与えられたオプションの最初の値を返します。結果は配列で、各要素がそれぞれのカテゴリーID ('id') の値 ('value') を持つ配列になっています(パラメータは<code>getBlogOptionTop</code>を参照)。</p>
1723 <h3>[v3.2] getItemOptionTop($name, $amount = 10, $sort = 'desc')</h3>
1725 <p>与えられたオプションの最初の値を返します。結果は配列で、各要素がそれぞれのアイテムID ('id') の値 ('value') を持つ配列になっています(パラメータは<code>getBlogOptionTop</code>を参照)。</p>
1729 <b>注:</b> プラグインクラス内のコンストラクタから、これらのファンクションを呼ぶことはできません。プラグインがロードされた後にこれらを実行したいときは、かわりに<code>init()</code>メソッド内に置きます。</div>
1731 <h1>データベース・テーブル<a name="tables" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
1733 <h2>Nucleusテーブルへのアクセス</h2>
1735 <p>v2.0まで、Nucleusテーブルへのアクセスは単に<code>nucleus_</code>と名づけられたテーブルに対してSQL命令を実行するだけのものでした。Nucleusのバージョン2.2以降はカスタム・テーブル名を利用できるようになったため、プラグイン開発に若干注意する必要があります。</p>
1738 <li><code>nucleus_item</code> などの固定されたテーブル名の代わりに、テーブル名のプレフィックスを生成するために <code>sql_table('item') </code>というグローバルファンクションを利用します。</li>
1739 <li><code>supportsFeature('SqlTablePrefix')</code> が呼ばれたときにプラグインが1(真)を返すようにします。これがないと、カスタムプレフィックスがセットされている場合でバージョンが2.0より大きいNucleusではプラグインをロードできません(用心のため)。</li>
1742 <p class="note">v2.0までのNucleusではグローバルファンクション <code>sql_table</code> は利用できないことに注意してください。もしこのメソッドを用いつつ、プラグインをv2.0以下のNucleusで動作させたい場合は、以下のコードをプラグインクラスの前に追加してください。</p>
1744 <pre class="example"><code><?
1746 // プラグインがNucleusバージョン2.0以下と互換性を持つために必要
1747 if (!function_exists('sql_table'))
1749 function sql_table($name) {
1750 return 'nucleus_' . $name;
1754 class NP_HelloWorld extends NucleusPlugin {
1762 <p>もしプラグイン独自のテーブルが必要なら、<code>install</code>メソッドの中で独自テーブルを生成し、<code>unInstall</code>メソッドの中でそれを削除するようにします。</p>
1766 <li><code>nucleus_plug_<em>plugname</em></code> のように、他のプラグインと競合しないテーブル名を考えてください。カスタムプレフィックスに対応するため、テーブル名を
1767 <code>sql_table('plug_plugname')</code> で生成してください。
1769 <li>自分自身でデータベース接続をする必要はありません。PHPコマンド <code>mysql_query()</code> を使ってSQL命令を実行できます。</li>
1770 <li>自分でデータベース接続をする場合、後でNucleusデータベースへの接続を復元するようにしてください。自前処理の後で <code>sql_connect()</code> を呼ぶことで可能です。頻繁な再接続を避けるために、コンストラクタでそれを行うのも良いです。<code>$this- >db</code>のリンクIDを保持でき、各クエリにそれを渡すことができます。</li>
1771 <li>バックアップ機能を使う時は、独自テーブルもバックアップに含めるよう、<code>getTableList()</code> を再定義してください。</li>
1774 <h1>プラグイン管理エリア<a name="admin" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
1776 <p>Ver2.5から、Nucleusの管理エリアに統合されたプラグイン管理エリアを作成できます。これらのページは従来のプラグイン管理ページや左側のクイックメニューからアクセスできます。</p>
1780 <p>管理エリアを提供するには、次のステップが必要です。</p>
1783 <li>プラグインディレクトリに<strong>プラグイン名</strong>のサブディレクトリを作ります。たとえばプラグイン名が<code>NP_PluginName</code>なら、'pluginname'です。ディレクトリ名はすべて小文字で!</li>
1785 そのディレクトリで、次のような<strong>index.php</strong>を用意します。
1788 // if your 'plugin' directory is not in the default location,
1789 // edit this variable to point to your site directory
1790 // (where config.php is)
1791 $strRel = '../../../';
1793 include($strRel . 'config.php');
1794 if (!$member->isLoggedIn())
1795 doError('You\'re not logged in.');
1797 include($DIR_LIBS . 'PLUGINADMIN.php');
1799 // create the admin area page
1800 $oPluginAdmin = new PluginAdmin('<strong>PluginName</strong>');
1801 $oPluginAdmin->start();
1803 echo '<h2>プラグイン名</h2>';
1805 echo '<p><strong>ページ内容</strong><p>';
1807 $oPluginAdmin->end();
1812 プラグイン側に次のコードを挿入し、クイックメニューイベントに登録します。
1813 <pre><code>function event_QuickMenu(&$data) {
1817 'title' => '<strong>プラグイン名</strong>',
1818 'url' => $this->getAdminURL(),
1819 'tooltip' => '<strong>ツールチップテキスト</strong>'
1826 <pre><code>function hasAdminArea()
1836 <li>登録できるからといって安易にクイックメニューへ登録しないこと。クイックメニューにプラグインが100個並んだりしたらかなりウンザリするでしょう。ですので、クイックメニューに登録する場合でも、クイックメニュー登録を有効・無効化するプラグインオプションを(グローバルまたはメンバーオプションで)用意することを考えてください。</li>
1837 <li><code>プラグインディレクトリが nucleus/plugins/ ではない場合は、index.php内の $strRel</code> 変数は手動で書き換える必要があります。</li>
1838 <li>管理エリアのアウトプットが<strong>正しいXHTML</strong>になっているか確認してください。正しくないと、MozillaなどのGeckoベースのブラウザでページ表示が崩れます。</li>
1841 <h2>PluginAdmin クラス</h2>
1843 <p><code>PluginAdmin</code> クラスは助けになります。これを一度生成すれば、<code>$oPluginAdmin->plugin</code> でプラグインのインスタンスにアクセスできます。</p>
1845 <h1>プラグイン用ヘルプページ <a name="help" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
1847 <p>Nucleus v3.2から、プラグインの機能の概要、利用できるスキン・テンプレート変数、さらに詳細な情報のありかなどを示すヘルプページを提供可能になりました。</p>
1849 <p>ヘルプページは管理画面のプラグイン一覧からアクセス可能になります。</p>
1852 <p>ヘルプページを提供するために、次のステップが必要です。</p>
1854 <li>プラグインディレクトリに、プラグイン名をつけたサブディレクトリを作成します。ディレクトリ名は小文字であることに注意します。<a href="#admin">管理エリア</a>を作るときと同様です。</li>
1855 <li>そのディレクトリの中に help.html を作り、プラグインについての文章を記述します。次の雛型からはじめると良いでしょう。
1856 <pre><code><h3>プラグインの概要</h3>
1858 <p>このプラグインはヘルプページがいかに機能するかを示すためだけのものです</p>
1860 <h3>インストール</h3>
1862 <p>これを読めてるならインストールは正しく出来てます :-)</p>
1864 <h3>スキン変数</h3>
1866 <p>このプラグインはただのテストケースなのでスキン・テンプレート変数はありませんが、書くとすれば。
1868 <ul><li><b><%HelpPageTestCase1%></b>: なにかをする</li>
1869 <li><b><%HelpPageTestCase1(foobar)%></b>: 別のなにかをする</li></ul></p>
1871 <h3>サポートとバグ報告</h3>
1873 <p>さらなるサポートやバグ報告のために、次のフォーラムのスレッドを利用してください。
1874 <a href="http://forum.nucleuscms.org/viewtopic.php?t=<トピックID>">
1875 http://forum.nucleuscms.org/viewtopic.php?t=<トピックID></a></p>
1877 <h3>バージョン履歴</h3>
1879 <ul><li>Version 0.1: 最初のテストケースバージョン</li>
1880 <li>Version 0.0: その前のバージョン ;-)</li></ul></code></pre>
1882 <li>supportsFeature('HelpPage') で0より大きい数字を返すように設定します。
1883 <pre><code>function supportsFeature($what) {
1894 <h1>プラグイン依存チェック <a name="dependency" href="#top" class="toplink"><img src="../icon-up.gif" width="15" height="15" alt="back to top" /></a></h1>
1896 <p>v3.2から、他のプラグインとの依存関係を宣言する新しいプラグインインターフェイスが追加されました。他のプラグインの機能を必要とするプラグインに利用できます。特に依存関係が成立しなくて正しく機能しない状態を検知するときに便利です。</p>
1898 <h2>この機能を利用するプラグインの書き方</h2>
1900 <p>現実世界での例からはじめましょう。</p>
1902 <p>NP_PageLinkList は NP_BlogWithOffset の機能を利用するため、利用者には NP_BlogWithOffset のインストール後に NP_PageLinkList をインストールさせたいとします。NucleusはこのAPIによって、インストール前に依存関係を検知させる方法をプラグインに提供します。</p>
1904 <p>このケースでは、NP_PageLinkList 側に NP_BlogWithOffset が必要だということを認識させるコードを埋め込みます。プラグインがインストールされる際に、Nucleusコアは <code>getPluginDep()</code> というファンクションを呼び出します。このファンクションは必要なプラグインのリストを返し、コアはインストール済みのプラグインをチェックして、もし依存関係に欠如があればインストールを拒否します。</p>
1906 <p>必要なことは NP_PageLinkList にこのファンクションを追加する、ただそれだけです。</p>
1908 <pre><code>function getPluginDep() {
1909 return array('NP_BlogWithOffset');
1912 <p>このプラグイン依存チェックは、他のプラグインが依存しているプラグインがアンインストールされることも防ぎます。</p>