Я создаю MEAN-приложение с Twilio, которое позволяет людям подписывать онлайн-петицию, отправляя свое имя приложению.Люди должны иметь возможность подписать петицию только один раз.Я планирую обеспечить это, разрешив только одну подпись на номер телефона.
Каждый раз, когда подписывается петиция, создается объект Монго, подобный этому:
{
"_id" : ObjectId("5c5a47ae8f04f9148f43b033"),
"name" : "John Doe",
"number" : "+18373987466",
"date" : "2/5/19"
}
Я уже включилnumber
поле в уникальный индекс , поэтому для каждого номера телефона может быть только подпись.
Проблема, с которой я сталкиваюсь, заключается в том, что делать, когда кто-то пытается подписать несколько петиций.раз.Я хочу перехватить их попытку и отправить им сообщение о том, что они уже подписали петицию.
На мой взгляд, у меня есть два варианта:
ОПЦИЯ № 1 Запросите базу данных, чтобы узнать, был ли уже введен тот же номер.
Это кажется чем-то простым, но я просто не могу понять, как это сделать.
var number = '+18373987466';
if(collection.find({"number":number}) {
twiml.message("You have already signed the petition");
}
Я думаю, что collection.find({"number":number})
вернет true
, если найдет запись с тем же номером.Однако он возвращает весь курсор Mongo.
OPTION # 2 Поскольку number
является уникальным индексом, Mongo выдаст ошибку, если другой объект будет создан с тем же значением.Я мог бы перехватить сгенерированную ошибку и впоследствии отправить сообщение пользователю.
Мой первый вопрос с этим подходом: хороший ли дизайн программного обеспечения, чтобы сознательно позволить вашему приложению выдавать ошибку?
Я попробовал этот подход с блоком try/catch
, но возникшая ошибка сразу же вызвала сбой приложения.
try {
collection.insertOne(
{name : name, number : number, date: dateSigned},
function(error, result) {
console.log(`${name} has been added to the database`);
});
} catch (error) {
// handle error
}
Разве это не правильный способ «перехватить» ошибку и предотвратить ее сбой?приложение?