How to send headers after loophow to save multiple for loops data?How do I debug Node.js applications?How do I get started with Node.jsHow do I get the path to the current script with Node.js?How do I pass command line arguments to a Node.js program?How to decide when to use Node.js?How to exit in Node.jsWhat is the purpose of Node.js module.exports and how do you use it?How can I update NodeJS and NPM to the next versions?Error: Can't set headers after they are sent to the clientHow do I update each dependency in package.json to the latest version?

Do UK voters know if their MP will be the Speaker of the House?

Valid term from quadratic sequence?

When (not how or why) to calculate Big O of an algorithm

What do you call someone who asks many questions?

Examples of smooth manifolds admitting inbetween one and a continuum of complex structures

Can compressed videos be decoded back to their uncompresed original format?

Is there a hemisphere-neutral way of specifying a season?

Method Does Not Exist error message

Are there any examples of a variable being normally distributed that is *not* due to the Central Limit Theorem?

Would Slavery Reparations be considered Bills of Attainder and hence Illegal?

Can my sorcerer use a spellbook only to collect spells and scribe scrolls, not cast?

Unlock My Phone! February 2018

If human space travel is limited by the G force vulnerability, is there a way to counter G forces?

Madden-Julian Oscillation (MJO) - How to interpret the index?

CAST throwing error when run in stored procedure but not when run as raw query

Plagiarism or not?

What method can I use to design a dungeon difficult enough that the PCs can't make it through without killing them?

Could the museum Saturn V's be refitted for one more flight?

Avoiding the "not like other girls" trope?

I would say: "You are another teacher", but she is a woman and I am a man

Short story with a alien planet, government officials must wear exploding medallions

Is it logically or scientifically possible to artificially send energy to the body?

How to tell a function to use the default argument values?

Mathematica command that allows it to read my intentions



How to send headers after loop


how to save multiple for loops data?How do I debug Node.js applications?How do I get started with Node.jsHow do I get the path to the current script with Node.js?How do I pass command line arguments to a Node.js program?How to decide when to use Node.js?How to exit in Node.jsWhat is the purpose of Node.js module.exports and how do you use it?How can I update NodeJS and NPM to the next versions?Error: Can't set headers after they are sent to the clientHow do I update each dependency in package.json to the latest version?













0















I want to do find an user, whose model contains an array of cities (for example:[Madrid, London, Moscow, Buenos Aires, etc])



This is the model:



var UserSchema = Schema(
name: String,
surname: String,
userName: String,
email: String,
password: String,
rol: String,
suscriptionDate: Date,
cities:[String],
citiesPopulate:[]
);


Once I've found the user, I want to iterate through this array to use each city as the parameter in order to find the info that I have on the model City just to add coords to user.citiesPopulate



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,function(err,userFound)
if(err)
console.log(err)
else

for(let i=0;i<userFound.cities.length;i++)

City.findOne('city':userFound.cities[i],function(err,citiesFound)
if(err)
console.log(err)
else
userFound.citiesPopulate.push(citiesFound.coords);
console.log(userFound)

)



)



And, once all the info of every single city has been added to userFound.citiesPopulate (by now just arrays with a pair of coordinates), I want to use res.status(200).send(userFound) to see the result on my postman console, something like this(three cities and three pairs of coordinates):



 cities: [ 'Bilbao', 'Madrid', 'Barcelona' ],
citiesPopulate: [ [ -3.68, 40.4 ], [ -2.97, 43.25 ], [ 2.18, 41.38 ] ],
_id: 5c82c2e5cfa8d543d0133dd6,
name: 'pruebas35',
surname: 'pruebas35',
userName: 'pruebas35',
email: 'pruebas35@prueba.es',
password: '$2a$10$eSue5gw7r4dFPtwD8qzJhODcvvNFaRkeQYRAOPO9MCBsy3Djhkffq',
rol: 'user',
suscriptionDate: 2019-03-08T19:30:45.075Z,
__v: 0


But if I type the res.status into the loop, it is sent and I can´t get the whole information.



I'd like to know a solution for this, please.










share|improve this question






















  • If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

    – Carlos FTG
    Mar 9 at 11:26















0















I want to do find an user, whose model contains an array of cities (for example:[Madrid, London, Moscow, Buenos Aires, etc])



This is the model:



var UserSchema = Schema(
name: String,
surname: String,
userName: String,
email: String,
password: String,
rol: String,
suscriptionDate: Date,
cities:[String],
citiesPopulate:[]
);


Once I've found the user, I want to iterate through this array to use each city as the parameter in order to find the info that I have on the model City just to add coords to user.citiesPopulate



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,function(err,userFound)
if(err)
console.log(err)
else

for(let i=0;i<userFound.cities.length;i++)

