-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathupdate-euclid-data.js
More file actions
113 lines (90 loc) · 3.08 KB
/
update-euclid-data.js
File metadata and controls
113 lines (90 loc) · 3.08 KB
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
const fs = require('fs');
const path = require('path');
const fb = require('firebase-admin');
const csv = require("csvtojson");
const serviceAccount = require('../private/service-account.json');
// --------
const csvPath = "/Users/drew/Downloads/Admissions July 3 2024.csv";
const emailField = 'email';
const dryRun = true; // when true, will just log what it will write, but not save it
// --------
// here be dragons
//
fb.initializeApp({
credential: fb.credential.cert(serviceAccount),
databaseURL: 'https://parallel-beta-31dc4.firebaseio.com'
});
const userDb = fb.firestore().collection('users');
const updatableFields = [
'guardianName',
'guardianPhone',
'schoolName',
'schoolPostcode'
];
const getUploadableData = (csvDataEntry) => {
const foundKeys = Object.keys(csvDataEntry);
const uploadableData = {};
foundKeys.forEach(foundKey => {
if (foundKey.toLowerCase() === emailField.toLowerCase()) {
uploadableData.email = csvDataEntry[foundKey];
}
updatableFields.forEach(field => {
if (foundKey.toLowerCase() === field.toLowerCase()) {
if (!['', '-', 'n/a'].includes(csvDataEntry[foundKey].trim())) {
uploadableData[field] = csvDataEntry[foundKey];
}
}
});
});
if (!uploadableData.email) {
console.log(`\nNo email field found`);
process.exit(1);
}
return uploadableData;
}
const run = async () => {
const file = path.join(__dirname, `../private/tmp-users.json`);
const accounts = JSON.parse(fs.readFileSync(file)).users;
const accountsByEmail = accounts.reduce((acc, account) => {
acc[account.email.toLowerCase()] = account;
return acc
}, {});
let csvData;
try {
csvData = await csv().fromFile(csvPath);
} catch (error) {
console.error(`\nError reading csv file: ${error.message}\n`);
}
const data = csvData.map(getUploadableData).map(d => {
const account = accountsByEmail[d.email.toLowerCase()];
if (account) {
return {
id: account.localId,
...d,
}
} else {
console.log(`\nAccount not found for ${d.email}\n`);
process.exit(1);
}
});
for (const d of data) {
const newData = {};
if (d.guardianName) newData.guardianName = d.guardianName;
if (d.guardianPhone) newData.guardianPhone = d.guardianPhone;
if (d.schoolName) newData.schoolName = d.schoolName;
if (d.schoolPostcode) newData.schoolPostcode = d.schoolPostcode;
if (dryRun) {
console.log(`\nWould update ${d.email} (${d.id}) with`);
console.log(newData);
} else {
console.log(`\nUpdating ${d.email} ${d.id} with`);
console.log(newData);
await userDb.doc(d.id).set(newData, { merge: true });
console.log(`Updated ${d.email} complete`);
}
}
if (dryRun) {
console.log(`\n\n\nSet dryRun to false to actually update the data\n`);
}
}
run();