@nitra/vite-boot 3.2.1 → 3.3.1

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,6 +1,6 @@
1
1
  {
2
2
  "name": "@nitra/vite-boot",
3
- "version": "3.2.1",
3
+ "version": "3.3.1",
4
4
  "description": "Vite boot",
5
5
  "type": "module",
6
6
  "exports": {
package/src/login.js CHANGED
@@ -1,4 +1,4 @@
1
- import { checkToken } from './token.js'
1
+ import { checkToken, getToken } from './token.js'
2
2
  import { setUser } from './user.js'
3
3
  // import { router } from './router.js'
4
4
  // Використовуємо глобальну версію
@@ -7,7 +7,7 @@ import { router } from '@nitra/vite-boot/router'
7
7
  /**
8
8
  * Автоматичний вхід користувача
9
9
  *
10
- * @param {{}} token
10
+ * @param {String} token
11
11
  */
12
12
  export async function autoLogin(token) {
13
13
  if (token) {
@@ -21,9 +21,14 @@ export async function autoLogin(token) {
21
21
  /**
22
22
  * Вхід аоб на попередню або на кореневу сторінку
23
23
  *
24
- * @param {{}} token
24
+ * @param {Object} decoded
25
25
  */
26
26
  export async function defaultLogin(decoded) {
27
+ // Якщо задано що токен з localStorage
28
+ if (import.meta.env.VITE_TOKEN_STORAGE) {
29
+ return localStorage.setItem(import.meta.env.TOKEN_STORAGE, getToken())
30
+ }
31
+
27
32
  setUser(decoded)
28
33
  const route = sessionStorage.getItem('url-before-logout') || '/'
29
34
  return router.push(route)
package/src/token.js CHANGED
@@ -10,7 +10,7 @@ const allowedRoles = import.meta.env.VITE_HASURA_ROLE.split(',')
10
10
  * та перенаправляємо на сторінку входу
11
11
  *
12
12
  * @param {string} token - JWT токен
13
- * @returns {{result: string, token: {}}} - Повертає результат перевірки токена
13
+ * @returns {{result: string, decoded?: {}}} - Повертає результат перевірки токена
14
14
  */
15
15
  export function checkToken(token) {
16
16
  const decoded = jwtDecode(token)
@@ -38,6 +38,12 @@ export function checkToken(token) {
38
38
  * Токен з кукі
39
39
  */
40
40
  export function getToken() {
41
+ // Якщо задано що токен беремо з localStorage
42
+ if (import.meta.env.VITE_TOKEN_STORAGE) {
43
+ return localStorage.getItem(import.meta.env.TOKEN_STORAGE)
44
+ }
45
+
46
+ // інакше з кукі
41
47
  const cookieObj = new URLSearchParams(document.cookie.replaceAll('; ', '&')) // eslint-disable-line
42
48
  const token = cookieObj.get('__session')
43
49
 
@@ -49,6 +55,13 @@ export function getToken() {
49
55
  */
50
56
  export function cleanToken() {
51
57
  unsetUser()
58
+
59
+ // Якщо задано що токен беремо з localStorage
60
+ // то й видаляємо з localStorage
61
+ if (import.meta.env.VITE_TOKEN_STORAGE) {
62
+ return localStorage.removeItem(import.meta.env.TOKEN_STORAGE)
63
+ }
64
+
52
65
  document.cookie = `__session=; Max-Age=0; path=/; domain=${import.meta.env.VITE_DOMAIN}` // eslint-disable-line
53
66
  }
54
67