Решението, за което се сещам, е да актуализирам вложените документи един по един.
Да приемем, че сме се сдобили със забранените фрази, които представляват масив от низове:
var bannedPhrases = ["censorship", "evil"]; // and more ...
След това извършваме заявка, за да намерим всички UserComments
който има comments
които съдържат някоя от bannedPhrases
.
UserComments.find({"comments.comment": {$in: bannedPhrases }});
Използвайки обещания, можем да извършим актуализация асинхронно заедно:
UserComments.find({"comments.comment": {$in: bannedPhrases }}, {"comments.comment": 1})
.then(function(results){
return results.map(function(userComment){
userComment.comments.forEach(function(commentContainer){
// Check if this comment contains banned phrases
if(bannedPhrases.indexOf(commentContainer.comment) >= 0) {
commentContainer.isHidden = true;
}
});
return userComment.save();
});
}).then(function(promises){
// This step may vary depending on which promise library you are using
return Promise.all(promises);
});
Ако използвате Bluebird JS е обещаващата библиотека на Mongoose, кодът може да бъде опростен:
UserComments.find({"comments.comment": {$in: bannedPhrases}}, {"comments.comment": 1})
.exec()
.map(function (userComment) {
userComment.comments.forEach(function (commentContainer) {
// Check if this comment contains banned phrases
if (bannedPhrases.indexOf(commentContainer.comment) >= 0) {
commentContainer.isHidden = true;
}
});
return userComment.save();
}).then(function () {
// Done saving
});