#google-cloud-firestore
#google-cloud-firestore
Вопрос:
Я выполняю пакетную фиксацию документов порциями по 50 в коллекцию cloud firestore с именем «Действия», и я написал облачную функцию, которая запускается при создании, обновлении и удалении любого документа в этой коллекции, но облачная функция запускается только один раз для каждого пакета, а не для всех документов в пакете.
Я подсчитал журналы, в которых печатается, сколько раз вызывались облачные функции, и это примерно соответствует количеству раз, когда вызывалась пакетная фиксация.
Код, выполняющий пакетную фиксацию :
const activitiesRef = app.firestore.collection(`activities`);
if (_.isArray(insertObj)) {
const chunksOf450 = await _.chunk(insertObj, 450);
for (const singleChunk of chunksOf450) {
// Get a new write batch
const batch = app.firestore.batch();
for (const obj of singleChunk) {
const tempRef = activitiesRef.doc((obj as any).uid);
batch.set(tempRef, obj);
}
// Commit the batch
await batch.commit();
}
return {
message: 'All objects written to database successfully'
};
Облачная функция, которая запускается при onWrite :
export default functions.firestore.document('activities/{activityId}').onWrite(async (snap, context) => {
const isDocumentExists = snap.after.exists
utils.app.initializeApp(initializeAdminApp.default);
adminUtils.ElasticHelper.init();
if (isDocumentExists) {
const afterDocData = snap.after.data();
const afterDocId = snap.after.id;
console.log('starting..', afterDocData, afterDocId);
const { contentType } = snap.after.data();
if (contentType === 'activityTypes') {
await adminUtils.ElasticHelper.index('activity', afterDocId, afterDocData);
}
if (contentType === 'itemTypes') {
await adminUtils.ElasticHelper.index('item', afterDocId, afterDocData);
}
if (contentType === 'questionTypes') {
await adminUtils.ElasticHelper.index('question', afterDocId, afterDocData);
}
} else {
const beforeDocId = snap.before.id;
const { contentType } = snap.before.data();
console.log('deleting on elastic ..', beforeDocId);
if (contentType === 'activityTypes') {
await adminUtils.ElasticHelper.delete('activity', beforeDocId);
}
if (contentType === 'itemTypes') {
await adminUtils.ElasticHelper.delete('item', beforeDocId);
}
if (contentType === 'questionTypes') {
await adminUtils.ElasticHelper.delete('question', beforeDocId);
}
}
console.log('function success');
});
Для каждого документа, который записывается при пакетной фиксации, я хочу, чтобы запускалась эта облачная функция.
Спасибо.
Ответ №1:
Это работает нормально, если вы полностью удаляете коллекцию, а затем выполняете пакетную фиксацию, потому что, если коллекция уже существует, и вы пытаетесь перезаписать документы, облачные триггеры не запустятся. Сначала вы должны удалить все документы.