用户无法将他人添加到私人消息中

这是我刚刚在 TPM 创建的一个示例:

我刚刚试着给你发了一条消息,结果在这里显示如下:

虽然我现在不在 TL2,但在 TPM 我是 TL3 级别(一位版主为了测试把我提升到了这个级别)。

因此,当我作为发送者时,我无法移除自己(这很合理),也无法移除其他人;而当我作为接收者时,我只能移除自己,但在 TPM 上并没有通过“+”按钮添加其他人的选项……

1 个赞

这是我找到的情况:

  • TL2+ 用户可以将其他用户添加到私信中,无论他们是话题发起者还是收件人。
  • TL1 私信创建者无法添加或移除用户。
  • TL1 私信收件人可以移除自己,但无法添加新用户。

根据我们的信任等级说明,上述行为似乎是正确的(已加粗强调):

@laughingriver 最好的做法是先更新网站。之后我们可以尝试找出可能存在的其他影响因素。

7 个赞

说到这个,@sam,我们或许可以考虑添加以下某种功能:

  • 开启一个“封闭”的私信,除管理员外,任何人都无法添加或移除成员
  • 仅私信所有者可添加或移除成员(管理员除外)

我认为这比在这里折腾 TL2/TL3 权限更有用。

8 个赞

好的,如果这是网站更新的问题,考虑到 TPM 更新频率很高,那可能需要很长时间了。

那些信任级别设置是在他们升级到 2.3.0 版本之前发布的,所以我原以为这些设置已经生效了好几个版本了……

2 个赞

在我们的网站上,我们已关闭“启用个人消息”功能,因为必须防止成年人在未抄送家长或其他成年人的情况下向未成年人发送消息。我们确实使用个人消息在版主和用户之间进行沟通。

我们遇到的问题是:当点击现有消息的“添加或删除”时,只能移除收件人,无法添加新收件人。请问是否需要设置其他选项?或者,由于我们关闭了“启用个人消息”功能,导致添加收件人(即使是版主和管理员)也被禁用了?

感谢您的帮助。

6 个赞

我今天早些时候也调查过类似的问题:https://meta.discourse.org/t/unable-to-add-user-to-pm-topic/162945。在那种情况下,我发现的问题是,如果“每日最大邀请数”设置为 0,普通用户无法邀请用户加入私信。而在您的案例中,问题可能出在“启用私信”这一站点设置上。当该设置被禁用时,只有管理员可以向现有私信中添加用户。如果“启用私信”被禁用,版主也无法向私信中添加用户。

您能否再次确认一下,管理员是否能够在您的网站上向私信中添加用户?要实现这一点,管理员必须是发起该私信的用户。

我相当确定这种行为是有意为之,因为代码中已明确写入。我不确定在禁用“启用私信”站点设置时,阻止版主向私信中添加用户背后的考量是什么。这或许是可以更改的。

我会在我们的开发者这里留个备注,以防有人想查看。问题出现在这里:discourse/lib/guardian.rb at main · discourse/discourse · GitHub

9 个赞

我测试了用管理员账号创建新的私信并添加用户,操作成功。

如果版主也能在“启用私信”功能被禁用的情况下发起私信时添加用户,那就更好了。

2 个赞

是否考虑过增加一个选项(或 simply 移除该限制),以便在“启用个人消息”功能被禁用的情况下,允许工作人员将用户添加至他们发起的私人消息中?

2 个赞

大家好,

几周前的一次更新后,我们开始遇到这个问题。用户可以移除他们拥有的私信中的其他参与者,但无法再添加任何用户:

邀请权限设置为所有 TL2 级别的用户(我的测试用户具备该级别),并且已启用“允许个人消息”。每日最大邀请数设置为 10。我尚未发现导致此问题的其他原因。

有什么想法吗?谢谢!

3 个赞

我也在最新的提交中看到了这个行为 :cry:

3 个赞

@tshenry 我们能否在此复现任何问题?

3 个赞

一篇帖子被拆分到了一个新主题:为什么邀请与私信如此紧密地关联?

我今天抽空稍微调查了一下这个问题,但无法复现所描述的行为。我尝试了三种消息场景,使用了提到的设置(PM 已启用,TL2 每天最多可邀请 10 次):

  1. 管理员 –\u003e TL2 :white_check_mark:
  2. TL2 –\u003e 管理员 :white_check_mark:
  3. TL2 –\u003e TL2 :white_check_mark:

我尝试查看后续回复是否会破坏添加新用户的能力,但有趣的是,上述所有场景都显示所有者和参与者都有“添加”选项。如果要说有什么的话,我觉得目前的设置有点太宽松了。

唯一出现“移除”按钮但没有“添加”选项的情况是,当我作为某人发起的 PM 的 TL1 参与者时。我可以移除自己,但无法添加或移除其他人。

@sdpiowa @diakopter 你们仍然看到这个问题吗?如果是的话,能否帮我梳理一些详细的复现步骤,以便我尝试?

3 个赞

是的,我将研究相关人员的语言等级(TL)和设定。我相信所有账号都是TL2,但我已针对某些情况调整了最低语言等级设定。我很快会再联系您。

3 个赞

您好,

在我们的论坛(由 Discourse 托管)上,我们也遇到了同样的问题。我们的站点已禁用“邀请”功能(即允许用户通过电子邮件向非用户发送邀请),并且个人消息现在仅显示“移除…”按钮(针对非管理员用户)。简要查看此处链接的代码:

我猜测,目前没有专门的代码(函数或分支)来测试用户是否有权邀请他人加入现有的个人消息。也许这个“测试”最初是以某种方式偶然处理的,而在最近的更新后,行为发生了变化,但这是无意的(作为副作用)?如果能将其转化为管理员仪表板上的独立设置(“允许主题发起者向现有个人消息线程添加用户?”和“允许任何参与者向现有个人消息线程添加用户?”),那就太好了……

3 个赞

以上信息对 @tshenry 有帮助吗?

2 个赞

有可能!我还没有机会再次深入调查。我会将其优先级调高,并争取明天处理。

4 个赞

您在这方面有任何进展吗?我刚更新到最新版本,但行为似乎没有变化。

从我的角度来看,关键在于“必须批准用户”设置与邀请外部人员或现有用户加入项目(PMs)之间的交互。

3 个赞

抱歉让大家久等,我们已指派工程师处理该问题。问题将很快得到解决。

4 个赞

我认为邀请加入主题(现有用户)和论坛(新用户)是两回事,应分别处理。我已提交一个拉取请求来修改此问题:

8 个赞