-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
55 lines (45 loc) · 1.48 KB
/
server.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
var express = require('express')
var cors = require('cors');
const fetch = (...args) =>
import('node-fetch').then(({default: fetch}) => fetch(...args));
var bodyParser = require('body-parser');
const CLIENT_ID = "1ae3e0de7d70a65589dd";
const CLIENT_SEC = "1a36b3621c8e6de8bc8325a00384b823ab80ed81"
var app = express();
app.use(cors());
app.use(bodyParser.json());
//code being passed from the frontend
app.get('/getAccessToken', async function (req, res){
console.log(req.query.code);
const params = "?client_id=" + CLIENT_ID + "&client_secret=" + CLIENT_SEC + "&code=" + req.query.code;
await fetch("https://github.com/login/oauth/access_token" + params, {
method: "POST",
headers: {
"Accept": "application/json"
}
}).then((response) => {
return response.json();
}).then((data) => {
console.log(data);
res.json(data);
});
})
// getUserData
// access token is going to be passed in as an Authorization header
app.get('/getUserData', async function (req, res){
req.get("Authorization"); // Bearer ACCESSTOKEN
await fetch("https://api.github.com/user", {
method: "GET",
headers: {
"Authorization": req.get("Authorization") // Bearer ACCESSTOKEN
}
}).then((response) => {
return response.json();
}).then((data) => {
console.log(data)
res.json(data)
})
})
app.listen(4000, function(){
console.log("CORS server running on port 4000")
})