-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
93 lines (72 loc) · 2.41 KB
/
index.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
89
90
91
92
93
const express = require('express');
const { google } = require('googleapis');
const bodyParser = require('body-parser');
const { v4: uuidv4 } = require('uuid');
const app = express();
app.use(bodyParser.json());
const CLIENT_ID = process.env.CLIENT_ID;
const CLIENT_SECRET = process.env.CLIENT_SECRET;
const REDIRECT_URI = process.env.REDIRECT_URI;
const oauth2Client = new google.auth.OAuth2(CLIENT_ID, CLIENT_SECRET, REDIRECT_URI);
const SCOPES = ['https://www.googleapis.com/auth/drive'];
// Store device codes temporarily
const deviceCodes = new Map();
app.post('/device', (req, res) => {
const userCode = uuidv4().slice(0, 8); // Generate a short userCode
const deviceCode = uuidv4();
deviceCodes.set(deviceCode, { userCode, authenticated: false });
res.json({ userCode, deviceCode });
});
app.get('/auth', (req, res) => {
const userCode = req.query.code;
let deviceCode = null;
for (const [key, value] of deviceCodes.entries()) {
if (value.userCode === userCode) {
deviceCode = key;
break;
}
}
if (!deviceCode) {
return res.status(400).send('Invalid code');
}
const authUrl = oauth2Client.generateAuthUrl({
access_type: 'offline',
scope: SCOPES,
state: deviceCode,
prompt: 'consent'
});
res.redirect(authUrl);
});
app.get('/oauth2callback', async (req, res) => {
const { code, state: deviceCode } = req.query;
try {
const { tokens } = await oauth2Client.getToken(code);
oauth2Client.setCredentials(tokens);
const deviceCodeData = deviceCodes.get(deviceCode);
if (deviceCodeData) {
deviceCodeData.authenticated = true;
deviceCodeData.tokens = tokens;
}
res.send('Authentication successful! You can close this window.');
} catch (error) {
console.error('Error retrieving access token', error);
res.status(500).send('Authentication failed');
}
});
app.get('/token/:deviceCode', (req, res) => {
const { deviceCode } = req.params;
const deviceCodeData = deviceCodes.get(deviceCode);
if (deviceCodeData) {
if (deviceCodeData.authenticated) {
deviceCodes.delete(deviceCode);
return res.json(deviceCodeData.tokens);
} else {
return res.status(400).json({ error: 'authorization_pending' });
}
}
res.status(404).json({ error: 'not_found' });
});
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
});