Интеграция пакетной фиксации и триггеров облачного firestore

#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:

Это работает нормально, если вы полностью удаляете коллекцию, а затем выполняете пакетную фиксацию, потому что, если коллекция уже существует, и вы пытаетесь перезаписать документы, облачные триггеры не запустятся. Сначала вы должны удалить все документы.