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

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";
}
主站蜘蛛池模板: 大港区| 永平县| 霞浦县| 慈利县| 昌平区| 荔波县| 吕梁市| 永兴县| 纳雍县| 张家川| 许昌县| 安多县| 通河县| 福建省| 海南省| 共和县| 永宁县| 犍为县| 巴楚县| 托里县| 邻水| 茌平县| 鹿邑县| 武川县| 城固县| 淮阳县| 西乌| 辰溪县| 平顺县| 林芝县| 镇坪县| 蒙阴县| 内黄县| 卢氏县| 江源县| 临洮县| 仙桃市| 乐东| 饶河县| 巴塘县| 新竹市|