@nitra/vite-boot 1.0.8 → 1.0.12

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 CHANGED
@@ -1,13 +1,14 @@
1
1
  {
2
2
  "name": "@nitra/vite-boot",
3
- "version": "1.0.8",
3
+ "version": "1.0.12",
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",
@@ -21,7 +22,18 @@
21
22
  "author": "vitaliytv <vitaliytv@nitralabs.com>",
22
23
  "license": "MIT",
23
24
  "prettier": "@nitra/prettier-config",
25
+ "eslintConfig": {
26
+ "extends": [
27
+ "@nitra/eslint-config/vue"
28
+ ],
29
+ "globals": {
30
+ "__HASURA_ROLE__": "readonly",
31
+ "__SENTRY_DSN__": "readonly",
32
+ "__GITHUB_SHA__": "readonly"
33
+ }
34
+ },
24
35
  "devDependencies": {
36
+ "@nitra/eslint-config": "^1.0.9",
25
37
  "@nitra/prettier-config": "^1.0.0"
26
38
  },
27
39
  "files": [
@@ -29,7 +41,7 @@
29
41
  ],
30
42
  "dependencies": {
31
43
  "@apollo/client": "^3.5.6",
32
- "@nitra/consola": "^1.3.1",
44
+ "@nitra/consola": "^1.6.1",
33
45
  "@sentry/tracing": "^6.16.1",
34
46
  "@sentry/vue": "^6.16.1",
35
47
  "graphql": "^16.2.0",
package/src/apollo.js CHANGED
@@ -4,14 +4,11 @@ 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/browser'
8
- import { isDev, isProd } from '@nitra/isenv'
7
+ import { createLogger } from '@nitra/consola'
8
+ import { refreshToken } from './token.js'
9
9
 
10
10
  const consola = createLogger(import.meta.url)
11
11
 
12
- console.log('isDev', isDev)
13
- console.log('isProd', isProd)
14
-
15
12
  class WebSocketLink extends ApolloLink {
16
13
  constructor(options) {
17
14
  super()
@@ -64,19 +61,11 @@ const wsLink = new WebSocketLink({
64
61
  }
65
62
  })
66
63
 
67
- const errorLink = onError(({ graphQLErrors, networkError, operation, forward }) => {
64
+ const errorLink = onError(({ graphQLErrors, networkError, _operation, _forward }) => {
68
65
  if (graphQLErrors) {
69
66
  for (const err of graphQLErrors) {
70
67
  consola.debug('graphQLErrors: ', err)
71
68
 
72
- // TODO: реалізуввати ретрай токен
73
- // ще один токен
74
- // в якому будуть міститись закодовані дані користувача
75
- // и якщо цей користувач ще валідний в БД
76
- // то видавати йому новий токен
77
- // тобто ця перевірка універсальна
78
- // не в залежності який типом авторизувався користувач
79
- // а в залежності від того чи він валідний в БД
80
69
  // switch (err.extensions.code) {
81
70
  // // Apollo Server sets code to UNAUTHENTICATED
82
71
  // // when an AuthenticationError is thrown in a resolver
@@ -99,8 +88,13 @@ const errorLink = onError(({ graphQLErrors, networkError, operation, forward })
99
88
  // instead of the onError link. This just logs the error.
100
89
  if (networkError) {
101
90
  if (networkError?.message.match('JWTExpired')) {
102
- localStorage.removeItem('token')
103
- window.location.replace('/login')
91
+ // ретрай токен
92
+ // и якщо цей користувач ще валідний в БД
93
+ // то видавати йому новий токен
94
+ // тобто ця перевірка універсальна
95
+ // не в залежності який типом авторизувався користувач
96
+ // а в залежності від того чи він валідний в БД
97
+ refreshToken()
104
98
  } else {
105
99
  console.log(`[Network error]: ${networkError}`)
106
100
  }
package/src/i18n.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { createI18n } from 'petite-vue-i18n'
2
- import { createLogger } from '@nitra/consola/browser'
2
+ import { persistStore } from 'src/stores/persist.js'
3
3
 
4
4
  const consola = createLogger(import.meta.url)
5
5
 
@@ -29,4 +29,12 @@ export const mt = uk => {
29
29
  return ukP
30
30
  }
31
31
 
32
+ export const updGlobalLocale = lang => {
33
+ const persist = persistStore()
34
+ if (lang) {
35
+ persist.locale = lang
36
+ }
37
+ i18n.global.locale.value = persist.locale
38
+ }
39
+
32
40
  consola.debug('End i18n boot')
package/src/pinia.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { createPinia } from 'pinia'
2
2
  import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
3
- import { createLogger } from '@nitra/consola/browser'
3
+ import { createLogger } from '@nitra/consola'
4
4
 
5
5
  const consola = createLogger(import.meta.url)
6
6
 
package/src/token.js ADDED
@@ -0,0 +1,52 @@
1
+ import { createLogger } from '@nitra/consola'
2
+
3
+ const consola = createLogger(import.meta.url)
4
+
5
+ /**
6
+ * Ініціалізація Sentry
7
+ */
8
+ export const refreshToken = async () => {
9
+ try {
10
+ const token = localStorage.getItem('token')
11
+
12
+ consola.debug('token refresh', token)
13
+
14
+ if (!token) {
15
+ // Чекаємо, можливо це паралельний JWTExpired
16
+ consola.debug('begin wait 5 sec')
17
+ await sleep(5000)
18
+ consola.debug('end wait, start logout')
19
+ window.location.replace('/logout')
20
+ } else {
21
+ // Прибираємо токен, щоб інші паралельні JWTExpired не виконувались
22
+ localStorage.removeItem('token')
23
+ consola.debug('token cleaned')
24
+
25
+ const response = await fetch('/refresh-token', {
26
+ method: 'POST',
27
+ headers: {
28
+ 'Content-Type': 'application/json'
29
+ },
30
+ body: JSON.stringify({ token })
31
+ })
32
+ const result = await response.json()
33
+ consola.debug('result refresh', result)
34
+
35
+ if (result.token) {
36
+ // якщо токен прийшов - замінюємо його
37
+ localStorage.setItem('token', result.token)
38
+ // та перезавантажуємо щоб він вступив в дію
39
+ window.location.reload()
40
+ } else {
41
+ // інакше вихід
42
+ window.location.replace('/logout')
43
+ }
44
+ }
45
+ } catch (error) {
46
+ console.error('Error:', error)
47
+ }
48
+ }
49
+
50
+ function sleep(ms) {
51
+ return new Promise(resolve => setTimeout(resolve, ms))
52
+ }