-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathImporting Data to a Firestore Database
122 lines (121 loc) · 3.89 KB
/
Importing Data to a Firestore Database
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
114
115
116
117
118
119
120
121
122
// Run this in cloudshell //
gcloud auth list
git clone https://github.com/rosera/pet-theory
cd pet-theory/lab01
npm install @google-cloud/firestore
npm install @google-cloud/logging
updated_content=$(cat <<EOF
const {promisify} = require('util');
const parse = promisify(require('csv-parse'));
const {readFile} = require('fs').promises;
const { Firestore } = require("@google-cloud/firestore");
const {Logging} = require('@google-cloud/logging');
const logName = "pet-theory-logs-importTestData";
const logging = new Logging();
const log = logging.log(logName);
const resource = {
type: "global",
};
if (process.argv.length < 3) {
console.error('Please include a path to a csv file');
process.exit(1);
}
const db = new Firestore();
function writeToFirestore(records) {
const batchCommits = [];
let batch = db.batch();
records.forEach((record, i) => {
var docRef = db.collection("customers").doc(record.email);
batch.set(docRef, record);
if ((i + 1) % 500 === 0) {
console.log(\`Writing record \${i + 1}\`);
batchCommits.push(batch.commit());
batch = db.batch();
}
});
batchCommits.push(batch.commit());
return Promise.all(batchCommits);
}
function writeToDatabase(records) {
records.forEach((record, i) => {
console.log(\`ID: \${record.id} Email: \${record.email} Name: \${record.name} Phone: \${record.phone}\`);
});
return ;
}
async function importCsv(csvFileName) {
const fileContents = await readFile(csvFileName, "utf8");
const records = await parse(fileContents, { columns: true });
try {
await writeToFirestore(records);
} catch (e) {
console.error(e);
process.exit(1);
}
console.log(\`Wrote \${records.length} records\`);
success_message = \`Success: importTestData - Wrote \${records.length} records\`;
const entry = log.entry(
{ resource: resource },
{ message: \`\${success_message}\` }
);
log.write([entry]);
}
importCsv(process.argv[2]).catch(e => console.error(e));
EOF
)
echo "$updated_content" > importTestData.js
npm install [email protected]
updated_contents=$(cat <<EOF
const fs = require('fs');
const faker = require('faker');
const { Logging } = require("@google-cloud/logging");
const logName = "pet-theory-logs-createTestData";
const logging = new Logging();
const log = logging.log(logName);
const resource = {
type: "global",
};
function getRandomCustomerEmail(firstName, lastName) {
const provider = faker.internet.domainName();
const email = faker.internet.email(firstName, lastName, provider);
return email.toLowerCase();
}
async function createTestData(recordCount) {
const fileName = \`customers_\${recordCount}.csv\`;
var f = fs.createWriteStream(fileName);
f.write("id,name,email,phone\\n");
for (let i = 0; i < recordCount; i++) {
const id = faker.datatype.number();
const firstName = faker.name.firstName();
const lastName = faker.name.lastName();
const name = \`\${firstName} \${lastName}\`;
const email = getRandomCustomerEmail(firstName, lastName);
const phone = faker.phone.phoneNumber();
f.write(\`\${id},\${name},\${email},\${phone}\\n\`);
}
console.log(\`Created file \${fileName} containing \${recordCount} records.\`);
const success_message = \`Success: createTestData - Created file \${fileName} containing \${recordCount} records.\`;
const entry = log.entry(
{ resource: resource },
{
name: \`\${fileName}\`,
recordCount: \`\${recordCount}\`,
message: \`\${success_message}\`,
}
);
log.write([entry]);
}
recordCount = parseInt(process.argv[2]);
if (process.argv.length != 3 || recordCount < 1 || isNaN(recordCount)) {
console.error('Include the number of test data records to create. Example:');
console.error(' node createTestData.js 100');
process.exit(1);
}
createTestData(recordCount);
EOF
)
echo "$updated_contents" > createTestData.js
gcloud firestore databases create --location=us-east1
node createTestData 1000
node importTestData customers_1000.csv
node createTestData 20000
node importTestData customers_20000.csv