Bug(バグ) #2353
完了ログインしてくださいというアラートが表示され続ける
100%
説明
Overview (現象)¶
未ログイン状態で閲覧にログインが必要なページにアクセスすると「ログインしてください」というアラートが表示されるが、その後、閲覧にログインが不要なページ(例:Web全体に公開の日記)にアクセスするとアラートが表示されたままになってしまう。
閲覧にログインが不要なページなのにこのようなアラートが表示されるのは不適切であると考えられる。
再現バージョン¶
- OpenPNE3.7 masterブランチ
- OpenPNE3.6beta13-dev
- OpenPNE3.4.15-dev
再現手順¶
1.メンバーAで未ログインの状態でログイン必要なページにアクセスする
(例:未ログイン状態で diary/new にアクセスする)
2.ログインしてくださいというアラートが表示されることを確認する
3.手順3の状態でweb全体に公開されている日記にアクセスする
4.「ログインしてください」の表示がされたままになる
Causes (原因)¶
ログインアクション(member/login)において、「ログインしてください」メッセージを
$this->getUser()->setFlash()を利用してセットしているが
上記メソッドは次のアクションまでセットされたメッセージを保持するため
ログイン画面から別のページ(ログイン画面に再度アクセスした場合も含む)に行った場合でも
メッセージが表示され続けてしまっている
Way to fix (修正内容)¶
$this->getUser()->setFlash()の第3引数($persist)をfalseにする
ファイル
Maki Takahashi さんが13年以上前に更新
- ステータス を New(新規) から Accepted(着手) に変更
- 担当者 を Maki Takahashi にセット
Maki Takahashi さんが13年以上前に更新
- ステータス を Accepted(着手) から Pending Review(レビュー待ち) に変更
- 進捗率 を 0 から 50 に変更
commit: a4bd10e2 にて修正いたしました。
再現手順を実行し、「ログインしてください」アラートが表示されている状態で
全体に公開の日記にアクセスした際に、アラートが表示されないことを確認しています。
Rimpei Ogawa さんが13年以上前に更新
- ステータス を Pending Review(レビュー待ち) から Rejected(差し戻し) に変更
チケット表題の問題についての修正内容はレビューしましたが問題ありません。
ただ、masterブランチの a4bd10e2 時点のソースコード(バンドルプラグイン含む)で調べたところ、以下の2箇所で同様の原因でエラーメッセージが画面遷移後に残る問題が発生する可能性があります。
mailActions::executeTemplate()
apps/pc_backend/modules/mail/actions/actions.class.php 68: $this->getUser()->setFlash('error', (string)$this->form->getErrorSchema()); 69- } 70- }
opCommunityTopicPluginEventCommentActions::executeCreate()
plugins/opCommunityTopicPlugin/lib/action/opCommunityTopicPluginEventCommentActions.class.php 67: $this->getUser()->setFlash('error', $e->getMessage()); 68- } 69- } 70- 71- $this->setTemplate('../../communityEvent/templates/show'); 72- 73- return sfView::SUCCESS; 74- }
Maki Takahashi さんが13年以上前に更新
- ステータス を Rejected(差し戻し) から Accepted(着手) に変更
note-9 について、それぞれチケットを作成いたします。
Maki Takahashi さんが13年以上前に更新
- ステータス を Pending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
- 進捗率 を 50 から 70 に変更
本チケットの修正内容につきましては、すでにレビューいただき問題ないとのことですので
テスト待ちにいたします
Yuma Sakata さんが約13年前に更新
- ステータス を Pending Testing(テスト待ち) から Fixed(完了) に変更
- 進捗率 を 70 から 100 に変更
テストOKです。