Is it acceptable to increment a counter with a realtime database trigger using transaction?
exports.incPostCount = functions.database.ref(\'/threadsMeta/{thr
Definitely! In fact, that's exactly how it's done in this code sample, although with a few small differences:
exports.countlikechange = functions.database.ref("/posts/{postid}/likes/{likeid}").onWrite((event) => {
var collectionRef = event.data.ref.parent;
var countRef = collectionRef.parent.child('likes_count');
return countRef.transaction(function(current) {
if (event.data.exists() && !event.data.previous.exists()) {
return (current || 0) + 1;
}
else if (!event.data.exists() && event.data.previous.exists()) {
return (current || 0) - 1;
}
});
});
Notably, this sample handles both an increment and a decrement case depending on whether the child node is being created or deleted.