API 调用 Rocket.Chat 集成

API Call in Rocket.Chat Integration

我正在尝试进一步扩展电报-rocket.chat 桥并且需要为此调用一些 api。为此,rocket.chat 公开了一个名为 HTTP 的 Meteor.js 包装器。

此代码片段是一个传出挂钩,用于处理用户发送的消息,让我转换消息并传递更改后的文本。

prepare_outgoing_request({request}) 被 rocket.chat 挂钩调用,我想在其中调用一个 API 来将表情符号代码解析为实际的表情符号-字符:“:see_no_evil:到“

/** Global Helpers
 *
 * console - A normal console instance
 * _       - An underscore instance
 * s       - An underscore string instance
 * HTTP    - The Meteor HTTP object to do sync http calls
 *           https://docs.meteor.com/api/http.html
 */


class Script {
    request_emojitext(emoji_code) {
       console.log(`called: request_emojitext('${emoji_code}')`);
       const url = `https://www.emojidex.com/api/v1/emoji/${emoji_code}`;
  
       const response = HTTP.call('GET', url);

       console.log(`Emoji Response: ${response.constructor.name} => ${JSON.stringify(response)}`);
      // Emoji Response: Object => {"error":{}}             
       return response;
    }
  
    /**
     request.params            {object}
      request.method            {string}
     request.url               {string}
     request.headers           {object}
     */
    prepare_outgoing_request({ request }) {
       const emojiResponse = this.request_emojitext('see_no_evil');
       const emojiCharacter = emojiResponse.content.emoji;
        
        return {
          // https://core.telegram.org/bots/api
          url: `${request.url}&text=${emojiCharacter}`,
          method: 'GET'
        };
    }
}

Meteor documentation 指出:

// Asynchronous call
Meteor.call('foo', 1, 2, (error, result) => { ... });

// Synchronous call
const result = Meteor.call('foo', 1, 2);

/*
On the client, if you do not pass a callback and you are not 
inside a stub, call will return undefined, and you will have 
no way to get the return value of the method. That is because
the client doesn’t have fibers, so there is not actually any 
way it can block on the remote execution of a method.
*/

我不确定如何在这里进行,因为我对异步编程还不是很满意。在结果实际可用之前,我将如何阻止,或者是否有我完全想念的不同方法?

如文档所述,无法在客户端进行阻止——浏览器根本不为此实现任何机制。所以问题是,是什么让你很难处理客户端的延迟,直到回调被调用。当然,典型的模式是在调用时将客户端切换到某种 "waiting" 状态(例如,显示微调器),然后在回调触发时用结果更新页面(并隐藏微调器)。

我通过查看 HTTP 变量 (PR #5876) 的实现发现了问题。 另外已打开异步调用的功能请求 (Issue #4775)。

const response = HTTP('GET', 'https://www.emojidex.com/api/v1/emoji/sweat_smile');

这会同步执行 API 调用和 returns 结果对象:

{
  "result": {
    "statusCode": 200,
    "headers": {
      // ...
    },
    "data": {
      "code": "sweat smile",
      "moji": "",
      // ...
    }
  }
}

如果您想查看完整代码,可以check it out on Git