🐛 (login) refresh token 15 minutes before expiration
This commit is contained in:
@@ -26,7 +26,7 @@ export const getOctokit = async (): Promise<Octokit> => {
|
|||||||
const accessToken = await refreshToken()
|
const accessToken = await refreshToken()
|
||||||
if (accessToken) {
|
if (accessToken) {
|
||||||
octokit = new Octokit({
|
octokit = new Octokit({
|
||||||
auth: accessToken?.token
|
auth: accessToken.token
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import { GithubAccessToken } from '@/data/models/GithubAccessToken'
|
|||||||
import { GithubToken } from '@/modules/user/interfaces/GithubToken'
|
import { GithubToken } from '@/modules/user/interfaces/GithubToken'
|
||||||
import { GithubTokenError } from '@/modules/user/interfaces/GithubTokenError'
|
import { GithubTokenError } from '@/modules/user/interfaces/GithubTokenError'
|
||||||
import { Octokit } from '@octokit/rest'
|
import { Octokit } from '@octokit/rest'
|
||||||
import { addMinutes, addSeconds } from 'date-fns'
|
import { addMinutes, addSeconds, isBefore } from 'date-fns'
|
||||||
|
|
||||||
const AUTHENTICATION_SERVER = 'https://litenote.li212.fr'
|
const AUTHENTICATION_SERVER = 'https://litenote.li212.fr'
|
||||||
const personalTokenId = 'token'
|
const personalTokenId = 'token'
|
||||||
@@ -31,7 +31,10 @@ export const needToRefreshToken = async () => {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Date(accessToken.expirationDate) <= addMinutes(new Date(), -15)
|
const expirationDate = new Date(accessToken.expirationDate)
|
||||||
|
const dateToCompare = addMinutes(new Date(), 15)
|
||||||
|
|
||||||
|
return isBefore(expirationDate, dateToCompare)
|
||||||
}
|
}
|
||||||
|
|
||||||
export const refreshToken = async () => {
|
export const refreshToken = async () => {
|
||||||
@@ -46,8 +49,6 @@ export const refreshToken = async () => {
|
|||||||
|
|
||||||
const needRefresh = await needToRefreshToken()
|
const needRefresh = await needToRefreshToken()
|
||||||
|
|
||||||
console.log(accessToken.refreshToken, needRefresh)
|
|
||||||
|
|
||||||
if (needRefresh) {
|
if (needRefresh) {
|
||||||
const authenticationServerURL = new URL(AUTHENTICATION_SERVER)
|
const authenticationServerURL = new URL(AUTHENTICATION_SERVER)
|
||||||
authenticationServerURL.searchParams.set('type', 'refresh')
|
authenticationServerURL.searchParams.set('type', 'refresh')
|
||||||
|
|||||||
@@ -8,11 +8,10 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { defineComponent, defineAsyncComponent, computed, onMounted } from 'vue'
|
import { defineComponent, defineAsyncComponent, computed } from 'vue'
|
||||||
import { useQueryStackedNotes } from '@/hooks/useQueryStackedNotes.hook'
|
import { useQueryStackedNotes } from '@/hooks/useQueryStackedNotes.hook'
|
||||||
import NewVersion from '@/components/NewVersion.vue'
|
import NewVersion from '@/components/NewVersion.vue'
|
||||||
import Authorize from '@/components/Authorize.vue'
|
import Authorize from '@/components/Authorize.vue'
|
||||||
import { refreshToken } from '@/modules/user/service/signIn'
|
|
||||||
|
|
||||||
const FluxNote = defineAsyncComponent(() => import('@/components/FluxNote.vue'))
|
const FluxNote = defineAsyncComponent(() => import('@/components/FluxNote.vue'))
|
||||||
|
|
||||||
@@ -34,13 +33,6 @@ export default defineComponent({
|
|||||||
},
|
},
|
||||||
setup(props) {
|
setup(props) {
|
||||||
const { resetStackedNotes } = useQueryStackedNotes()
|
const { resetStackedNotes } = useQueryStackedNotes()
|
||||||
onMounted(() => {
|
|
||||||
refreshToken()
|
|
||||||
})
|
|
||||||
|
|
||||||
onMounted(() => {
|
|
||||||
refreshToken()
|
|
||||||
})
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
resetStackedNotes,
|
resetStackedNotes,
|
||||||
|
|||||||
Reference in New Issue
Block a user