el problema es el siguiente, hago una insercion de usuario en la base de datos despues de haber comprobado con un select, si el usuario existe.
Como en nodejs, las funciones se ejecutan asincronimamente hay que hacer uso de los callback para asegurarnos de que lo que dependa del resultado de la consulta mysql, exista cuando vayas a utilizar la información. Hasta aqui, todo genial, hago el select, se ejecuta el callback, hago asignación de variables etc y realizo el insert, el cual tambien funciona correctamente e inserta en la base de datos, la infomación como lo quiero.
Ahora la cuestión del problema, tras la inserción en la bbdd se envia un correo al usuario para que valide la cuenta (como podeis ver es un sistema de registro de usuarios clasico) y para ello, entre otro tengo que tener confirmado que el usuario se creo correctamente y ademas usar el identificador que se genero. Por lo que si o si, debe realizarse estas funciones en el callback del insert.
Veamos el codigo (he dejado lo esencial para centrarnos en el problema y evitar codigo superfluo de asignación de variables y tal)
Código Javascript:
Ver original
client.query("SELECT id_user as id,validate FROM [.........]", function selectCb(err, results, fields) { if (err) { throw err;} if(results[0]){ if(results[0].id){ var Vmail = (results[0].validate=='si')?true:false; res.render('registre', { msg : lang.gen67[1] }); } } else{ if(req.body.password!='' && req.body.mail!='' && req.body.name!=''){ client.query("INSERT INTO `users` [.......]", [variables], function(err,results){ var id_user = results.insertId ; res.render('registre', { msg : lang.gen66[1] }); } )//query (insert) }//if validacion (existen las variables del formulario) else{ res.render('registre', { msg : lang.gen68[1] }); } } //if validación (usuario no existe) }//function query (select) );//query (select)
La configuración que estoy usando es nodejs + express + jade + node-mysql + nodemailer.
¿Alguna idea de porque no se ejecuta el callback del insert, cuando se ejecuta correctamente?
Con este codigo que os paso, me deja bloqueada la petición en el navegador (ya que el res.render() nunca se ejecuta).. si saco el render() fuera del callback. si termina la petición en el navegador.. pero obviamente falta información y no controlo en que momento se va a ejecutar.
Gracias, un saludo.
P.D.: La funcion MAIL() es una funcion a nivel global creada por mi, para el envio de correo. Esta y todo el resto codigo funciona correctamente, solo dejan de ejecutarse cuando lo introduzco en el callback del insert.