官术网_书友最值得收藏!

External APIs

Every time you deal with anything outside of your code, there is a risk that it will error. This might be a third-party API, your own API, or simply a query to a database. You should always write these requests so that if the request returns an error, you fully deal with it. This means logging what the error was and where it took place and making sure that the chatbot still works when an error occurs.

Making sure that the chatbot still works when an error occurs is really important as no one wants to talk to a chatbot that just stops talking to you halfway through the conversation. To make sure this doesn't happen, you have three options: create error messages for every external call you make, let all errors flow down to a very low-level error handler that sends a generic We had an error message, or a combination of the two. The idea would be using custom messages for every error that could happen but as your chatbot becomes larger and more complicated, that can become very time-consuming.

An effective method for dealing with the errors is to create a low-level error handler that passes a generic error message unless a specific error message is provided. This gives you the flexibility to let the user know exactly what went wrong when it matters but saves you having to create lots of similar error messages:

try {
let result = AccessPeopleAPI();
if (result === null || typeof result !== 'number'){
throw 'I've failed to get the number of people';
}
return 'We have ' + result + ' people in the building';
} catch (error) {
console.log(error || 'The system has had an error');
return error || "Unfortunately I've had an error";
}
主站蜘蛛池模板: 青铜峡市| 鄂温| 琼中| 沂源县| 商水县| 东台市| 青铜峡市| 和林格尔县| 乌兰浩特市| 庆阳市| 龙海市| 义乌市| 永城市| 弥渡县| 宁阳县| 宁陵县| 东宁县| 读书| 富平县| 东平县| 竹山县| 和硕县| 边坝县| 辉南县| 长乐市| 泸州市| 铜川市| 乳源| 伊金霍洛旗| 静安区| 七台河市| 枞阳县| 阜南县| 涪陵区| 祥云县| 东平县| 曲阜市| 原阳县| 芷江| 新平| 金昌市|