ejabberd mod_http_api休息请求

时间:2016-03-26 11:48:25

标签: ejabberd ejabberd-api

我正在尝试做一些休息请求(没有OAuth)但是ejabberd响应总是“HTTP / 1.1 400 Bad Request”

以下是详细信息:

ejabberd版本: 16.02

ejabberd配置

port: 5280
    ip: "::"
    module: ejabberd_http
    request_handlers:
      ##"/websocket": ejabberd_http_ws
      ##"/oauth": ejabberd_oauth
      "/api": mod_http_api
    ##  "/pub/archive": mod_http_fileserver
    web_admin: true
    http_bind: true
    http_poll: true
    ## register: true
    captcha: false
    commands_admin_access: configure
    commands:
      - add_commands: user
    oauth_expire: 3600
    oauth_access: all

请求

curl -v -X POST -H "X-Admin: true" -H "Authorization: Basic YWRtaW5AcHJqLmlvOmFkbWlu"  -H "Content-Type:application/json" http://prj.io:5280/api/status -d '{}'

日志

2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:process_header:281 (#Port<0.16265>) http query: 'POST' <<"/api/status">>
2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:extract_path_query:395 client data: <<"{}">>
2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:process:353 [<<"api">>,<<"status">>] matches [<<"api">>]
2016-03-26 04:38:04.711 [info] <0.490.0>@mod_http_api:log:388 Admin call status [] from ::FFFF:192.168.117.1:53583

请帮助我理解ejabberd的行为以及向mod_http_api发布一些请求的方式。

2 个答案:

答案 0 :(得分:0)

尝试以下......

commands_admin_access: configure
commands:
   - add_commands:
     - status

答案 1 :(得分:0)

请求中,您已经提供了

curl -v -X POST -H "X-Admin: true" -H "Authorization: Basic YWRtaW5AcHJqLmlvOmFkbWlu" -H "Content-Type:application/json" http://prj.io:5280/api/status -d '{}'

没有这样的终点状态

尝试使用以下其中一项作为终点

  1. num_active_users - 过去几天活跃的用户数
  2. status_num_host - 主机中具有给定状态的已记录用户数
  3. status_num - 具有给定状态的已记录用户数
  4. stats - 获取统计值:注册用户,在线用户,在线用户节点,正常运行时间秒 stats_host - 获取每个主机的统计值:注册用户,在线用户,在线用户节点,正常运行时间秒