27 lines
933 B
JavaScript
27 lines
933 B
JavaScript
require('dotenv').config()
|
|
|
|
const validateToken = require('./validateToken')
|
|
const refreshToken = require('./refreshToken')
|
|
const writeEnv = require('./writeEnv')
|
|
|
|
let client_id = process.env.TWITCH_APP_ID
|
|
let client_secret = process.env.TWITCH_APP_SECRET
|
|
|
|
module.exports = async function (access_token) {
|
|
|
|
// Check if user_access_token is valid
|
|
if (!await validateToken(access_token)) {
|
|
|
|
// If not, refresh it
|
|
let result = await refreshToken(client_id, client_secret, access_token)
|
|
if (result.status) return `Can't refresh user_access_token: ${result.message}`
|
|
|
|
let [user_access_token, user_refresh_token] = result
|
|
writeEnv('TWITCH_USER_ACCESS_TOKEN', user_access_token)
|
|
writeEnv('TWITCH_USER_REFRESH_TOKEN', user_refresh_token)
|
|
|
|
let user_name = await getUserInfo(client_id, user_access_token).login
|
|
writeEnv('TWITCH_USER_USERNAME', user_name)
|
|
}
|
|
return [user_access_token, user_name]
|
|
} |