l-assiette/Backend/start.ts

93 lines
3.3 KiB
TypeScript
Raw Normal View History

declare var require:any;
const express = require('express');
const app = express();
app.use(express.json());
app.use(express.urlencoded());
const port:number = 3000;
const validator = require('./google_validation.js').validator;
const crearUsuario = (con:any, data:object) => {
return new Promise((resolve, reject) => {
con.query (`INSERT INTO usuarios (nombre, email, img, carritoActual, GOOGLE_ID)\
VALUES ( '${(data as any)["nombreUsuario"]}', '${(data as any)["emailUsuario"]}',
'${(data as any)["imagenUsuario"]}', '{}', '${(data as any)["googleID"]}')`,
(err:any, res:string) => {
if (err) {
reject("Error al ejecutar query SQL (start.ts fila 18))...\n" + err);
}
resolve("Exito.");
}
);
});
};
const revisarUsuarioG = (usuario:object) => {
return new Promise((resolve, reject) => {
const mysql = require('mysql');
const con = mysql.createConnection({
host: '35.193.16.64',
user: 'Araozu',
password: 'xsakah4b',
database: 'Usuarios_DB'
});
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"];
con.query (`SELECT nombre, email, img, carritoActual, USER_ID 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}",
"carrito": {}`);
})
.catch((msg:string) => {
reject("Error al crear el usuario...\n" + msg);
})
} else {
console.log(`Respuesta servidor:\n${respuestaBD}`);
resolve(JSON.stringify(response[0]));
}
});
});
});
};
app.post('/log-inG',(req:any, res:any) => {
res.header('Access-Control-Allow-Origin', 'http://localhost:8080');
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) => {
revisarUsuarioG(usuario)
.then(response => res.send(response.toString()))
.catch(err => res.send(err))
})
.catch(console.error);
});
app.listen(port, () => {
console.log(`Estoy escuchando el puerto ${port} we v:`);
});