2006年08月04日
[補足記事]Apache 2.0 の hook 一覧(apache module 開発事初め その3-3)
先日この記事において hook の呼び出しに関してコメントを頂きました.
実際のところよく分かってない部分もあったので,hook に関してまとめてみました.
実際のところよく分かってない部分もあったので,hook に関してまとめてみました.
このページの記述について
- このページの内容に関して
- 英語の文章は,全て Apache 2.0.58 のソースコード中から集めてきた原文ママです.
- 全ての hook に関して調べ尽くした訳じゃないので間違いもあると思います.間違いに気づかれた方はコメントで指摘いただければ幸いです m(_ _)m
- hook の呼び出し順序に関して
- hook が呼び出される順序は,「設定初期化」「プロセス初期化」「コネクション」「リクエスト」に関しては記述した順序で呼び出されるようです.
- RUN_ALL,RUN_FIRST について
- RUN_FIRST の hook は,呼び出した hook 処理関数が OK や
DECLINEエラーを返した場合,その次の hook 処理関数を呼び出しません. - RUN_ALL の hook は,呼び出した hook 処理関数がエラーを返さない限り,登録されている全ての hook 処理関数を呼び出します.
- hook 登録関数 ap_hook_xxx() の引数について
- ap_hook_xxx() への引数は全て同じです.内容については,こちらを参照ください.
- 登録する hook 処理関数のプロトタイプは,各 hook 登録関数の説明の下に併記しています.
Index
設定初期化 | |
---|---|
RUN_ALL | ap_hook_pre_config() |
RUN_ALL | ap_hook_open_logs() |
RUN_ALL | ap_hook_post_config() |
VOID | ap_hook_optional_fn_retrieve() |
プロセス初期化 | |
RUN_ALL | ap_hook_pre_mpm() |
VOID | ap_hook_child_init() |
コネクション | |
RUN_FIRST | ap_hook_create_connection() |
RUN_ALL | ap_hook_pre_connection() |
RUN_FIRST | ap_hook_process_connection() |
リクエスト | |
RUN_ALL | ap_hook_create_request() |
RUN_ALL | ap_hook_post_read_request() |
RUN_FIRST | ap_hook_quick_handler() |
RUN_FIRST | ap_hook_translate_name() |
RUN_FIRST | ap_hook_map_to_storage() |
RUN_ALL | ap_hook_header_parser() |
RUN_ALL | ap_hook_access_checker() |
RUN_FIRST | ap_hook_check_user_id() |
RUN_FIRST | ap_hook_auth_checker() |
RUN_FIRST | ap_hook_type_checker() |
RUN_ALL | ap_hook_fixups() |
VOID | ap_hook_insert_filter() |
RUN_FIRST | ap_hook_handler() |
RUN_ALL | ap_hook_log_transaction() |
エラー | |
VOID | ap_hook_insert_error_filter() |
VOID | ap_hook_error_log() |
必要時 | |
RUN_FIRST | ap_hook_default_port() |
RUN_FIRST | ap_hook_http_method() |
任意のタイミング? | |
RUN_ALL | ap_hook_fatal_exception() |
RUN_ALL | ap_hook_get_mgmt_items() |
RUN_FIRST | ap_hook_uexec_identity() |
説明
ap_hook_pre_config() | RUN_ALL | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Run the pre_config function for each module | |||||||||||
|
ap_hook_open_logs() | RUN_ALL | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Run the open_logs functions for each module | |||||||||||||
|
ap_hook_post_config() | RUN_ALL | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Run the post_config function for each module | |||||||||||||
|
ap_hook_optional_fn_retrieve() | |||
---|---|---|---|
Retrieve the optional functions for each module. This is run immediately before the server starts. Optional functions should be registered during the hook registration phase. | |||
|
ap_hook_pre_mpm() | RUN_ALL | |||||||
---|---|---|---|---|---|---|---|---|
Hook for post scoreboard creation, pre mpm. | ||||||||
|
ap_hook_child_init() | |||||||
---|---|---|---|---|---|---|---|
Run the child_init functions for each module | |||||||
|
ap_hook_create_connection() | RUN_FIRST | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
create_connection is a RUN_FIRST hook which allows modules to create connections. In general, you should not install filters with the create_connection hook. If you require vhost configuration information to make filter installation decisions, you must use the pre_connection or install_network_transport hook. This hook should close the connection if it encounters a fatal error condition. | |||||||||||||||||
|
ap_hook_pre_connection() | RUN_ALL | ||||||||
---|---|---|---|---|---|---|---|---|---|
This hook gives protocol modules an opportunity to set everything up
before calling the protocol handler. All pre-connection hooks are
run until one returns something other than ok or decline Apache の付属文書によれば,accept()直後に呼ばれる | |||||||||
|
ap_hook_process_connection() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook implements different protocols. After a connection has been established, the protocol module must read and serve the request. This function does that for each protocol module. The first protocol module to handle the request is the last module run. | |||||||
|
ap_hook_create_request() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
Gives modules a chance to create their request_config entry when the request is created. | |||||||
|
ap_hook_post_read_request() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
This hook allows modules to affect the request immediately after the request has been read, and before any other phases have been processes. This allows modules to make decisions based upon the input header fields | |||||||
|
ap_hook_quick_handler() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
Run the quick handler functions for each module. The quick_handler
is run before any other requests hooks are called (location_walk,
directory_walk, access checking, et. al.). This hook was added
to provide a quick way to serve content from a URI keyed cache. Apache の付属文書によれば,キャッシュモジュールが使用している. | |||||||
|
ap_hook_translate_name() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook allow modules an opportunity to translate the URI into an actual filename. If no modules do anything special, the server's default rules will be followed. | |||||||
|
ap_hook_map_to_storage() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook allow modules to set the per_dir_config based on their own
context (such as | |||||||
|
ap_hook_header_parser() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
Run the header parser functions for each module | |||||||
|
ap_hook_access_checker() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
This hook is used to apply additional access control to this resource. It runs *before* a user is authenticated, so this hook is really to apply additional restrictions independent of a user. It also runs independent of 'Require' directive usage. | |||||||
|
ap_hook_check_user_id() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook is used to analyze the request headers, authenticate the user, and set the user information in the request record (r->user and r->ap_auth_type). This hook is only run when Apache determines that authentication/authorization is required for this resource (as determined by the 'Require' directive). It runs after the access_checker hook, and before the auth_checker hook. | |||||||
|
ap_hook_auth_checker() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook is used to check to see if the resource being requested is available for the authenticated user (r->user and r->ap_auth_type). It runs after the access_checker and check_user_id hooks. Note that it will *only* be called if Apache determines that access control has been applied to this resource (through a 'Require' directive). | |||||||
|
ap_hook_type_checker() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This routine is called to determine and/or set the various document type information bits, like Content-type (via r->content_type), language, et cetera. | |||||||
|
ap_hook_fixups() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
Allows modules to perform module-specific fixing of header fields. This is invoked just before any content-handler | |||||||
|
ap_hook_insert_filter() | |||||
---|---|---|---|---|---|
This hook allows modules to insert filters for the current request | |||||
|
ap_hook_handler() | RUN_FIRST | ||||
---|---|---|---|---|---|
Run the handler functions for each module non-wildcard handlers should HOOK_MIDDLE, wildcard HOOK_LAST | |||||
|
ap_hook_log_transaction() | RUN_ALL | ||||||
---|---|---|---|---|---|---|---|
This hook allows modules to perform any module-specific logging activities over and above the normal server things. | |||||||
|
ap_hook_insert_error_filter() | |||||
---|---|---|---|---|---|
This hook allows modules to insert filters for the current error response | |||||
|
ap_hook_error_log() | |||
---|---|---|---|
|
ap_hook_default_port() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
Return the default port from the current request | |||||||
|
ap_hook_http_method() | RUN_FIRST | ||||||
---|---|---|---|---|---|---|---|
This hook allows modules to retrieve the http method from a request. This
allows Apache modules to easily extend the methods that Apache understands ここで言う"method" は scheme の間違いのようです.実際,Apache 2.2 では ap_hook_http_scheme() に変更されています. | |||||||
|
ap_hook_fatal_exception() | RUN_ALL | ||
---|---|---|---|
|
ap_hook_get_mgmt_items() | RUN_ALL | ||||||||
---|---|---|---|---|---|---|---|---|---|
This hook provdes a way for modules to provide metrics/statistics about their operational status. | |||||||||
|
ap_hook_get_suexec_identity() | RUN_FIRST | ||
---|---|---|---|
|
トラックバックURL
この記事へのトラックバック
1. ap_hook_translate_name() にフックをかける場合は http_request.h をインクルードしよう [ 日々のこと ] 2009年08月11日 23:49
Apacheモジュールを開発する際にフックをかけるタイミングがたくさんあります...
この記事へのコメント
1. Posted by ありあり 2007年11月27日 15:32
RUN_FIRSTの場合、DECLINE(D)を返した場合は、次のフック関数を実行します。
以下、apr_hooks.h
#define APR_IMPLEMENT_EXTERNAL_HOOK_RUN_FIRST(ns,link,ret,name,args_decl,args_use,decline) \
APR_IMPLEMENT_EXTERNAL_HOOK_BASE(ns,link,name) \
link##_DECLARE(ret) ns##_run_##name args_decl \
{ \
ns##_LINK_##name##_t *pHook; \
int n; \
ret rv; \
\
if(!_hooks.link_##name) \
return decline; \
\
pHook=(ns##_LINK_##name##_t *)_hooks.link_##name->elts; \
for(n=0 ; n < _hooks.link_##name->nelts ; ++n) \
{ \
rv=pHook[n].pFunc args_use; \
\
if(rv != decline) \
return rv; \
} \
return decline; \
}
以下、apr_hooks.h
#define APR_IMPLEMENT_EXTERNAL_HOOK_RUN_FIRST(ns,link,ret,name,args_decl,args_use,decline) \
APR_IMPLEMENT_EXTERNAL_HOOK_BASE(ns,link,name) \
link##_DECLARE(ret) ns##_run_##name args_decl \
{ \
ns##_LINK_##name##_t *pHook; \
int n; \
ret rv; \
\
if(!_hooks.link_##name) \
return decline; \
\
pHook=(ns##_LINK_##name##_t *)_hooks.link_##name->elts; \
for(n=0 ; n < _hooks.link_##name->nelts ; ++n) \
{ \
rv=pHook[n].pFunc args_use; \
\
if(rv != decline) \
return rv; \
} \
return decline; \
}
2. Posted by かつみ 2007年11月27日 16:35
ありありさんコメントありがとうございます.
挙げていただいたマクロ定義は,apache が hook を定義するためのマクロですね.RUN_ALL の hook も同様のマクロを使って定義されています.
で,ご指摘の頂いているのはこの記事での説明で,RUN_FIRST 用の hook 処理関数が DECLINE を返したときの動作に関しての事かと思います.
確認してみたところ確かに間違っておりましたので,修正いたしました.
ご指摘ありがとうございました.
挙げていただいたマクロ定義は,apache が hook を定義するためのマクロですね.RUN_ALL の hook も同様のマクロを使って定義されています.
で,ご指摘の頂いているのはこの記事での説明で,RUN_FIRST 用の hook 処理関数が DECLINE を返したときの動作に関しての事かと思います.
確認してみたところ確かに間違っておりましたので,修正いたしました.
ご指摘ありがとうございました.