node.jsfirebasegoogle-cloud-firestoregoogle-cloud-functions

Delete a Document with all Subcollections and Nested Subcollections in Firestore


How can you delete a Document with all it's collections and nested subcollections? (inside the functions environment)

In the RTDB you can ref.child('../someNode).setValue(null) and that completes the desired behavior.

I can think of two ways you could achieve the desired delete behavior, both with tremendously ghastly drawbacks.

  1. Create a 'Super' function that will spider every document and delete them in a batch. This function would be complicated, brittle to changes, and might take a lengthy execution time.

  2. Add 'onDelete' triggers for each Document type, and make it delete any direct subcollections. You'll call delete on the root document, and the deletion calls will propagate down the 'tree'. This is sluggish, scales atrociously and is costly due to the colossal load of function executions.

Imagine you would have to delete a 'GROUP' and all it's children. It would be deeply chaotic with #1 and pricey with #2 (1 function call per doc)

groups > GROUP > projects > PROJECT > files > FILE > assets > ASSET
                                                   > urls > URL
                                    > members > MEMBER
               > questions > QUESTION > answers > ANSWER > replies > REPLY
                                      > comments > COMMENT
               > resources > RESOURCE > submissions > SUBMISSION
                                      > requests > REQUEST

Is there a superior/favored/cleaner way to delete a document and all it's nested subcollections?

It ought to be possible considering you can do it from the console.


Solution

  • according to firebase documentation:
    https://firebase.google.com/docs/firestore/solutions/delete-collections
    Deleting collection with nested subcollections might be done easy and neat with node-JS on the server side.

    const client = require('firebase-tools');
    await client.firestore
          .delete(collectionPath, {
            project: process.env.GCLOUD_PROJECT,
            recursive: true,
            yes: true
          });