I am new to Node.js and Mongoose and need some help. So I first create an array called beerObjects. Then I make a request to breweryDB and store info in this array.
request(options, function (error, response, body) {
if (error) throw new Error(error);
obj = JSON.parse(body);
data = obj['data'];
for(i = 0; i < data.length; i++) {
var newBeer = new Beer();
newBeer.id = data[i]['id'];
newBeer.name = data[i]['name'];
newBeer.description = data[i]['description'];
newBeer.abv = data[i]['abv'];
if (data[i].hasOwnProperty('labels')) {
newBeer.image = data[i]['labels']['large'];
}
beerObjects.push(newBeer);
console.log(beerObjects[i].name);
}
addBeersToDatabase(beerObjects);
});
I have another function that will take this array and store the info in my mongo database.
function addBeersToDatabase(beerObjects) {
console.log(beerObjects.length);
for (i = 0; i < beerObjects.length; i++) {
console.log(beerObjects[i].id);
// check if beer is already in database
Beer.count({id: beerObjects[i].id}, function(err, count){
if (err) {
handleError(err);
}
if (count == 0) {
// add new beer to database
var newBeer = new Beer();
newBeer.id = beerObjects[i].id;
newBeer.name = beerObjects[i].name;
newBeer.description = beerObjects[i].description;
newBeer.abv = beerObjects[i].abv;
newBeer.image = beerObjects[i].image;
newBeer.save(function(err) {
if (err) {
throw err;
}
});
}
else {
// beer is already in database
}
});
}
}
In the beginning of the addBeerToDatabase() function, beerObject is defined and the console.log() statements output the correct information. But inside the Mongoose function Beer.count(), I get this error message.
newBeer.id = beerObjects[i].id;
TypeError: Cannot read property 'id' of undefined
This 'id' is the id of beerObjects[i], not newBeer. How do I correctly pass beerObjects to the mongoose function and use it in that function?
EDIT:
function addBeersToDatabase(beerObjects) {
for (i = 0; i < beerObjects.length; i++) {
console.log(beerObjects[i].beerId);
var currentBeer = beerObjects[i];
// check if beer is already in database
Beer.findOne({'beerId': currentBeer.beerId}, function(err, beer){
if (err) {
handleError(err);
}
if (beer) {
// beer is already in database
}
else {
// add new beer to database
console.log(currentBeer.name);
saveNewBeer(currentBeer);
}
});
}
}
function saveNewBeer(currentBeer) {
var newBeer = new Beer();
newBeer.beerId = currentBeer.beerId;
newBeer.name = currentBeer.name;
newBeer.description = currentBeer.description;
newBeer.abv = currentBeer.abv;
newBeer.image = currentBeer.image;
newBeer.save(function(err) {
if (err) {
throw err;
}
});
}
This code is adding n duplicates (where n = beerObjects.length) of just the last item in beerObjects.