プロジェクト

全般

プロフィール

Bug(バグ) #4188

完了

アクティビティガジェット Web公開していない投稿がWeb公開されてしまう

kaoru n さんが7年以上前に追加. 5年以上前に更新.

ステータス:
Fixed(完了)
優先度:
High(高め)
担当者:
対象バージョン:
開始日:
2017-04-21
期日:
進捗率:

100%

予定工数:
3.6 で発生するか:
Yes (はい)
3.8 で発生するか:
Yes (はい)

説明

Overview (現象)

プロフィール画面のガジェット設定で、アクティビティガジェットを「web全体に公開」に設定した場合、
タイムラインへの投稿時に「全員に公開」で設定した投稿が、プロフィール画面でWeb全体に公開される。

各バージョンごとの動作確認

背景赤色がこのチケットの修正対象。
背景オレンジは通常バグであるので、このチケットの修正公開後に通常バグとしてチケット作成する。
「エラー(※)」は通常バグであるので、このチケットの修正公開後に通常バグとしてチケット作成する。

再現手順

  1. 管理画面→上級者向け設定(3.6.x の場合はSNS設定)→メンバーのプロフィールページ公開範囲設定 を 「メンバーの設定を許可する」もしくは「メンバーの設定を許可しない(Web全体に公開)」に設定
  2. 管理画面→デザイン設定→ガジェット設定→プロフィール画面ガジェット設定→ガジェット追加 にて アクティビティ を追加し、設定変更ボタンを押下
  3. アクティビティの設定画面を開き公開範囲を「Web全体に公開」に変更し submit ボタンを押下
  4. メンバーAのアカウントでSNSメンバー画面にログインし、タイムラインにて「全員に公開」で投稿
  5. SNSメンバー画面をログアウトするか、別のブラウザにて、「/member/{メンバーAのID}」を確認

Causes (原因)

プロフィールページの公開範囲及びガジェットの公開範囲を考慮していないため

Way to fix (修正内容)

修正内容を記入

--

補足

・OpenPNE-3.6.x では JSON API がないため opTimelinePlugin は動作しない
・タイムライン・アクティビティにて Web公開して投稿するためには、OpenPNE.yml に、「activity_is_open: true」を設定する必要がある


ファイル

t4188.png (68.5 KB) t4188.png kaoru n, 2018-01-15 14:24

関連するチケット 1 (0件未完了1件完了)

関連している OpenPNE 3 - Bug(バグ) #4260: opTimelinePlugin 携帯版プロフィール画面のSNSメンバーのタイムラインガジェット Web公開していない投稿がWeb公開されてしまうFixed(完了)kaoru n2017-11-15

操作

kaoru n さんが約7年前に更新

  • 題名opTimlinePlugin Web公開していない投稿がWeb公開されてしまう から アクティビティガジェット Web公開していない投稿がWeb公開されてしまう に変更

kaoru n さんが約7年前に更新

kaoru n さんが約7年前に更新

kaoru n さんが約7年前に更新

  • 説明 を更新 (差分)
  • ステータスNew(新規) から Accepted(着手) に変更
  • 担当者kaoru n にセット

kaoru n さんが約7年前に更新

  • 関連している Bug(バグ) #4260: opTimelinePlugin 携帯版プロフィール画面のSNSメンバーのタイムラインガジェット Web公開していない投稿がWeb公開されてしまう を追加

kaoru n さんがほぼ7年前に更新

  • ステータスAccepted(着手) から Pending Review(レビュー待ち) に変更
  • 進捗率0 から 50 に変更

kaoru n さんがほぼ7年前に更新

kaoru n さんがほぼ7年前に更新

  • 3.6 で発生するかUnknown (未調査) から Yes (はい) に変更

Rimpei Ogawa さんが5年以上前に更新

  • ステータスPending Review(レビュー待ち) から Rejected(差し戻し) に変更

非ログインユーザーに関しては一律で、
$flag = self::PUBLIC_FLAG_OPEN;
となるべきで、

間違っているのは、修正部分よりも手前の、

    if (is_null($viewerMemberId))
    {
      $flag = self::PUBLIC_FLAG_OPEN;
    }

https://github.com/openpne/OpenPNE3/blob/master/lib/model/doctrine/ActivityDataTable.class.php#L311
の部分だと思います。

おそらく opAnonymousMember::getId()null ではなく 0 を返すので、動いていない。

member_id は存在する場合は 1 以上の整数なので、null or 0 を弾く意味で、
if (!$viewerMemberId) {
でよいと思います。

このファイル内、他にもメンバーIDに対してNULLチェックをかけていてかなり怪しそう・・・

kaoru n さんが5年以上前に更新

  • ステータスRejected(差し戻し) から Pending Review(レビュー待ち) に変更

Rimpei Ogawa さんが5年以上前に更新

  • ステータスPending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
  • 進捗率50 から 70 に変更

レビューOKです。

Chiharu Nakajima さんが5年以上前に更新

  • ステータスPending Testing(テスト待ち) から Pending Merge(マージ待ち) に変更
  • 進捗率70 から 80 に変更

動作確認OKです

kaoru n さんが5年以上前に更新

  • ステータスPending Merge(マージ待ち) から Fixed(完了) に変更
  • 進捗率80 から 100 に変更

マージしました

kaoru n さんが5年以上前に更新

  • プロジェクト22 から OpenPNE 3 に変更
  • カテゴリ を削除 (権限不備)
  • 対象バージョンOpenPNE 3.8.32 にセット

isao sano さんが5年以上前に更新

  • 対象バージョンOpenPNE 3.8.32 から OpenPNE-3.9.5 に変更

isao sano さんが5年以上前に更新

  • 対象バージョンOpenPNE-3.9.5 から OpenPNE 3.8.32 に変更

他の形式にエクスポート: Atom PDF