🐛 (login) refresh token 15 minutes before expiration

This commit is contained in:
2021-05-13 16:34:30 +02:00
parent fce3fd49cf
commit 84ba5fcd46
3 changed files with 7 additions and 14 deletions

View File

@@ -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
}) })
} }
} }

View File

@@ -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')

View File

@@ -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,