A script that help to export and import in Cloud Firestore
THIS IS A fork of @dalenguyen/firestore-import-export
- use of .env instead of hard-coded url, so there's only one place to edit.
- fixed subCollection name when using sub collections
- exported (downloaded) data is "prettified" using tabs, remove
PRETTIFIED=1
from the.env
if you just want the regular JSON string. - import to firebase data with subcollections
You need NODE or something that can run JAVASCRIPT (JS) file.
Get serviceAccount JSON file from Project Setting > SERVICE ACCOUNTS in Firebase Console
Download or clone this repository
git clone https://github.com/TechnologyXING/firestore-import-export.git
Install NPM packages
npm install
The file should contain the following where https://*******.firebaseio.com is the URL of your Firebase Firestore database.
DB_URL=https://*******.firebaseio.com
You can get your database url from your Firebase Console > Project Settings > General tab > select your Web App below > then in Firebase SDK snippet choose Config radio button. copy the databaseURL without the quotes.
NOTE: in the absence of this configuration, Firebase Admin will automatically use the database URL saved locally when you installed and configured the firebase-cli.
This will help you create a backup of your collection and subcollection from Firestore to a JSON file name firestore-export.json
node export.js <your-collection-name> <sub-collection-name-(optional)>
This will import a collection to Firestore will overwrite any documents in that collection with matching id's to those in your json. If you have date type in your JSON, please add the field to the command line. If you have subcollections, please indicate their field_name. The date and geo arguments is optional.
node import.js import-to-firestore.json subcollection=subFieldName date=date geo=Location
If you have date type in your JSON, please add to your command line
Sample from import-to-firestore.json. "test" will be the collection name. The date type will have _seconds and _nanoseconds in it.
{
"test" : {
"first-key" : {
"email" : "[email protected]",
"website" : "dalenguyen.me",
"custom" : {
"firstName" : "Dale",
"lastName" : "Nguyen"
},
"date": {
"_seconds":1534046400,
"_nanoseconds":0
},
"Location": {
"_latitude": 49.290683,
"_longitude": -123.133956
}
},
"second-key" : {
"email" : "[email protected]",
"website" : "google.com",
"custom" : {
"firstName" : "Harry",
"lastName" : "Potter"
},
"date": {
"_seconds":1534262435,
"_nanoseconds":0
},
"Location": {
"_latitude": 49.290683,
"_longitude": -123.133956
}
}
}
}
Thanks to @fed239, you can use YAML files instead of JSON files in order to import to firestore.
- refactor subcollection logic