8

我正在开发 ejabberd API 来邀请用户到 MUC 房间。我已经为 API 设置了 OAuth。

我已经用 get_room_occupants 测试了 oauth,它工作正常。

现在,我正在尝试访问/api/send_direct_invitation,但根据日志,我无权访问此 api

我已经用命令行生成了 oauth ejabberdctl oauth_issue_token admin@host 31540000 "ejabberd:admin"

我需要传递任何额外的权限吗

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

这是一个ejabberd.yml文件

api_permissions:
  "console commands":
    from:
      - ejabberd_ctl
    who: all
    what: "*"
  "admin access":
    who:
      - access:
          - allow:
            - user: admin@host
      - oauth:
        - scope: "ejabberd:admin"
        - access:
          - allow:
            - user: admin@host
    what:
      - "*"
      - "!stop"
      - "!start"
  "public commands":
    who:
      - ip: "127.0.0.1/8"
    what:
      - "status"
      - "connected_users_number"
commands_admin_access:
  - allow:
    - user: "admin@host"
commands:
  add_commands:
    - status
    - registered_users
    - register
    - unregister
    - get_roster
    - connected_users
    - send_stanza_c2s
    - send_stanza
    - join_cluster
    - send_direct_invitation
oauth_expire: 3600
oauth_access: all

我尝试通过命令行运行它并收到此错误

命令:ejabberdctl send_direct_invitation naviteam1519 conference.xxx.yyy.com "" "You need this room!" KESH2FABDE@xxx.yyy.com

错误:

Problem 'error {bad_jid,<<"KESH2FABDE@xxx.yyy.com">>}' occurred executing the command.
Stacktrace: [{jid,decode,1,[{file,"src/jid.erl"},{line,138}]},
         {mod_muc_admin,'-get_users_to_invite/2-fun-1-',2,
                        [{file,"src/mod_muc_admin.erl"},{line,840}]},
         {lists,filtermap,2,[{file,"lists.erl"},{line,1317}]},
         {mod_muc_admin,send_direct_invitation,5,
                        [{file,"src/mod_muc_admin.erl"},{line,826}]},
         {ejabberd_ctl,call_command,4,
                       [{file,"src/ejabberd_ctl.erl"},{line,352}]},
         {ejabberd_ctl,try_call_command,4,
                       [{file,"src/ejabberd_ctl.erl"},{line,321}]},
         {ejabberd_ctl,process2,4,
                       [{file,"src/ejabberd_ctl.erl"},{line,271}]},
         {ejabberd_ctl,process,2,
                       [{file,"src/ejabberd_ctl.erl"},{line,249}]}]
4

1 回答 1

1

您没有向我们展示您的ejabberdctl send_direct_invitation命令和日志。

我敢打赌,您的命令格式不正确:

send_direct_invitation api来看,它应该是这样的:

POST /api/send_direct_invitation
{
  "name": "room1",
  "service": "muc.example.com",
  "password": "",
  "reason": "Check this out!",
  "users": "user2@localhost:user3@example.com"
}

然后一个例子看起来像这样:

ejabberdctl send_direct_invitation aRoom conference.localhost "" "You need this room!" msg_test1@localhost

至于你的ejabbered.yml文件。你确定你有: admin@host用户?那不应该是给你的admin@localhost吗?

编辑

根据评论: OP 缺少mod-client-state配置 mod-client-state配置:

示例配置:

modules:
  ...
  mod_client_state:
    queue_chat_states: true
    queue_pep: false
    queue_presence: true
  ...
于 2018-06-17T06:28:38.063 回答