How to delete all files in a firebase storage directory
Asked Answered
A

2

5

I have a firebase storage path that looks like this.

firebase.storage().ref('temp/test')

the "test" folder has about 25-50 files. I know there is not a way to delete the whole directory in firebase but Is there a way to iterate through all the files in a directory and deleting them one by one?

Aryn answered 16/8, 2020 at 7:24 Comment(0)
E
9

Is there a way to iterate through all the files in a directory and deleting them one by one?

Yes, you can use the listAll() method, as follows:

  const storageRef = firebase.storage().ref('temp');
  storageRef.listAll().then((listResults) => {
    const promises = listResults.items.map((item) => {
      return item.delete();
    });
    Promise.all(promises);
  });

Note that:

  1. This method is only available for Firebase Rules Version 2 (add rules_version = '2'; at the top of the Security Rules).
  2. This is a helper method for calling list() repeatedly until there are no more results. The default pagination size is 1000.
Earthshaking answered 16/8, 2020 at 8:47 Comment(0)
C
0

I did it this way in my Angular app (tree-shakable calls / modular api):

import {
   Storage, ref, getStorage, listAll, deleteObject, getBytes
} from '@angular/fire/storage';
  ...
  async deleteDirectory(directoryPath: string) {
    const storage = getStorage();
    const listRef = ref(storage, directoryPath);
    await this.deleteFiles(listRef);
  }

  async deleteFiles(listRef: any) {
    await listAll(listRef)
      .then((res) => {
        res.prefixes.forEach((folderRef) => {
          // if list item is a directory, recursively move through directory tree
          this.deleteFiles(folderRef);
        });
        res.items.forEach((itemRef) => {
          // if not a directory or empty, delete object
          deleteObject(itemRef);
        });
      }).catch((error) => {
        console.log('error deleting storage objects: ', error);
    });
  }
Chaoan answered 18/10, 2024 at 11:32 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.