Update app.js

main
Félix MIELCAREK 11 months ago committed by GitHub
parent d0704a4992
commit fec5818cbd
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -12,25 +12,15 @@ const redirectUri = 'https://felixmielcarek.github.io/callback/';
//#endregion //#endregion
//#region APP INIT //#region APP INIT
const app = express() const app = express()
app.listen(port, () => { console.log(`Big brother is listening on port ${port}`) }) app.listen(port, () => { console.log(`Big brother is listening on port ${port}`) })
//#endregion //#endregion
//#region ACCESS TOKEN //#region ACCESS TOKEN
app.get('/settings/deactivate', async (req,res) => { app.get('/settings/deactivate', async (req,res) => {
//console.log("
const code = req.query.code; const code = req.query.code;
const authOptions = {
const pool = mariadb.createPool({
host: 'felixmielcarek-bigbrotherdb',
user: process.env.MARIADB_USER,
database: process.env.MARIADB_DATABASE,
password: process.env.MARIADB_PASSWORD,
connectionLimit: 5
});
var authOptions = {
url: 'https://accounts.spotify.com/api/token', method: 'post', json: true, url: 'https://accounts.spotify.com/api/token', method: 'post', json: true,
data: { code: code, redirect_uri: redirectUri, grant_type: 'authorization_code' }, data: { code: code, redirect_uri: redirectUri, grant_type: 'authorization_code' },
headers: { headers: {
@ -38,22 +28,32 @@ app.get('/settings/deactivate', async (req,res) => {
'Authorization': 'Basic ' + (new Buffer.from(clientId + ':' + clientSecret).toString('base64')) 'Authorization': 'Basic ' + (new Buffer.from(clientId + ':' + clientSecret).toString('base64'))
} }
}; };
let userId;
const response1 = await axios(authOptions);
const accessToken = response1.data.access_token
let conn;
try { try {
conn = await pool.getConnection() const response1 = await axios(authOptions);
const accessToken = response1.data.access_token;
const response2 = await axios.get(`https://api.spotify.com/v1/me`, { headers: { 'Authorization': 'Bearer ' + accessToken, } }); const response2 = await axios.get(`https://api.spotify.com/v1/me`, { headers: { 'Authorization': 'Bearer ' + accessToken, } });
userId = response2.data.SpotifyId;
} catch (error) { console.log(`Error getting user Spotify id: ${error}`) }
const sqlQuery = ` const sqlQuery = `
DELETE FROM users DELETE FROM users
WHERE spotifyid = ?; WHERE spotifyid = ?;
`; `;
conn.query(sqlQuery, [response2.data.SpotifyId], (err, res) => { try {
const pool = mariadb.createPool({
host: 'felixmielcarek-bigbrotherdb',
user: process.env.MARIADB_USER,
database: process.env.MARIADB_DATABASE,
password: process.env.MARIADB_PASSWORD,
connectionLimit: 5
});
const conn = await pool.getConnection();
conn.query(sqlQuery, [userId], (err, res) => {
if (err) { if (err) {
console.error('Error executing query', err); console.error('Error executing query', err);
return; return;
@ -61,21 +61,12 @@ app.get('/settings/deactivate', async (req,res) => {
console.log('Data deleted successfully'); console.log('Data deleted successfully');
conn.end(); conn.end();
}); });
} catch (error) { console.log('Error getting user Spotify id') } } catch (error) { console.log(`Error accessing database: ${error}`) }
}) })
app.get('/', async (req, res) => { app.get('/', async (req, res) => {
const pool = mariadb.createPool({
host: 'felixmielcarek-bigbrotherdb',
user: process.env.MARIADB_USER,
database: process.env.MARIADB_DATABASE,
password: process.env.MARIADB_PASSWORD,
connectionLimit: 5
});
const code = req.query.code; const code = req.query.code;
const authOptions = {
var authOptions = {
url: 'https://accounts.spotify.com/api/token', method: 'post', json: true, url: 'https://accounts.spotify.com/api/token', method: 'post', json: true,
data: { code: code, redirect_uri: redirectUri, grant_type: 'authorization_code' }, data: { code: code, redirect_uri: redirectUri, grant_type: 'authorization_code' },
headers: { headers: {
@ -83,23 +74,19 @@ app.get('/', async (req, res) => {
'Authorization': 'Basic ' + (new Buffer.from(clientId + ':' + clientSecret).toString('base64')) 'Authorization': 'Basic ' + (new Buffer.from(clientId + ':' + clientSecret).toString('base64'))
} }
}; };
let data;
try {
const response1 = await axios(authOptions); const response1 = await axios(authOptions);
const accessToken = response1.data.access_token const accessToken = response1.data.access_token
const refreshToken = response1.data.refresh_token const refreshToken = response1.data.refresh_token
let conn;
try {
conn = await pool.getConnection()
const response2 = await axios.get(`https://api.spotify.com/v1/me`, { headers: { 'Authorization': 'Bearer ' + accessToken, } }); const response2 = await axios.get(`https://api.spotify.com/v1/me`, { headers: { 'Authorization': 'Bearer ' + accessToken, } });
data = {
const data = {
SpotifyId: response2.data.id, SpotifyId: response2.data.id,
AccessToken: accessToken, AccessToken: accessToken,
RefreshToken: refreshToken RefreshToken: refreshToken
}; };
} catch (error) { console.log(`Error getting user Spotify id: ${error}`) }
const sqlQuery = ` const sqlQuery = `
INSERT INTO users (spotifyid, accesstoken, refreshtoken) INSERT INTO users (spotifyid, accesstoken, refreshtoken)
@ -109,6 +96,17 @@ app.get('/', async (req, res) => {
refreshtoken = VALUES(refreshtoken); refreshtoken = VALUES(refreshtoken);
`; `;
try {
const pool = mariadb.createPool({
host: 'felixmielcarek-bigbrotherdb',
user: process.env.MARIADB_USER,
database: process.env.MARIADB_DATABASE,
password: process.env.MARIADB_PASSWORD,
connectionLimit: 5
});
const conn = await pool.getConnection();
conn.query(sqlQuery, [data.SpotifyId, data.AccessToken, data.RefreshToken], (err, res) => { conn.query(sqlQuery, [data.SpotifyId, data.AccessToken, data.RefreshToken], (err, res) => {
if (err) { if (err) {
console.error('Error executing query', err); console.error('Error executing query', err);
@ -117,6 +115,6 @@ app.get('/', async (req, res) => {
console.log('Data inserted/updated successfully'); console.log('Data inserted/updated successfully');
conn.end(); conn.end();
}); });
} catch (error) { console.log('Error getting user Spotify id') } } catch (error) { console.log(`Error accessing database: ${error}`) }
}); });
//#endregion //#endregion
Loading…
Cancel
Save