/
token.js
49 lines (42 loc) · 1.25 KB
/
token.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
const axios = require('axios');
const qs = require('query-string');
const { ZOOM_OAUTH_ENDPOINT } = require('../constants');
const redis = require('../configs/redis');
/**
* Retrieve token from Zoom API
*
* @returns {Object} { access_token, expires_in, error }
*/
const getToken = async () => {
try {
const { ZOOM_ACCOUNT_ID, ZOOM_CLIENT_ID, ZOOM_CLIENT_SECRET } = process.env;
const request = await axios.post(
ZOOM_OAUTH_ENDPOINT,
qs.stringify({ grant_type: 'account_credentials', account_id: ZOOM_ACCOUNT_ID }),
{
headers: {
Authorization: `Basic ${Buffer.from(`${ZOOM_CLIENT_ID}:${ZOOM_CLIENT_SECRET}`).toString('base64')}`,
},
},
);
const { access_token, expires_in } = await request.data;
return { access_token, expires_in, error: null };
} catch (error) {
return { access_token: null, expires_in: null, error };
}
};
/**
* Set zoom access token with expiration in redis
*
* @param {Object} auth_object
* @param {String} access_token
* @param {int} expires_in
*/
const setToken = async ({ access_token, expires_in }) => {
await redis.set('access_token', access_token);
await redis.expire('access_token', expires_in);
};
module.exports = {
getToken,
setToken,
};