@nitra/vite-boot 1.0.9 → 1.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +9 -3
- package/src/apollo.js +10 -13
- package/src/token.js +27 -0
package/package.json
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nitra/vite-boot",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.10",
|
|
4
4
|
"description": "Vite boot",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
7
7
|
"./apollo": "./src/apollo.js",
|
|
8
8
|
"./i18n": "./src/i18n.js",
|
|
9
9
|
"./pinia": "./src/pinia.js",
|
|
10
|
-
"./sentry": "./src/sentry.js"
|
|
10
|
+
"./sentry": "./src/sentry.js",
|
|
11
|
+
"./token": "./src/token.js"
|
|
11
12
|
},
|
|
12
13
|
"repository": {
|
|
13
14
|
"type": "git",
|
|
@@ -24,7 +25,12 @@
|
|
|
24
25
|
"eslintConfig": {
|
|
25
26
|
"extends": [
|
|
26
27
|
"@nitra/eslint-config/vue"
|
|
27
|
-
]
|
|
28
|
+
],
|
|
29
|
+
"globals": {
|
|
30
|
+
"__HASURA_ROLE__": "readonly",
|
|
31
|
+
"__SENTRY_DSN__": "readonly",
|
|
32
|
+
"__GITHUB_SHA__": "readonly"
|
|
33
|
+
}
|
|
28
34
|
},
|
|
29
35
|
"devDependencies": {
|
|
30
36
|
"@nitra/eslint-config": "^1.0.9",
|
package/src/apollo.js
CHANGED
|
@@ -4,7 +4,8 @@ import { ApolloLink, ApolloClient, Observable, InMemoryCache, from } from '@apol
|
|
|
4
4
|
import { onError } from '@apollo/client/link/error'
|
|
5
5
|
import { print } from 'graphql'
|
|
6
6
|
import { createClient } from 'graphql-ws'
|
|
7
|
-
import { createLogger } from '@nitra/consola
|
|
7
|
+
import { createLogger } from '@nitra/consola'
|
|
8
|
+
import { refreshToken } from './token.js'
|
|
8
9
|
|
|
9
10
|
const consola = createLogger(import.meta.url)
|
|
10
11
|
|
|
@@ -60,19 +61,11 @@ const wsLink = new WebSocketLink({
|
|
|
60
61
|
}
|
|
61
62
|
})
|
|
62
63
|
|
|
63
|
-
const errorLink = onError(({ graphQLErrors, networkError,
|
|
64
|
+
const errorLink = onError(({ graphQLErrors, networkError, _operation, _forward }) => {
|
|
64
65
|
if (graphQLErrors) {
|
|
65
66
|
for (const err of graphQLErrors) {
|
|
66
67
|
consola.debug('graphQLErrors: ', err)
|
|
67
68
|
|
|
68
|
-
// TODO: реалізуввати ретрай токен
|
|
69
|
-
// ще один токен
|
|
70
|
-
// в якому будуть міститись закодовані дані користувача
|
|
71
|
-
// и якщо цей користувач ще валідний в БД
|
|
72
|
-
// то видавати йому новий токен
|
|
73
|
-
// тобто ця перевірка універсальна
|
|
74
|
-
// не в залежності який типом авторизувався користувач
|
|
75
|
-
// а в залежності від того чи він валідний в БД
|
|
76
69
|
// switch (err.extensions.code) {
|
|
77
70
|
// // Apollo Server sets code to UNAUTHENTICATED
|
|
78
71
|
// // when an AuthenticationError is thrown in a resolver
|
|
@@ -95,9 +88,13 @@ const errorLink = onError(({ graphQLErrors, networkError, operation, forward })
|
|
|
95
88
|
// instead of the onError link. This just logs the error.
|
|
96
89
|
if (networkError) {
|
|
97
90
|
if (networkError?.message.match('JWTExpired')) {
|
|
98
|
-
|
|
99
|
-
//
|
|
100
|
-
|
|
91
|
+
// ретрай токен
|
|
92
|
+
// и якщо цей користувач ще валідний в БД
|
|
93
|
+
// то видавати йому новий токен
|
|
94
|
+
// тобто ця перевірка універсальна
|
|
95
|
+
// не в залежності який типом авторизувався користувач
|
|
96
|
+
// а в залежності від того чи він валідний в БД
|
|
97
|
+
refreshToken()
|
|
101
98
|
} else {
|
|
102
99
|
console.log(`[Network error]: ${networkError}`)
|
|
103
100
|
}
|
package/src/token.js
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ініціалізація Sentry
|
|
3
|
+
*/
|
|
4
|
+
export const refreshToken = async () => {
|
|
5
|
+
try {
|
|
6
|
+
const response = await fetch('/refresh-token', {
|
|
7
|
+
method: 'POST',
|
|
8
|
+
headers: {
|
|
9
|
+
'Content-Type': 'application/json'
|
|
10
|
+
},
|
|
11
|
+
body: JSON.stringify({ token: localStorage.getItem('token') })
|
|
12
|
+
})
|
|
13
|
+
const result = await response.json()
|
|
14
|
+
|
|
15
|
+
if (result.token) {
|
|
16
|
+
// якщо токен прийшов - замінюємо його
|
|
17
|
+
localStorage.setItem('token', result.token)
|
|
18
|
+
// та перезавантажуємо щоб він вступив в дію
|
|
19
|
+
window.location.reload()
|
|
20
|
+
} else {
|
|
21
|
+
// інакше вихід
|
|
22
|
+
window.location.replace('/logout')
|
|
23
|
+
}
|
|
24
|
+
} catch (error) {
|
|
25
|
+
console.error('Error:', error)
|
|
26
|
+
}
|
|
27
|
+
}
|