とほほのDrupal入門

目次

Hook関数一覧

custom_url_rewrite_inbound / custom_url_rewrite_outbound / hook_access / hook_actions_delete / hook_action_info / hook_action_info_alter / hook_block / hook_boot / hook_comment / hook_cron / hook_db_rewrite_sql / hook_delete / hook_disable / hook_elements / hook_enable / hook_exit / hook_file_download / hook_filter / hook_filter_tips / hook_flush_caches / hook_footer / hook_form / hook_forms / hook_form_alter / hook_form_FORM_ID_alter / hook_help / hook_hook_info / hook_init / hook_insert / hook_install / hook_link / hook_link_alter / hook_load / hook_locale / hook_mail / hook_mail_alter / hook_menu / hook_menu_alter / hook_menu_link_alter / hook_nodeapi / hook_node_access_records / hook_node_grants / hook_node_info / hook_node_operations / hook_node_type / hook_perm / hook_ping / hook_prepare / hook_profile_alter / hook_requirements / hook_schema / hook_schema_alter / hook_search / hook_search_preprocess / hook_system_info_alter / hook_taxonomy / hook_term_path / hook_theme / hook_theme_registry_alter / hook_translated_menu_link_alter / hook_uninstall / hook_update / hook_update_index / hook_update_N / hook_update_status_alter / hook_user / hook_user_operations / hook_validate / hook_view / hook_watchdog / hook_xmlrpc / module_hook / module_implements / module_invoke / module_invoke_all

主なHook関数

xxx_help()

ヘルプを表示します。下記の例により、[管理セクション]→[ヘルプ] に Testモジュールが追加されます。パスは http://~/?q=admin/help/test となります。Drupal 5.x と 6.x では引数が変更されています。

function test_help($path, $arg) {
  switch ($path) {
    case 'admin/help#test':
      $output = '<p>' . t('This is TEST module.') . '</p>';
      return $output;
  }
}

xxx_menu()

ナビゲーションリンクへのメニューを設定します。下記の例ではナビゲーションリンクのトップに TEST メニューが表示されます。メニューが実行されると test_main() が呼び出されます。このメニューは 'do test' 権限を持っているユーザが実行できます。$item['test'] を $item['admin/build/test'] とすると、[管理セクション]→[サイトの構築]→[TEST] メニューが追加されます。

function test_menu() {
  $item['test'] = array(
    'title' => 'TEST',
    'page callback' => 'test_main',
    'access arguments' => array('do test'),
  );
  return $item;
}

xxx_perm()

[管理セクション]→[ユーザの管理]→[権限] で参照可能な権限を追加します。

function test_perm() {
  return array('do test');
}

xxx_init()

ページが開かれる度に呼び出されます。必要とするCSSファイルやJavaScriptファイルを追加する場合に便利です。

function test_init() {
  drupal_add_css(drupal_get_path('module', 'test') . '/test.css');
}

xxx_cron()

cron.php が実行された時に実行されます。

function test_cron() {
  :
}

xxx_enable()

モジュールが有効化された時に実行されます。

function test_enable() {
  :
}

xxx_disable()

モジュールが無効化された時に実行されます。

function test_disable() {
  :
}

ページのフッタに追加するHTMLを指定します。ページ末尾に JavaScript コードを埋め込むのにも使用されます。フロントページの時 $main は 0 になります。

function test_footer($main) {
  return '<div>See you!</div>';
}

xxx_block()

モジュールがブロックをサポートする場合に定義します。$op = 'list' は、[管理セクション]→[サイトの構築]→[ブロック] で表示される名前を定義します。$op = 'view' は、そのブロックが表示される際に $block->subject と $block->content で参照されるHTMLを定義します。subject と content 以外にも任意のブロック変数を増やすことができます。複数のブロックをサポートする場合、$delta が 0, 1, 2... と変化します。

function test_block($op = 'list', $delta = 0) {
  if ($op == 'list') {
    $blocks[0] = array(
      'info' => t('Test block'),
    );
    return $blocks;
  }
  if ($op == 'view') {
    if ($delta == 0) {
      $block = array(
        'subject' => t('Test block'),
        'content' => t('Hello World'),
      );
    }
    return $block;
  }
}

xxx_watchdog()

syslog に記録するような何らかのイベントが発生した際に呼び出されます。

function test_watchdog($log_msg) {
  $msg =
    "---------------------\n";
    "Severity: {$log_msg['severity']}\n" .
    "Time: " . format_date($log_msg['timestamp']) . "\n" .
    "Type: {$log_msg['type']}\n" .
    "Ip Address: {$log_msg['ip']}\n" .
    "Message: {$log_msg['message']}\n" .
    "Name: {$log_msg['user']->name}\n" .
    "Uid: {$log_msg['user']->uid}\n" .
    "Link: {$log_msg['link']}\n" .
    "Request URI: {$log_msg['request_uri']}\n" .
    "Referrer URI: {$log_msg['referer_uri']}\n" .
    "---------------------\n";

  $log = fopen("/tmp/xx", "a");
  fwrite($log, "test_watchdog()\n");
  fwrite($log, $msg);
  fclose($log);
}

Search モジュールから呼び出されます。'name' ではサーチ画面のに表示するサブメニューを、'search' ではサーチ結果を返します。

function test_search($op = 'search', $keys = NULL, $skip_access_check = FALSE) {
  switch ($op) {
    case 'name':
      return 'Test';
      break;
    case 'search':
      $find = array();
       $result = db_query("SELECT name FROM {users} WHERE name = '%s'", $keys);
       while ($data = db_fetch_object($result)) {
         $find[] = array(
           'title' => $data->name,
           'link' => $data->name,
         );
      }
      return $find;
      break;
  }
}

xxx_node_info()

下記を記述しておくと、[コンテンツの作成] メニューの下に Test コンテンツの追加メニューが表示されます。

function test_node_info() {
  return array(
    'test' => array(
      'name' => 'Test',
      'module' => 'test',
      'description' => 'Test is my contents.',
    ),
  );
}

その他のHook関数

その他のフック関数については下記を参照してください。