/
app.js
executable file
·88 lines (70 loc) · 2.25 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
var express = require('express');
var request = require('request');
var querystring = require('querystring');
var cookieParser = require('cookie-parser');
require('dotenv').config();
var port = process.env.PORT || 8080;
var redirect_uri = port === 8080? 'http://192.168.1.68:8080/result' : 'https://music-signature.herokuapp.com/result';
var client_id = process.env.CLIENT_ID;
var client_secret = process.env.CLIENT_SECRET;
var stateKey = 'spotify_auth_state';
var app = express();
app.set('view engine', 'ejs');
app.use(cookieParser());
app.use(express.static(__dirname + '/public'));
app.set('views', __dirname + '/public');
app.get('/', (req, res) => {
res.render('index');
});
app.get('/login', (req, res) => {
var state = generateRandomString(16);
res.cookie('stateKey', state);
var scope = 'user-library-read user-top-read';
res.redirect('https://accounts.spotify.com/authorize/?' +
querystring.stringify({
client_id: client_id,
redirect_uri: redirect_uri,
response_type: 'code',
scope: scope,
state: state,
// show_dialog: true
}));
});
app.get('/result', (req, res) => {
const code = req.query.code || null;
const storedCode = req.cookies.storedCode || null;
if (storedCode === code)
{
res.clearCookie('storedCode');
res.redirect('/login');
}
else {
res.cookie('storedCode', code);
let authOptions = {
url: 'https://accounts.spotify.com/api/token',
form: {
code: code,
redirect_uri: redirect_uri,
grant_type: 'authorization_code'
},
headers: {
'Authorization': 'Basic ' + (new Buffer(client_id + ':' + client_secret).toString('base64'))
},
json: true
};
request.post(authOptions, (error, response, body) => {
const accessToken = body.access_token;
res.cookie('access_token', accessToken)
res.render('result', {accessToken: accessToken});
});
}
});
var generateRandomString = function(length) {
var text = '';
var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for (var i = 0; i < length; i++) {
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
};
app.listen(port, () => console.log('listening on: '+port));