forked from vueschool/vue-masterclass
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfirestoreImport.js
51 lines (46 loc) · 1.58 KB
/
firestoreImport.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Imports
const firestoreService = require('firestore-export-import')
const firebaseConfig = require('./src/config/firebase.js')
const serviceAccount = require('./serviceAccount.json')
const fs = require('fs')
const tempFileName = `${__dirname}/data-temp.json`;
// procedure
(async () => {
const fileContents = fs.readFileSync(`${__dirname}/src/data.json`, 'utf8')
const data = JSON.parse(fileContents)
const transformed = transformDataForFirestore(data)
fs.writeFileSync(tempFileName, JSON.stringify(transformed))
await jsonToFirestore()
fs.unlinkSync(tempFileName)
})()
// Helper Functions
// -------------------------------------
// JSON To Firestore
async function jsonToFirestore () {
try {
console.log('Initialzing Firebase')
await firestoreService.initializeApp(serviceAccount, firebaseConfig.databaseURL)
console.log('Firebase Initialized')
await firestoreService.restore(tempFileName)
console.log('Upload Success')
} catch (error) {
console.log(error)
}
}
// In order to preserve ids in data.json
// as ids in firestore
// must use keyed object (id being the key) instead of array of records
function transformDataForFirestore (data) {
const collections = data
delete collections.stats
const collectionsById = {}
Object.keys(collections).forEach((collectionKey) => {
collectionsById[collectionKey] = {}
const collection = collections[collectionKey]
collection.forEach((record) => {
collectionsById[collectionKey][record.id] = record
delete collectionsById[collectionKey][record.id].id
})
})
return collectionsById
}