Intents

Events

Every time when there is an incoming request, the handler will be called and parse out events from the request. Afterwards, the Event instance is attached to context so that you can access it via context.event.
Bottender help you recognize what kind of messages or payloads are sent from users. In this way, you are able to handle intents more easily.

Check Event Reference to get more information about event.

Pattern Matching

String Comparison

Here's an example handler which only handles specific commands:

bot.onEvent(async context => {
  if (context.event.isText) {
    switch (context.event.text) {
      case '/start':
        await context.sendText('Running....');
        break;
      case '/help':
        await context.sendText(`
/start   start to run
/help    quick help on <command>
        `);
        break;
      default:
        await context.sendText(`${context.event.text} is not a valid command.`);
    }
  }
});

Regular Expression

Exactly matching looks a little rigid. Consider using some equality operators to determine whether receiving greeting words or not:

bot.onEvent(async context => {
  if (context.event.isText) {
    const { text } = context.event.message;
    if (text === 'hello' || text === 'hi') {
      // ...
    }
  }
});

It only matches hello and hi. Neither Hello nor hi~ would work in the above example.

We can use regular expressions for more general pattern matching. It will be helpful when building rule-based logic.

bot.onEvent(async context => {
  if (context.event.isText) {
    const { text } = context.event.message;
    if (/^h(ello|i)/i.test(text)) {
      // ...
    }
  }
});

Now, not only hello, hi but also Hello, hi~ will be matched.

Leverage NLU Technologies

If you want to have more general intent recognition, you can leverage modern NLU (Natural Language Understanding) technologies. They can help you recognize the intent of user input sentences. There are several online services you can choose from, for example: