如何从自托管自定义Microsoft Teams bot获取消息?

时间:2017-05-18 11:58:08

标签: node.js botframework

我一直在敲打这个问题太久了;

我想要一个设置

  • 我在Node.js中编码
  • 我运行本地服务器
  • 在我可以回复的频道中,提及对自定义机器人的回复

我成功了

  • Node.js中的代码
  • 运行本地服务器(使用restify或https)
  • 我设法将请求发送到我的Node.js实现

我还没有成功

  • 在提及机器人时,抓住实际的消息字符串或其他有用信息

我已经搜索了多个资源而没有太多运气,这可以用最简单的形式解释你的情况;启动一个Node.js应用程序,该应用程序侦听来自自定义机器人的传入请求,解析它以获取消息字符串,然后将其发送回通道。

这是一些转储我得到的响应的代码

const fs = require('fs');
var restify = require('restify');
var builder = require('botbuilder');

const https_options = {
    key: fs.readFileSync('[redacted].key'),
    cert: fs.readFileSync('[redacted].pem')
};

// Setup Restify Server
var server = restify.createServer(https_options);

server.listen(process.env.port || process.env.PORT || 8080, function () {
    console.log('%s listening to %s', server.name, server.url);
});

// Create chat connector for communicating with the Bot Framework Service
var connector = new builder.ChatConnector({
    appId: process.env.MICROSOFT_APP_ID,
    appPassword: process.env.MICROSOFT_APP_PASSWORD
});

// Listen for messages from users
server.post('/api/messages', function (request, response, next) {
    console.log(request);
});

// Receive messages from the user and respond by echoing each message back (prefixed with 'You said:')
var bot = new builder.UniversalBot(connector, function (session) {
    session.send("You said: %s", session.message.text);
});

当端点被命中时,这给了我1850行JSON格式的控制台输出(这也意味着机器人至少捕获了请求。但是数据中没有任何内容对应于消息,类似于找到的示例的消息在此处提到的“示例入站邮件”中https://msdn.microsoft.com/en-us/microsoft-teams/custombot

执行以下代码切换时

---- replacing this ----
// Listen for messages from users
server.post('/api/messages', function (request, response, next) {
    logger.debug(request);
});
---- with this ----
// Listen for messages from users
server.post('/api/messages', connector.listen());

结果是

  

错误:ChatConnector:receive - 没有发送安全令牌。

我怀疑这与我正在尝试使用为Office Store制作的连接器解析自定义机器人的请求有关。我对任何商店发布这个机器人都不感兴趣。我只需要一个可以响应并响应消息的自托管机器人。

我是在寻找错误的地方还是没有找到这个权利?关于自定义机器人的讨论很少,我保证我会做示例代码来描述如果最终有效的话,如何处理这个场景。

1 个答案:

答案 0 :(得分:1)

最后,我在StackOverflow上发现了https://stackoverflow.com/a/8640308/975641,最终让我走上了正轨!

获取处理消息的最终结果

const fs = require('fs');
var restify = require('restify');
const https_options = {
    key: fs.readFileSync('[redacted].key'),
    cert: fs.readFileSync('[redacted].pem')
};

var handler = function (request, res) {
    if (request.method === 'POST') {
        var body = '';
        request.on('data', function (data) {
            body += data;
            // 1e6 === 1 * Math.pow(10, 6) === 1 * 1000000 ~~~ 1MB
            if (body.length > 1e6) {
                // FLOOD ATTACK OR FAULTY CLIENT, NUKE REQUEST
                request.connection.destroy();
            }
        });
        request.on('end', function () {

            console.log(body)
            // use POST

        });
    }

    res.writeHead(200, {'Content-Type': 'application/json'});
    //res.end(parseCommands(req));
    res.end(`{
    "type": "message",
    "text": "This is a reply!"
    }`);
};

// Setup Restify Server
var server = restify.createServer(https_options);

server.listen(process.env.port || process.env.PORT || 8080, function () {
    console.log('%s listening to %s', server.name, server.url);
});

// Listen for messages from users
server.post('/api/messages', handler);

这将为您提供一个JSON格式的字符串!亚斯!