🐛 (authentication) simplify refres…
This commit is contained in:
@@ -1,37 +1,10 @@
|
|||||||
import { useGitHubLogin } from '@/hooks/useGitHubLogin.hook'
|
import { getAccessToken } from '@/modules/user/service/signIn'
|
||||||
import { needToRefreshToken, refreshToken } from '@/modules/user/service/signIn'
|
|
||||||
import { Octokit } from '@octokit/rest'
|
import { Octokit } from '@octokit/rest'
|
||||||
|
|
||||||
let refreshingToken = false
|
|
||||||
let octokit = new Octokit()
|
|
||||||
|
|
||||||
const sleep = async (ms: number) => {
|
|
||||||
return new Promise((resolve) => setTimeout(resolve, ms))
|
|
||||||
}
|
|
||||||
|
|
||||||
export const getOctokit = async (): Promise<Octokit> => {
|
export const getOctokit = async (): Promise<Octokit> => {
|
||||||
const { accessToken } = useGitHubLogin()
|
const response = await getAccessToken()
|
||||||
octokit = new Octokit({
|
|
||||||
auth: accessToken.value
|
|
||||||
})
|
|
||||||
|
|
||||||
if (refreshingToken) {
|
return new Octokit({
|
||||||
await sleep(100)
|
auth: response?.token ?? ''
|
||||||
return getOctokit()
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!refreshingToken) {
|
|
||||||
refreshingToken = true
|
|
||||||
if (await needToRefreshToken()) {
|
|
||||||
const accessToken = await refreshToken()
|
|
||||||
if (accessToken) {
|
|
||||||
octokit = new Octokit({
|
|
||||||
auth: accessToken.token
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
|
||||||
refreshingToken = false
|
|
||||||
}
|
|
||||||
|
|
||||||
return octokit
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user