Bottender - 在facebook上启用persistent_menu和get_started按钮

时间:2018-02-26 01:14:24

标签: node.js facebook bots bottender

我正在使用NodeJS& Bottender运行我的facebook messenger webhook。

所以我希望有get started buttonpersistent menu。我查了一下&在像this one这样的回购邮件上提供的示例上设置了我的配置,但我还不能让它出现在信使上。

这是我的config.js

require('dotenv').config();

const {
  FB_ACCESS_TOKEN,
  FB_VERIFY_TOKEN,
  APP_ID,
  APP_SECRET,
} = process.env;

const { bots } = require('./global-session');

const profile = {
  get_started: {
    payload: '/start',
  },
  persistent_menu: [
    {
      locale: 'default',
      composer_input_disabled: false,
      call_to_actions: [
        {
          type: 'postback',
          title: 'Menu',
          payload: '/menu',
        },
      ],
    },
  ],
};
/* istanbul ignore next */
module.exports = {
  messenger: {
    bot: {
      accessToken: FB_ACCESS_TOKEN,
      appId: APP_ID,
      appSecret: APP_SECRET,
      mapPageToAccessToken: bots.getTokenByPageById,
      profile,
    },
    server: {
      verifyToken: FB_VERIFY_TOKEN,
      path: '/messenger',
      profile,
    },
  },
};

以及我如何使用它

const { MessengerBot } = require('bottender');
const express = require('express');
const bodyParser = require('body-parser');
const { registerRoutes } = require('bottender/express');
const handler = require('./handlers');
const logger = require('./utils/logger');

const { APP_PORT, NODE_ENV } = process.env;
const server = express();

/* istanbul ignore next */
const verify = (req, res, buf) => {
  req.rawBody = buf.toString();
};

server.use(bodyParser.json({ verify }));
server.use(require('morgan')('short', { stream: logger.logStream }));

const { messenger } = require('./config');

const bots = {
  messenger: new MessengerBot(messenger.bot).onEvent(handler.messenger.execute),
  // Define other platform bots here!
};

const initialize = async () => {
  try {
    registerRoutes(server, bots.messenger, messenger.server);
    // Start server
    server.listen(APP_PORT, () => logger.info(`ENV[${NODE_ENV}] - server is listening on port ${APP_PORT}...`));
  } catch (e) {
    logger.error('unable to start server!');
    logger.error(e);
    throw Error();
  }
};

/* istanbul ignore next */
if (process.env.NODE_ENV !== 'test') {
  initialize();
}

module.exports = initialize;

我的Facebook应用程序背景 - 已经发布到公众已批准(至少对于pages_messaging

我错过了什么?任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:1)

我们将messenger profile控件留给开发人员,因为我们无法假设开发人员何时想要设置,更新或删除机器人的信使配置文件。

例如,您可以使用这样的脚本:

const { MessengerClient } = require('messaging-api-messenger'); 

const config = require('./bottender.config');

const client = MessengerClient.connect();

const tokens = [ /* */ ]; // get tokens from somewhere

for (let i = 0; i < tokens.length; i++) {
  const token = tokens[i];
  client.setMessengerProfile(config.messenger.profile, {
    access_token: token, // important! pass token to client api
  });
}

或者,当您将令牌注册到数据库时,您可以致电setMessengerProfile

async function registerPage(page, token) {
  // ....put page and token to database
  await client.setMessengerProfile(config.messenger.profile, {
    access_token: token, // important! pass token to client api
  });
}