City.findOne('city':userFound.cities[i],function(err,citiesFound)
if(err)
console.log(err)
else
userFound.citiesPopulate.push(citiesFound.coords);
console.log(userFound)

)



)



And, once all the info of every single city has been added to userFound.citiesPopulate (by now just arrays with a pair of coordinates), I want to use res.status(200).send(userFound) to see the result on my postman console, something like this(three cities and three pairs of coordinates):



 cities: [ 'Bilbao', 'Madrid', 'Barcelona' ],
citiesPopulate: [ [ -3.68, 40.4 ], [ -2.97, 43.25 ], [ 2.18, 41.38 ] ],
_id: 5c82c2e5cfa8d543d0133dd6,
name: 'pruebas35',
surname: 'pruebas35',
userName: 'pruebas35',
email: 'pruebas35@prueba.es',
password: '$2a$10$eSue5gw7r4dFPtwD8qzJhODcvvNFaRkeQYRAOPO9MCBsy3Djhkffq',
rol: 'user',
suscriptionDate: 2019-03-08T19:30:45.075Z,
__v: 0


But if I type the res.status into the loop, it is sent and I can´t get the whole information.



I'd like to know a solution for this, please.










share|improve this question






















  • If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

    – Carlos FTG
    Mar 9 at 11:26













0












0








0








I want to do find an user, whose model contains an array of cities (for example:[Madrid, London, Moscow, Buenos Aires, etc])



This is the model:



var UserSchema = Schema(
name: String,
surname: String,
userName: String,
email: String,
password: String,
rol: String,
suscriptionDate: Date,
cities:[String],
citiesPopulate:[]
);


Once I've found the user, I want to iterate through this array to use each city as the parameter in order to find the info that I have on the model City just to add coords to user.citiesPopulate



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,function(err,userFound)
if(err)
console.log(err)
else

for(let i=0;i<userFound.cities.length;i++)

City.findOne('city':userFound.cities[i],function(err,citiesFound)
if(err)
console.log(err)
else
userFound.citiesPopulate.push(citiesFound.coords);
console.log(userFound)

)



)



And, once all the info of every single city has been added to userFound.citiesPopulate (by now just arrays with a pair of coordinates), I want to use res.status(200).send(userFound) to see the result on my postman console, something like this(three cities and three pairs of coordinates):



 cities: [ 'Bilbao', 'Madrid', 'Barcelona' ],
citiesPopulate: [ [ -3.68, 40.4 ], [ -2.97, 43.25 ], [ 2.18, 41.38 ] ],
_id: 5c82c2e5cfa8d543d0133dd6,
name: 'pruebas35',
surname: 'pruebas35',
userName: 'pruebas35',
email: 'pruebas35@prueba.es',
password: '$2a$10$eSue5gw7r4dFPtwD8qzJhODcvvNFaRkeQYRAOPO9MCBsy3Djhkffq',
rol: 'user',
suscriptionDate: 2019-03-08T19:30:45.075Z,
__v: 0


But if I type the res.status into the loop, it is sent and I can´t get the whole information.



I'd like to know a solution for this, please.










share|improve this question














I want to do find an user, whose model contains an array of cities (for example:[Madrid, London, Moscow, Buenos Aires, etc])



This is the model:



var UserSchema = Schema(
name: String,
surname: String,
userName: String,
email: String,
password: String,
rol: String,
suscriptionDate: Date,
cities:[String],
citiesPopulate:[]
);


Once I've found the user, I want to iterate through this array to use each city as the parameter in order to find the info that I have on the model City just to add coords to user.citiesPopulate



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,function(err,userFound)
if(err)
console.log(err)
else

for(let i=0;i<userFound.cities.length;i++)

City.findOne('city':userFound.cities[i],function(err,citiesFound)
if(err)
console.log(err)
else
userFound.citiesPopulate.push(citiesFound.coords);
console.log(userFound)

)



)



And, once all the info of every single city has been added to userFound.citiesPopulate (by now just arrays with a pair of coordinates), I want to use res.status(200).send(userFound) to see the result on my postman console, something like this(three cities and three pairs of coordinates):



 cities: [ 'Bilbao', 'Madrid', 'Barcelona' ],
citiesPopulate: [ [ -3.68, 40.4 ], [ -2.97, 43.25 ], [ 2.18, 41.38 ] ],
_id: 5c82c2e5cfa8d543d0133dd6,
name: 'pruebas35',
surname: 'pruebas35',
userName: 'pruebas35',
email: 'pruebas35@prueba.es',
password: '$2a$10$eSue5gw7r4dFPtwD8qzJhODcvvNFaRkeQYRAOPO9MCBsy3Djhkffq',
rol: 'user',
suscriptionDate: 2019-03-08T19:30:45.075Z,
__v: 0


But if I type the res.status into the loop, it is sent and I can´t get the whole information.



I'd like to know a solution for this, please.







