この記事は最後に更新してから1年以上経過しています。

5.3の新機能:サイト管理者のメールアドレスを定期的に確認する

説明

WordPress 5.3 Beta 1」に記載されていた「Admin Email Verification」の項目が目に留まる。管理者のメールアドレスを定期的に確認するという仕組みがどんなものなのか気になったので、ちょっと調べてみた。

wp-login.phpが機能拡張

はじめに、この記事は公開された5.3 Beta1をもとにしており、正式リリースの際に変更される可能性があることを予めお断りする。

まずはメールアドレスの確認ページを見てみたいので、ソースコードを調べてみる。wp-login.phpの中にそれっぽい記述が見つかり、管理ページにログインした状態で、ブラウザのアドレスバーに「http://localhost/wp-login.php?action=confirm_admin_email」とタイプする。

メールアドレスの確認ページ

このページで「The emails is correct」ボタンをクリックすると「Dashboard(ダッシュボード)」ページへ遷移する。また「Update」ボタンをクリックすると「General Settings(一般設定)」ページへ遷移するため、この機能の「サイト管理者のメールアドレス」とはログイン中のユーザー(管理者)のものではないことがわかる。

メールアドレスの有効期限

メールアドレスの確認ページが表示されるタイミングは、ログインページでID・パスワード認証した後、管理ページにリダイレクトする直前となる。その際、次の条件を満たしている場合にメールアドレスの確認ページが表示される仕組みになっていた。

  1. ID・パスワード認証したユーザーが管理者('manage_options'権限(能力)を所有する)
  2. 管理者のメールアドレスの確認間隔('admin_email_check_interval'フィルター)が0より大きい(標準で180日)
  3. 管理者のメールアドレスが有効期限が切れている

3の有効期限については、5.3にアップデートした際のデータベース更新により、オプション名'admin_email_lifespan'として180日が設定されている。これによりアナウンス通りに5.3が2019年11月12日に公開され、すぐにサーバーをアップデートしたとしてもメールアドレスの確認ページが表示されるのは2020年5月10日以降となる。サイト管理者としてすぐに動作確認したい場合、テーマのfunctions.phpに次のようなコードを追加し、'admin_email_lifespan'の値を適当に更新すればよい。

update_option( 'admin_email_lifespan', time() + 10 );

確認ページを表示させない

メールアドレスの確認ページを表示させるタイミングは、先の表示条件を示したように'admin_email_check_interval'フィルターを利用することで調整できる。

メールアドレスの確認ページを表示させたくない場合は、次のようにフィルターで0を返せばよい。

add_filter( 'admin_email_check_interval', '__return_zero' );

表示間隔を180日以外にしたい場合も同様だが、その場合はフィルター関数を用意することになる。例えば30日間隔にしたい場合は次のようになる。

function admin_email_check_interval_to_30days( $interval ) {
	return 30 * DAY_IN_SECONDS;
}

add_filter( 'admin_email_check_interval', 'admin_email_check_interval_to_30days' );

なお'admin_email_check_interval'フィルターの値は、メールアドレスの確認ページで「The emails is correct」ボタンをクリックした際に更新されるオプション名'admin_email_lifespan'の値に影響し、それが次回の表示タイミングとなる。


ここで紹介した新機能は「Login rebuilder」が影響を与える可能性があったため率先して調べてみた。とりあえず、最新版のプラグインで問題なく機能することが確認でき、一安心といったところである。


最終更新 : 2019年09月27日 09:14

お勧め

wp_save_post_revision(2024年1月10日 更新)

int | WP_Error | void wp_save_post_revision( int $post_id )
現状の投稿のリビジョンを作成する。

get_the_author_posts_link(2019年8月21日 更新)

string get_the_author_posts_link( )
投稿者アーカイブページのリンクを取得する。

get_year_link(2012年2月2日 更新)

string get_year_link( mixed $year )
年アーカイブのURLを取得する。

register_taxonomy(2022年6月1日 更新)

WP_Taxonomy | WP_Error register_taxonomy( string $taxonomy, array | string $object_type, array | string $args = array() )
タクソノミーを登録する。

wp_add_object_terms(2013年8月6日 更新)

mixed wp_add_object_terms( int $object_id, mixed $terms, mixed $taxonomy )
投稿情報などにタクソノミーを追加する。