l-assiette/Backend/revisarUsuarioG.ts

80 lines
3.2 KiB
TypeScript
Raw Normal View History

const validator = require('./google_validation.js').validator;
const crearUsuario = (con:any, data:object) => {
return new Promise((resolve, reject) => {
2018-11-02 16:39:33 +00:00
con.query (
`INSERT INTO usuarios (nombre, email, img, carritoActual, GOOGLE_ID, ROL)\
VALUES ('${(data as any)["nombreUsuario"]}', '${(data as any)["emailUsuario"]}',
'${(data as any)["imagenUsuario"]}', '{}', '${(data as any)["googleID"]}', 'user')`,
(err:any, res:string) => {
if (err) {
2018-11-02 16:39:33 +00:00
reject("Error al ejecutar query SQL (revisarUsuarioG.ts fila 18))...\n" + err);
}
2018-11-02 16:39:33 +00:00
console.log("Resultado de añadir usuario a la BBDD (revisarUsuarioG.ts 22):\n" + res);
resolve("Exito.");
}
);
});
};
2018-11-02 16:39:33 +00:00
const revisarUsuarioG = (usuario:object, sesion:any) => {
return new Promise((resolve, reject) => {
const mysql = require('mysql');
2018-11-02 16:39:33 +00:00
const SQL_CONNECT_DATA = require('./VARIABLES').sqlConnectData;
2018-11-02 16:39:33 +00:00
const con = mysql.createConnection(SQL_CONNECT_DATA);
con.connect( (err:any) => {
if (err) {
reject("Error al conectarse a la BBDD.");
}
const nombreUsuario:string = (usuario as any)["name"];
const emailUsuario:string = (usuario as any)["email"];
const imagenUsuario:string = (usuario as any)["picture"];
const googleID:number = (usuario as any)["sub"];
2018-11-02 16:39:33 +00:00
con.query (`SELECT nombre, email, img, carritoActual, USER_ID, ROL FROM usuarios WHERE GOOGLE_ID='${googleID}'`,
(err:any, response:any) => {
if (err) {
reject("Error al ejecutar query SQL");
}
const respuestaBD:string = JSON.stringify(response);
if (respuestaBD === '[]') {
crearUsuario(con, {nombreUsuario, emailUsuario, imagenUsuario, googleID})
.then( () => {
resolve(`{ "nombre": "${nombreUsuario}", "email": "${emailUsuario}", "img": "${imagenUsuario}",
2018-11-02 16:39:33 +00:00
"carrito": {}, "rol": "user"}`);
})
.catch((msg:string) => {
reject("Error al crear el usuario...\n" + msg);
})
} else {
console.log(`Respuesta servidor:\n${respuestaBD}`);
resolve(JSON.stringify(response[0]));
}
});
});
});
};
2018-11-02 16:39:33 +00:00
const revisarUsuario = (req:any, res:any) => {
res.header('Access-Control-Allow-Origin', 'http://localhost:8081');
res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE');
res.header('Access-Control-Allow-Headers', 'Content-Type');
const token:string = req.body.idtoken;
validator(token)
.then( (usuario:object) => {
2018-11-02 16:39:33 +00:00
revisarUsuarioG(usuario, req.session)
.then(response => res.send(response.toString()))
.catch(err => res.send(err))
})
.catch(console.error);
2018-11-02 16:39:33 +00:00
};
2018-11-02 16:39:33 +00:00
module.exports.revisarUsuarioG = revisarUsuario;