-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathinsert_db.js
More file actions
87 lines (74 loc) · 2.09 KB
/
insert_db.js
File metadata and controls
87 lines (74 loc) · 2.09 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
import mongoose from "mongoose";
import dotenv from 'dotenv';
import { loadData } from './utils/file_ctrl.js';
import { Drinks, Brewer } from './models.js';
dotenv.config();
const MONGO_HOST = process.env.MONGO_HOST_URL;
const DATA_DIR = 'output/out';
const DROP_BEFORE_ACTION = true;
// DB connection
mongoose.connect(MONGO_HOST, {
retryWrites: true,
w: 'majority'
}).then((resp) => {
// console.log(resp);
console.log("Connected");
return DROP_BEFORE_ACTION;
}).then(async (drop) => {
if(drop) {
console.log("Drop existing collections")
let cnt = 0;
cnt += await Drinks.collection?.drop() ? 1 : 0;
cnt += await Brewer.collection?.drop() ? 1 : 0;
return cnt;
}
return 0;
}).then(async (length) => {
console.log(`dropped ${length} collections`);
const brewerData = loadData(DATA_DIR, 'brewers.json');
const brewsers = await Brewer.insertMany(brewerData);
const brewersMap = createBrewerMap(brewsers);
const drinkData = loadData(DATA_DIR, 'products.json');
// console.log(campaignData[0]);
const drinkDataWithBrewerId = appendBrewerId(drinkData, brewersMap);
console.log(drinkDataWithBrewerId[0]);
await Drinks.insertMany(drinkDataWithBrewerId);
return;
}).then(() => {
console.log(`DONE, close connection`);
mongoose.disconnect();
})
.catch((error) => {
console.log(error);
console.log(`failed to connect DB : ${MONGO_HOST}`);
mongoose.disconnect();
});
/**
* Create map(key: name, value: objectId) from array.
* @param {Array} list
* @return brewer map
*/
function createBrewerMap(list) {
let ret = new Map();
list.forEach((elem, idx) => {
if(!ret.get(elem.name))
ret.set(elem.name, elem._id);
});
return ret;
}
/**
* Append Brewer's id using name
* @param {Array} list
* @param {Map} map
* @return {Array} array of product with brewer id
*/
function appendBrewerId(list, map) {
let ret = [];
ret = list.map((elem, id) => {
return {
...elem,
brewerId: map.get(elem.brewer)
};
});
return ret;
}