问题描述
我正在尝试从云函数 cron 作业中删除多个 firebase 文档。函数正在执行,但没有发生删除。我有多个聊天室,每个聊天室下面都有聊天集。当我一一调用我的删除函数时,它正确执行。但是我想写一个cron作业,每个月都会删除特定的聊天室。
为了获取这些特定聊天室的列表,我运行了多个 firebase 循环来获取聊天室文档 ID。
async function deleteallChatData() {
admin.firestore()
.collection(`ENV/${HOST_SERVER_NAME}/MAIN_CATEGORY`)
.get().then(snapshot => {
console.log("doc------------snapshot----MAIN_CATEGORY-----",snapshot.size);
snapshot.forEach(doc => {
console.log("doc---------------------",doc.data().isPaid);
if (doc.data().isPaid) { // paid vent rooms
deleteSubCategories(doc.data().id)
} else { // free vent rooms
//clear chatroom chatData
let chat_id = 'maincategory' + doc.data().id;
let chatPath = `ENV/${HOST_SERVER_NAME}/CHAT_ROOMS/${chat_id}`;
deleteCollectionAtPath(chatPath)
}
});
}).catch(error => {
console.log("error=====MAIN_CATEGORY======",error);
})
async function deleteSubCategories(id) {
admin.firestore()
.collection(`ENV/${HOST_SERVER_NAME}/SUB_CATEGORY`)
.where('parentCategoryId','==',id)
.get().then(snapshot => {
snapshot.forEach(doc => {
if (doc.data().isOpenForChat) { // sub category chat rooms
let chat_id = 'subcategory' + createChatId(doc.data().id,doc.data().parentCategoryId);
let chatPath = `ENV/${HOST_SERVER_NAME}/CHAT_ROOMS/${chat_id}`;
deleteCollectionAtPath(chatPath)
} else { // articles
deleteArticles(doc.data().id)
}
});
})
}
async function deleteCollectionAtPath(path) {
console.log("path=deleteCollectionAtPath===",path);
firebase_tools.firestore
.delete(path,{
project: process.env.GCLOUD_PROJECT,recursive: true,yes: true,token: functions.config().fb.token
}).then(() => {
console.log("SUCCESS----------deleteCollectionAtPath------------");
}).catch(error => {
console.log("error=====deleteCollectionAtPath======",error);
})
}
当我多次分别调用 deleteCollectionAtPath 时,删除工作没有任何问题,但它在 for 循环内无法正常工作。
我有单独的 MAIN_CATEGORY 、 SUB_CATEGORY 、 CHAT_ROOMS 集合。 CHAT_ROOM 文档 ID 取决于其父类别。
有人可以帮忙解决这个问题吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)