node.js mongoose






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Mar 8 at 22:20









Carlos FTGCarlos FTG

134




134












  • If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

    – Carlos FTG
    Mar 9 at 11:26

















  • If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

    – Carlos FTG
    Mar 9 at 11:26
















If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

– Carlos FTG
Mar 9 at 11:26





If I use a callback function after the first query, the one that finds the user by Id, I get an error that says:TypeError: Invalid select() argument. Must be string or object. But the argument is actually a parameter

– Carlos FTG
Mar 9 at 11:26












1 Answer
1






active

oldest

votes


















1














As pointed out by Carlos, this won't work because of the asynchronous nature of database requests. The way I would do it is to use async/await to make the code synchronous, like this:



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,async function(err,userFound)
if(err)
console.log(err)
else
try

for(let i=0;i<userFound.cities.length;i++)

let cityFound = await City.findOne('city':userFound.cities[i]);

userFound.citiesPopulate.push(cityFound.coords);


//complete userFound
console.log(userFound);

catch (e)
console.log(e);



)



Notice the use of the keyword async in the callback function from User.findById. You can only use the await feature if it is inside a function marked with the async keyword.



Also, when you doesn't specify a callback function to any Mongoose query funcion, it returns a Promise, and you can only use the await keyword on promises.



If the promise resolves, the code will continue to run, and the resolved value will be in the variable cityFound, otherwise (if the promise rejects), it will throw an execption, so the code will fall into the catch statement, and the rejected value will be in variable e.






share|improve this answer

























  • This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

    – Carlos FTG
    Mar 9 at 10:57











  • You are correct, my apologies. Edited the answer, check if it helps you now.

    – Renato Vassão
    Mar 9 at 13:48











  • That's fine, know it works, thanks Renato.

    – Carlos FTG
    Mar 10 at 17:36











  • Great! Could you please accept the answer?

    – Renato Vassão
    Mar 10 at 18:11











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55071803%2fhow-to-send-headers-after-loop%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














As pointed out by Carlos, this won't work because of the asynchronous nature of database requests. The way I would do it is to use async/await to make the code synchronous, like this:



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,async function(err,userFound)
if(err)
console.log(err)
else
try

for(let i=0;i<userFound.cities.length;i++)

let cityFound = await City.findOne('city':userFound.cities[i]);

userFound.citiesPopulate.push(cityFound.coords);


//complete userFound
console.log(userFound);

catch (e)
console.log(e);



)



Notice the use of the keyword async in the callback function from User.findById. You can only use the await feature if it is inside a function marked with the async keyword.



Also, when you doesn't specify a callback function to any Mongoose query funcion, it returns a Promise, and you can only use the await keyword on promises.



If the promise resolves, the code will continue to run, and the resolved value will be in the variable cityFound, otherwise (if the promise rejects), it will throw an execption, so the code will fall into the catch statement, and the rejected value will be in variable e.






share|improve this answer

























  • This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

    – Carlos FTG
    Mar 9 at 10:57











  • You are correct, my apologies. Edited the answer, check if it helps you now.

    – Renato Vassão
    Mar 9 at 13:48











  • That's fine, know it works, thanks Renato.

    – Carlos FTG
    Mar 10 at 17:36











  • Great! Could you please accept the answer?

    – Renato Vassão
    Mar 10 at 18:11















1














As pointed out by Carlos, this won't work because of the asynchronous nature of database requests. The way I would do it is to use async/await to make the code synchronous, like this:



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,async function(err,userFound)
if(err)
console.log(err)
else
try

for(let i=0;i<userFound.cities.length;i++)

let cityFound = await City.findOne('city':userFound.cities[i]);

userFound.citiesPopulate.push(cityFound.coords);


//complete userFound
console.log(userFound);

catch (e)
console.log(e);



)



Notice the use of the keyword async in the callback function from User.findById. You can only use the await feature if it is inside a function marked with the async keyword.



Also, when you doesn't specify a callback function to any Mongoose query funcion, it returns a Promise, and you can only use the await keyword on promises.



If the promise resolves, the code will continue to run, and the resolved value will be in the variable cityFound, otherwise (if the promise rejects), it will throw an execption, so the code will fall into the catch statement, and the rejected value will be in variable e.






share|improve this answer

























  • This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

    – Carlos FTG
    Mar 9 at 10:57











  • You are correct, my apologies. Edited the answer, check if it helps you now.

    – Renato Vassão
    Mar 9 at 13:48











  • That's fine, know it works, thanks Renato.

    – Carlos FTG
    Mar 10 at 17:36











  • Great! Could you please accept the answer?

    – Renato Vassão
    Mar 10 at 18:11













1












1








1







As pointed out by Carlos, this won't work because of the asynchronous nature of database requests. The way I would do it is to use async/await to make the code synchronous, like this:



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,async function(err,userFound)
if(err)
console.log(err)
else
try

