Last active
September 24, 2022 07:30
-
-
Save martenc/b551a440a1f2a28a19f27d5c537c506a to your computer and use it in GitHub Desktop.
import CSV or JSON to firebase cloud firestore
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// https://stackoverflow.com/questions/46640981/how-to-import-csv-or-json-to-firebase-cloud-firestore | |
const admin = require('../functions/node_modules/firebase-admin'); | |
const serviceAccount = require("./service-key.json"); | |
admin.initializeApp({ | |
credential: admin.credential.cert(serviceAccount), | |
databaseURL: "https://<your-database-name>.firebaseio.com" | |
}); | |
const data = require("./fakedb.json"); | |
/** | |
* Data is a collection if | |
* - it has a odd depth | |
* - contains only objects or contains no objects. | |
*/ | |
function isCollection(data, path, depth) { | |
if ( | |
typeof data != 'object' || | |
data == null || | |
data.length === 0 || | |
isEmpty(data) | |
) { | |
return false; | |
} | |
for (const key in data) { | |
if (typeof data[key] != 'object' || data[key] == null) { | |
// If there is at least one non-object item then it data then it cannot be collection. | |
return false; | |
} | |
} | |
return true; | |
} | |
// Checks if object is empty. | |
function isEmpty(obj) { | |
for(const key in obj) { | |
if(obj.hasOwnProperty(key)) { | |
return false; | |
} | |
} | |
return true; | |
} | |
async function upload(data, path) { | |
return await admin.firestore() | |
.doc(path.join('/')) | |
.set(data) | |
.then(() => console.log(`Document ${path.join('/')} uploaded.`)) | |
.catch(() => console.error(`Could not write document ${path.join('/')}.`)); | |
} | |
/** | |
* | |
*/ | |
async function resolve(data, path = []) { | |
if (path.length > 0 && path.length % 2 == 0) { | |
// Document's length of path is always even, however, one of keys can actually be a collection. | |
// Copy an object. | |
const documentData = Object.assign({}, data); | |
for (const key in data) { | |
// Resolve each collection and remove it from document data. | |
if (isCollection(data[key], [...path, key])) { | |
// Remove a collection from the document data. | |
delete documentData[key]; | |
// Resolve a colleciton. | |
resolve(data[key], [...path, key]); | |
} | |
} | |
// If document is empty then it means it only consisted of collections. | |
if (!isEmpty(documentData)) { | |
// Upload a document free of collections. | |
await upload(documentData, path); | |
} | |
} else { | |
// Collection's length of is always odd. | |
for (const key in data) { | |
// Resolve each collection. | |
await resolve(data[key], [...path, key]); | |
} | |
} | |
} | |
resolve(data); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment