0

我正在通过 API http 向 muc room 发送消息。我观察到get_room_occupants加入 muc room 的用户可能会这样做。

现在,从 ejabberd muc room 我发现团队成员在那里但不是团队的成员,这就是为什么Only occupants are allowed to send messages to the conference虽然是团队成员却显示此错误。

是否有任何 api 可以将我连接到 muc 并在居住者中显示我?

Ejabberd 版本:17.11 安装在:ubuntu 16.04 配置数据库:mysql

Ejaberd.yml

api_permissions:
  "console commands":
    from:
      - ejabberd_ctl
    who: all
    what: "*"
  "admin access":
    who: all
    what:
      - "*"
      - "!stop"
      - "!start"
  "public commands":
    who: all
    what:
      - "*"
commands_admin_access:
  - allow:
    - user: "xxx@yy.zz"
commands:
  add_commands:
    - status
    - registered_users
    - register
    - unregister
    - get_roster
    - connected_users
    - send_stanza_c2s
    - send_stanza
    - join_cluster
oauth_expire: 3600
oauth_access: all
4

1 回答 1

1

在 MUC 服务中具有管理员权限的帐户可以向任何房间发送消息,无需成为房间占用者。

例如,使用此配置:

acl:
  admin:
    user:
      - "user1@localhost"
modules:
  mod_muc:
    access_admin:
      - allow: admin

我可以执行此查询,提供一个存在的帐户和一个存在的房间,但该帐户不在该房间内:

$ ejabberdctl send_message groupchat user1@localhost room1@conference.localhost Sub Bodyyy

该房间的住户收到以下消息:

<message to='user2@localhost/tka1'
    from='room1@conference.localhost'
    type='groupchat'
    id='1234779465623896577'>
  <body xml:lang='en'>Bodyyy</body>
  <subject xml:lang='en'>Sub</subject>
</message>

或者,您可以为 MUC 房间订阅一个帐户,然后该帐户可以在没有占用的情况下向该房间发送消息。例如:

$ ejabberdctl subscribe_room user2@localhost/tka1 User2 room1@conference.localhost urn:xmpp:mucsub:nodes:messages
urn:xmpp:mucsub:nodes:messages

$ ejabberdctl send_message groupchat user2@localhost room1@conference.localhost Sub Bodyyy
于 2018-04-26T15:11:53.283 回答