for(let i=0;i<userFound.cities.length;i++)

let cityFound = await City.findOne('city':userFound.cities[i]);

userFound.citiesPopulate.push(cityFound.coords);


//complete userFound
console.log(userFound);

catch (e)
console.log(e);



)



Notice the use of the keyword async in the callback function from User.findById. You can only use the await feature if it is inside a function marked with the async keyword.



Also, when you doesn't specify a callback function to any Mongoose query funcion, it returns a Promise, and you can only use the await keyword on promises.



If the promise resolves, the code will continue to run, and the resolved value will be in the variable cityFound, otherwise (if the promise rejects), it will throw an execption, so the code will fall into the catch statement, and the rejected value will be in variable e.






share|improve this answer















As pointed out by Carlos, this won't work because of the asynchronous nature of database requests. The way I would do it is to use async/await to make the code synchronous, like this:



function findUsersCities(req,res)
let id=req.body._id;

User.findById(id,async function(err,userFound)
if(err)
console.log(err)
else
try

for(let i=0;i<userFound.cities.length;i++)

let cityFound = await City.findOne('city':userFound.cities[i]);

userFound.citiesPopulate.push(cityFound.coords);


//complete userFound
console.log(userFound);

catch (e)
console.log(e);



)



Notice the use of the keyword async in the callback function from User.findById. You can only use the await feature if it is inside a function marked with the async keyword.



Also, when you doesn't specify a callback function to any Mongoose query funcion, it returns a Promise, and you can only use the await keyword on promises.



If the promise resolves, the code will continue to run, and the resolved value will be in the variable cityFound, otherwise (if the promise rejects), it will throw an execption, so the code will fall into the catch statement, and the rejected value will be in variable e.







share|improve this answer














share|improve this answer



share|improve this answer








edited Mar 9 at 15:11

























answered Mar 8 at 22:58









Renato VassãoRenato Vassão

915




915












  • This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

    – Carlos FTG
    Mar 9 at 10:57











  • You are correct, my apologies. Edited the answer, check if it helps you now.

    – Renato Vassão
    Mar 9 at 13:48











  • That's fine, know it works, thanks Renato.

    – Carlos FTG
    Mar 10 at 17:36











  • Great! Could you please accept the answer?

    – Renato Vassão
    Mar 10 at 18:11

















  • This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

    – Carlos FTG
    Mar 9 at 10:57











  • You are correct, my apologies. Edited the answer, check if it helps you now.

    – Renato Vassão
    Mar 9 at 13:48











  • That's fine, know it works, thanks Renato.

    – Carlos FTG
    Mar 10 at 17:36











  • Great! Could you please accept the answer?

    – Renato Vassão
    Mar 10 at 18:11
















This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

– Carlos FTG
Mar 9 at 10:57





This is what I did first but the problem is that it returns the coords array empty as this is asynchronus, and it deals faster with res.status(200).send(userFound) rather than the for loop, I guess

– Carlos FTG
Mar 9 at 10:57













You are correct, my apologies. Edited the answer, check if it helps you now.

– Renato Vassão
Mar 9 at 13:48





You are correct, my apologies. Edited the answer, check if it helps you now.

– Renato Vassão
Mar 9 at 13:48













That's fine, know it works, thanks Renato.

– Carlos FTG
Mar 10 at 17:36





That's fine, know it works, thanks Renato.

– Carlos FTG
Mar 10 at 17:36













Great! Could you please accept the answer?

– Renato Vassão
Mar 10 at 18:11





Great! Could you please accept the answer?

– Renato Vassão
Mar 10 at 18:11



















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55071803%2fhow-to-send-headers-after-loop%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

How to get text form Clipboard with JavaScript in Firefox 56?How to validate an email address in JavaScript?How do JavaScript closures work?How do I remove a property from a JavaScript object?How do you get a timestamp in JavaScript?How do I copy to the clipboard in JavaScript?How do I include a JavaScript file in another JavaScript file?Get the current URL with JavaScript?How to replace all occurrences of a string in JavaScriptHow to check whether a string contains a substring in JavaScript?How do I remove a particular element from an array in JavaScript?

Can't initialize raids on a new ASUS Prime B360M-A motherboard2019 Community Moderator ElectionSimilar to RAID config yet more like mirroring solution?Can't get motherboard serial numberWhy does the BIOS entry point start with a WBINVD instruction?UEFI performance Asus Maximus V Extreme

List of MPs elected to the English parliament in 1640 (April) Contents List of constituencies and members See also Notes References Navigation menueNational Archives – The Glynde Place ArchivesCobbett's Parliamentary history of England, from the Norman Conquest in 1066 to the year 1803'Aldermen in Parliament', The Aldermen of the City of London: Temp. Henry III – 1912onepage&q&f&#61, false 229