コメントを管理者が編集したときに、編集したコメントの著者を管理者に変更する
解決済
回答 1
投稿
- 評価
- クリップ 0
- VIEW 1,028
管理者以外が投稿したコメントを管理者が編集したときに、そのコメントの著者(厳密にはuser_ID
?)を管理者に変更したいです。
フィルターのcomment_save_pre
にフックして、コメントが編集されたときに編集者が管理者権限を持っていて、尚且つ編集するコメントが管理者権限を持つ編集者以外だったらuser_ID
をその編集者(管理者)のものに書き換える処理にしたら良いのかなという大まかなイメージはあるのですが、具体的なコードが思いつかずに行き詰まっています。
コードの実例やアドバイスなど、何かしらの回答を頂けると嬉しく思います。
よろしくお願い致します。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
+1
多分こんな感じでいけるのでは。
// ID書き換え
function my_pre_user_id( $user_id ) {
if ( is_user_logged_in() ) {
$user = wp_get_current_user();
if ( $user->ID && $user->ID === 1 ) { // 書き換えたいユーザーIDを指定
$user_id = $user->ID;
}
}
return $user_id;
}
add_filter( 'pre_user_id' , 'my_pre_user_id' );
【pre_user_id | Hook | WordPress Developer Resources】
https://developer.wordpress.org/reference/hooks/pre_user_id/
// 名前も書き換え
function my_pre_comment_author_name( $name ) {
if ( is_user_logged_in() ) {
$user = wp_get_current_user();
if ( $user->ID && $user->ID === 1 ) { // 書き換えたいユーザーIDを指定
$name = $user->display_name; // 表示名( $user->first_name / $user->last_name も使用可)
}
}
return $name;
}
add_filter( 'pre_comment_author_name', 'my_pre_comment_author_name' );
【pre_comment_author_name | Hook | WordPress Developer Resources】
https://developer.wordpress.org/reference/hooks/pre_comment_author_name/
pre_comment_author_name と pre_user_id は wp_filter_comment の中で呼ばれていて、wp_new_comment / wp_update_comment 双方から呼ばれているため、新規投稿でも更新でもフックが呼ばれます。
【comment.php in tags/4.5/src/wp-includes - WordPress Trac】
https://core.trac.wordpress.org/browser/tags/4.5/src/wp-includes/comment.php#wp_filter_comment
管理者のみに絞り込んでいるこの箇所
if ( $user->ID && $user->ID === 1 ) {}
は
if ( $user->ID && $user->has_cap( 'install_plugins' ) ) {}
/* OR */
if ( $user->ID && in_array( 'administrator', (array) $user->roles ) ) {}
と書いたほうがより汎用性が高いので追記。
追記:
コメントにflatさんが書かれていた通り、is_admin()
を使えば管理画面に絞れますよね、気付きませんでした。コメント周りのコードを追っていて更新時のみにする方法を思いついたので追記しておきます。'preprocess_comment'
は新規コメントにのみ使われるフックでかつ wp_filter_comment()
の前に実行されるので、そこで pre_comment_author_name
pre_user_id
のフィルターを外してしまう戦略です。
テストしていないので、きちんと動いた方のコードを優先して使ってください。(すいません、自己満足です)
function my_preprocess_comment( $commentdata ) {
if ( is_admin()
&& is_user_logged_in()
&& current_user_can( 'administrator' )
&& isset( $commentdata[ 'comment_ID' ] ) // 確実に新規コメント時にしか実行されないはずだが 'comment_ID' が入っていないことを確認(問題無ければ削除してもよい)
&& $commentdata[ 'comment_ID' ] > 0 // 〃
) { // 新規投稿のみフックを無効化
remove_filter( 'pre_user_id' , 'my_pre_user_id' );
remove_filter( 'pre_comment_author_name', 'my_pre_comment_author_name' );
}
return $commentdata;
}
add_filter( 'preprocess_comment' , 'my_preprocess_comment' );
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.35%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
2016/04/17 00:25 編集
IDだけでなく著者名にも対応して下さり大変感謝しています。
>新規投稿でも更新でもフックが呼ばれます。
更新時のみ適用というのが理想ですが、こればかりは仕方ないですね。
このようなフックがあることに全く気づいていなかったので大変助かりました。
ちなみに、回答して下さったコードは一部を次のように書き換えて使うことにしました。
if (is_admin() && is_user_logged_in() && current_user_can('administrator') && get_current_user_id() === 1) {
$user = wp_get_current_user();
$user_id = $user->ID;
}
ずっと疑問に思いながら考え続けていたので本当に助かりました。
ありがとうございました。
---
このコメントを書いた後で追記に気付いてしまいました。
少し悩みますが、問題が無さそうに見えるのでとりあえずこのままのコードにしてみようと思います。
2016/04/17 18:13
2016/04/18 19:06 編集
追記して下さったコードですが、新規投稿時は無条件でフィルターを無効化したかったので、条件分岐を除いて利用することにしました。
動作の方もきちんと新規投稿時にフィルターが無効化され、更新・編集時にはフィルターが適用されていることを確認しました。
また、書き換えを行う関数の条件分岐なのですが、get_current_user_id() が「ログイン済みユーザーのIDを取得」する関数なので is_user_logged_in() は外すことにしました。
あとは get_current_user_id() でユーザーを特定しているので current_user_can('administrator') も動作的には外して良いのですが、やはり管理者権限を持っているかどうかはきちんと判別しておきたいので残しました。
追加の回答を頂いたことで新たな改善点にも気付くことができ、とても有意義な機会を得ることができました。
親切な心遣いに心より感謝致します:)