如何从漫游器向用户发送主动消息

时间:2019-09-24 17:31:10

标签: botframework microsoft-graph microsoft-teams

我正在尝试从机器人向尚未安装该机器人并且不需要通过REST API安装该机器人的团队用户发送消息。

我已尝试遵循此document

它明确指出: “发送消息以启动新的对话线程与发送消息以响应现有对话是不同的:当您的漫游器开始新的对话时,没有预先存在的对话可以将该消息发布到该对话。您需要的主动消息:“

据我了解,这意味着我正在尝试做的事情是可能的。我已经尝试运行此sample

但是,据我所知,它需要一个对话ID。没有对话ID,将无法正常工作。

我尝试使用bot网络令牌(通常用于响应用户的活动请求)发送这样的请求:

POST /v3/conversations
{
  "bot": {
    "id": "28:10j12ou0d812-2o1098-c1mjojzldxcj-1098028n ",
    "name": "The Bot"
  },
  "members": [
    {
      "id": "29:012d20j1cjo20211"
    }
  ],
  "channelData": {
    "tenant": {
      "id": "197231joe-1209j01821-012kdjoj"
    }
  }
}

但是,它失败并显示以下消息:

Send Message to https://graph.microsoft.com/v3/conversations failed: (401) {
  "error": {
    "code": "InvalidAuthenticationToken",
    "message": "Access token validation failure. Invalid audience.",
    "innerError": {
      "request-id": "92922235-8c87-47ed-92bc-4ba17469611a",
      "date": "2019-09-24T14:43:59"
    }
  }
}

我猜想这可能是因为我没有先发送MicrosoftAppCredentials.TrustServiceUrl。但这是一个c#调用。如何在REST API中进行相同的调用?

1 个答案:

答案 0 :(得分:0)

请查看Bot Framework REST APIs文档。

以下是generate the access token的步骤,您可以使用这些步骤来调用Create Conversation API。

POST https://login.microsoftonline.com/botframework.com/oauth2/v2.0/token
Host: login.microsoftonline.com
Content-Type: application/x-www-form-urlencoded

grant_type=client_credentials&client_id=MICROSOFT-APP-ID&client_secret=MICROSOFT-APP-PASSWORD&scope=https%3A%2F%2Fapi.botframework.com%2F.default